@sjcrh/proteinpaint-client 2.166.0 → 2.167.1

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 (882) hide show
  1. package/dist/2dmaf-6M6QWXAQ.js +1364 -0
  2. package/dist/AIProjectAdmin-2NHMC3IV.js +780 -0
  3. package/dist/AppHeader-CTHEWSZD.js +813 -0
  4. package/dist/BoxPlot-3U6ZAKKO.js +44 -0
  5. package/dist/CorrelationVolcano-2ASIR6KY.js +616 -0
  6. package/dist/DifferentialAnalysis-C3NYGF7U.js +237 -0
  7. package/dist/Disco-2QLBZ3X5.js +3089 -0
  8. package/dist/Disco.UI-GPIIPM2P.js +238 -0
  9. package/dist/DziViewer-OHPZOH72.js +16328 -0
  10. package/dist/GB-FH6YQGHI.js +1099 -0
  11. package/dist/HicApp-TI2II3SZ.js +2218 -0
  12. package/dist/NumBinaryEditor-O42T63EX.js +259 -0
  13. package/dist/NumBinaryEditor.unit.spec-UMB2PHT5.js +277 -0
  14. package/dist/NumContEditor-7NOUKPCV.js +98 -0
  15. package/dist/NumContEditor.unit.spec-JGXJ2HLE.js +160 -0
  16. package/dist/NumCustomBinEditor-6CHN3KX3.js +29 -0
  17. package/dist/NumCustomBinEditor.unit.spec-RJPQLE3E.js +275 -0
  18. package/dist/NumDiscreteEditor-AFTUKU4K.js +145 -0
  19. package/dist/NumDiscreteEditor.unit.spec-GKR6ZNBQ.js +193 -0
  20. package/dist/NumRegularBinEditor-UJ5WQPHR.js +29 -0
  21. package/dist/NumRegularBinEditor.unit.spec-5HGJQEX7.js +220 -0
  22. package/dist/NumSplineEditor-JANA2DUE.js +181 -0
  23. package/dist/NumSplineEditor.unit.spec-UYAMAKZD.js +190 -0
  24. package/dist/NumericDensity-YE5R4CNP.js +29 -0
  25. package/dist/NumericDensity.unit.spec-SVEB5U2S.js +212 -0
  26. package/dist/NumericHandler-WW4M7YW2.js +30 -0
  27. package/dist/NumericHandler.unit.spec-2BWDFO53.js +210 -0
  28. package/dist/SC-UGJGMBL7.js +714 -0
  29. package/dist/Volcano-IU76MEIL.js +1018 -0
  30. package/dist/WSIViewer-3S7N4UDO.js +46959 -0
  31. package/dist/WsiSamplesPlot-4CAOHWCL.js +153 -0
  32. package/dist/adSandbox-AEBS3RTL.js +29 -0
  33. package/dist/alphaGenome-F2PB4SGI.js +170 -0
  34. package/dist/app-6SKETLMT.js +28 -0
  35. package/dist/app-GBEF2HBR.js +54 -0
  36. package/dist/app.js +16 -16
  37. package/dist/bam-5SE6XQJV.js +842 -0
  38. package/dist/barchart-AUSOT2XB.js +48 -0
  39. package/dist/barchart.data-GYCNBRPY.js +30 -0
  40. package/dist/barchart.events-QTSWNYXO.js +44 -0
  41. package/dist/barchart.integration.spec-LORJLJVX.js +1600 -0
  42. package/dist/bars.renderer-4N4QOUNI.js +12 -0
  43. package/dist/bars.settings-SDU7PZOS.js +10 -0
  44. package/dist/block-QLSIELXK.js +6291 -0
  45. package/dist/block.init-OOLEA6ZK.js +29 -0
  46. package/dist/block.mds.expressionrank-D2KUISXZ.js +350 -0
  47. package/dist/block.mds.geneboxplot-AMYBWXPS.js +819 -0
  48. package/dist/block.mds.junction-OG335MBK.js +1536 -0
  49. package/dist/block.mds.svcnv-WYDBQ6FV.js +6792 -0
  50. package/dist/block.svg-OH73245R.js +155 -0
  51. package/dist/block.tk.aicheck-CG5THFW2.js +274 -0
  52. package/dist/block.tk.ase-G2L3G5MQ.js +356 -0
  53. package/dist/block.tk.bam-DXWCA6EU.js +1897 -0
  54. package/dist/block.tk.bedgraphdot-LF3TFPNL.js +375 -0
  55. package/dist/block.tk.bigwig.ui-JKXZ3VDF.js +202 -0
  56. package/dist/block.tk.hicstraw-ZK4RKFB6.js +814 -0
  57. package/dist/block.tk.junction-ZB7Q2NLB.js +2355 -0
  58. package/dist/block.tk.junction.textmatrixui-ZYNQWKIW.js +190 -0
  59. package/dist/block.tk.ld-7H64HGER.js +90 -0
  60. package/dist/block.tk.menu-WFVKAH74.js +1020 -0
  61. package/dist/block.tk.pgv-632LLSBI.js +935 -0
  62. package/dist/brainImaging-AEPTHIQF.js +417 -0
  63. package/dist/chat-3XZCAFDD.js +142 -0
  64. package/dist/chat-3XZCAFDD.js.map +7 -0
  65. package/dist/chunk-22O6F463.js +619 -0
  66. package/dist/chunk-2HJ7OD7H.js +252 -0
  67. package/dist/chunk-2MN5JLZB.js +2878 -0
  68. package/dist/chunk-2OVIUIIL.js +1720 -0
  69. package/dist/chunk-2OVIUIIL.js.map +7 -0
  70. package/dist/chunk-37CK5IGW.js +480 -0
  71. package/dist/chunk-3JFEWVHR.js +80 -0
  72. package/dist/chunk-3MGBC64I.js +133 -0
  73. package/dist/chunk-3NWLWH4G.js +6364 -0
  74. package/dist/chunk-46T54RUY.js +1133 -0
  75. package/dist/chunk-46T54RUY.js.map +7 -0
  76. package/dist/chunk-4GKQ5PWY.js +142 -0
  77. package/dist/chunk-4PHD5H4A.js +226 -0
  78. package/dist/chunk-56IFQMJK.js +413 -0
  79. package/dist/chunk-5AMBV2JE.js +797 -0
  80. package/dist/chunk-5AMBV2JE.js.map +7 -0
  81. package/dist/chunk-5DMFTXUZ.js +158 -0
  82. package/dist/chunk-5QJDZHRU.js +95 -0
  83. package/dist/chunk-5WAVKWL6.js +1275 -0
  84. package/dist/chunk-6ISTNHM6.js +144 -0
  85. package/dist/chunk-6VQ4C735.js +1536 -0
  86. package/dist/chunk-74WMSW3E.js +229 -0
  87. package/dist/chunk-AFU66YOW.js +459 -0
  88. package/dist/chunk-AUJ2YUXV.js +14 -0
  89. package/dist/chunk-B65X5UQH.js +518 -0
  90. package/dist/chunk-B6I64LSV.js +634 -0
  91. package/dist/chunk-BAJ74DKS.js +419 -0
  92. package/dist/chunk-BAJ74DKS.js.map +7 -0
  93. package/dist/chunk-BTYCW3D5.js +85 -0
  94. package/dist/chunk-CCB5KYFQ.js +1415 -0
  95. package/dist/chunk-CKLYFA7H.js +467 -0
  96. package/dist/chunk-CLYRJ466.js +272 -0
  97. package/dist/chunk-CPHCZZWT.js +82 -0
  98. package/dist/chunk-CUADOD2T.js +217 -0
  99. package/dist/chunk-CV6ID6T7.js +422 -0
  100. package/dist/chunk-CWHBWY3B.js +190 -0
  101. package/dist/chunk-D53HBTYQ.js +238 -0
  102. package/dist/chunk-DDOM4XYV.js +1177 -0
  103. package/dist/chunk-DDOM4XYV.js.map +7 -0
  104. package/dist/chunk-DKI7YOTJ.js +196 -0
  105. package/dist/chunk-DNU4IPD2.js +165 -0
  106. package/dist/chunk-FN5XPUPH.js +83 -0
  107. package/dist/chunk-FN5XPUPH.js.map +7 -0
  108. package/dist/chunk-GLSDMBHR.js +55 -0
  109. package/dist/chunk-GLSDMBHR.js.map +7 -0
  110. package/dist/chunk-H3BSKMND.js +487 -0
  111. package/dist/chunk-H3BSKMND.js.map +7 -0
  112. package/dist/chunk-H6HP4H3U.js +2327 -0
  113. package/dist/chunk-HPEMEDXB.js +123 -0
  114. package/dist/chunk-HUDESZGX.js +1151 -0
  115. package/dist/chunk-ITJ2SXU5.js +467 -0
  116. package/dist/chunk-ITJ2SXU5.js.map +7 -0
  117. package/dist/chunk-J7IU77CA.js +166 -0
  118. package/dist/chunk-JMO7ENSD.js +381 -0
  119. package/dist/chunk-JTPN3BRG.js +129 -0
  120. package/dist/chunk-KCAMFDJH.js +323 -0
  121. package/dist/chunk-LD45BCVM.js +177 -0
  122. package/dist/chunk-LMELY5Z2.js +1412 -0
  123. package/dist/chunk-LVQK62CV.js +215 -0
  124. package/dist/chunk-MCVLRF66.js +157 -0
  125. package/dist/chunk-MK7RRJTX.js +1968 -0
  126. package/dist/chunk-MK7RRJTX.js.map +7 -0
  127. package/dist/chunk-MLD7DW5I.js +613 -0
  128. package/dist/chunk-NEF7LGNE.js +2789 -0
  129. package/dist/chunk-O7BAQPP3.js +256 -0
  130. package/dist/chunk-O7BAQPP3.js.map +7 -0
  131. package/dist/chunk-OARG7PAV.js +401 -0
  132. package/dist/chunk-OGCF6E6I.js +4947 -0
  133. package/dist/chunk-OGCF6E6I.js.map +7 -0
  134. package/dist/chunk-OGWY4MOB.js +748 -0
  135. package/dist/chunk-PQD6K5W5.js +2784 -0
  136. package/dist/chunk-Q4FYGFTQ.js +91 -0
  137. package/dist/chunk-QX5QVWUP.js +451 -0
  138. package/dist/chunk-QX5QVWUP.js.map +7 -0
  139. package/dist/chunk-RA2KI64U.js +303 -0
  140. package/dist/chunk-RHHLAKYS.js +1088 -0
  141. package/dist/chunk-RKV3CP4C.js +258 -0
  142. package/dist/chunk-RL7RU2V7.js +368 -0
  143. package/dist/chunk-RQ7CE7SK.js +161 -0
  144. package/dist/chunk-RX552WU6.js +1143 -0
  145. package/dist/chunk-S7V4SFKB.js +276 -0
  146. package/dist/chunk-SEL5UNRC.js +142 -0
  147. package/dist/chunk-SRBO57AD.js +297 -0
  148. package/dist/chunk-SYGLOTOV.js +1197 -0
  149. package/dist/chunk-TGZA4ETW.js +311 -0
  150. package/dist/chunk-TGZA4ETW.js.map +7 -0
  151. package/dist/chunk-UZ466XO3.js +203 -0
  152. package/dist/chunk-VDF5W47R.js +149 -0
  153. package/dist/chunk-W4SEWZF2.js +279 -0
  154. package/dist/chunk-W4SEWZF2.js.map +7 -0
  155. package/dist/chunk-W5EG334J.js +15083 -0
  156. package/dist/chunk-W5EG334J.js.map +7 -0
  157. package/dist/chunk-WTPVXDJT.js +31 -0
  158. package/dist/chunk-XRIM2YJZ.js +228 -0
  159. package/dist/chunk-YSWMQO23.js +55 -0
  160. package/dist/chunk-ZBZXIWSK.js +402 -0
  161. package/dist/chunk-ZFFHOEBE.js +117 -0
  162. package/dist/chunk-ZG63ZUDE.js +102 -0
  163. package/dist/chunk-ZGQ3BMLW.js +2676 -0
  164. package/dist/chunk-ZNINQ3FN.js +293 -0
  165. package/dist/chunk-ZQZWM544.js +4172 -0
  166. package/dist/condition-4FVKPSQ2.js +323 -0
  167. package/dist/controls-ZWBN566I.js +35 -0
  168. package/dist/controls.btns-H4TWTHTW.js +10 -0
  169. package/dist/controls.config-YU4W3CDL.js +31 -0
  170. package/dist/correlation-VADB4SQO.js +102 -0
  171. package/dist/cuminc-4BXE2YS6.js +1143 -0
  172. package/dist/cuminc.integration.spec-XQREKHVA.js +669 -0
  173. package/dist/customdata.inputui-VBQWT3M7.js +278 -0
  174. package/dist/dataDownload-QIZKBKH7.js +320 -0
  175. package/dist/dataDownload.integration.spec-MLJEHLYD.js +184 -0
  176. package/dist/databrowser.ui-6UIR4ULJ.js +426 -0
  177. package/dist/dictionary-FLWIWAC6.js +90 -0
  178. package/dist/e2pca-NKWSJRXM.js +341 -0
  179. package/dist/ep-EPN3AR6D.js +1247 -0
  180. package/dist/expclust.gdc.spec-ZRUH5E6E.js +298 -0
  181. package/dist/facet-BM7SLACF.js +437 -0
  182. package/dist/frequencyChart-HBXRIBAW.js +371 -0
  183. package/dist/frequencyChart.integration.spec-YJUYZWM6.js +301 -0
  184. package/dist/geneExpClustering-4VD5PAWN.js +242 -0
  185. package/dist/geneExpression-6OT2Y4P6.js +54 -0
  186. package/dist/geneExpression-EAMEZXJQ.js +310 -0
  187. package/dist/geneORA-RI2AG7JT.js +272 -0
  188. package/dist/geneVariant-FYYEOTWA.js +32 -0
  189. package/dist/geneVariant-PAKVDVC4.js +29 -0
  190. package/dist/genefusion.ui-QWC42XWQ.js +242 -0
  191. package/dist/geneset-XA6IWP3Q.js +186 -0
  192. package/dist/genomeBrowser.spec-LRKXWXNT.js +272 -0
  193. package/dist/grin2-O6TETVZ3.js +1044 -0
  194. package/dist/grin2-O6TETVZ3.js.map +7 -0
  195. package/dist/grin2-WLB7BY3S.js +1547 -0
  196. package/dist/gsea-ZM4WOPSQ.js +43 -0
  197. package/dist/hierCluster-LD43LLRC.js +60 -0
  198. package/dist/hierCluster-ZGYRS2WV.js +56 -0
  199. package/dist/hierCluster.config-O5HUOFNH.js +32 -0
  200. package/dist/hierCluster.integration.spec-37UNKHTH.js +389 -0
  201. package/dist/hierCluster.interactivity-B27ETKRP.js +45 -0
  202. package/dist/hierCluster.renderers-GWFH5ZX7.js +21 -0
  203. package/dist/imagePlot-LJZVGNDJ.js +134 -0
  204. package/dist/importPlot-RMVENQRD.js +8 -0
  205. package/dist/launch.adhoc-S3XHRSLN.js +36 -0
  206. package/dist/leftlabel.sample-J6PCA3UB.js +249 -0
  207. package/dist/lollipop-OZTV4C7A.js +159 -0
  208. package/dist/maf-3SRLCKGO.js +435 -0
  209. package/dist/maf-3SRLCKGO.js.map +7 -0
  210. package/dist/maftimeline-6F2LQJU6.js +584 -0
  211. package/dist/matrix-FIXOFAB4.js +60 -0
  212. package/dist/matrix-O5KPDLM2.js +55 -0
  213. package/dist/matrix.cells-SCLZA3P4.js +30 -0
  214. package/dist/matrix.config-WG7HFJL4.js +33 -0
  215. package/dist/matrix.controls-QQLBUUYP.js +31 -0
  216. package/dist/matrix.data-6JLF5HVI.js +35 -0
  217. package/dist/matrix.dom-QO7BXZ27.js +11 -0
  218. package/dist/matrix.groups-QMZMZ6Q7.js +26 -0
  219. package/dist/matrix.integration.spec-ZJYWNQ57.js +2936 -0
  220. package/dist/matrix.interactivity-ZZY5ET4E.js +36 -0
  221. package/dist/matrix.layout-XKFB4PKY.js +35 -0
  222. package/dist/matrix.legend-CS6DNC5V.js +22 -0
  223. package/dist/matrix.renderers-4LST6PBA.js +29 -0
  224. package/dist/matrix.serieses-3SERD6CV.js +21 -0
  225. package/dist/matrix.sort-UVS6WHIS.js +27 -0
  226. package/dist/matrix.sort.unit.spec-CTSUNUWB.js +464 -0
  227. package/dist/matrix.sorterUi-JDGLTLJM.js +18 -0
  228. package/dist/matrix.sorterUi.unit.spec-VQFMHIYI.js +335 -0
  229. package/dist/mavb-ECQ2CQ7F.js +723 -0
  230. package/dist/mds.fimo-JDYDT5NK.js +509 -0
  231. package/dist/mds.samplescatterplot-PEJBVSTO.js +1541 -0
  232. package/dist/mds.survivalplot-GYK6VRQT.js +474 -0
  233. package/dist/mutationSignature-43SECPTY.js +72 -0
  234. package/dist/numericDictTermCluster-2ER4FUKO.js +72 -0
  235. package/dist/oncomatrix-ZXDJMLN3.js +287 -0
  236. package/dist/oncomatrix.spec-HOPRIG3I.js +439 -0
  237. package/dist/plot.2dvaf-Y4SZUHLD.js +368 -0
  238. package/dist/plot.app-W5Z3C7P5.js +35 -0
  239. package/dist/plot.barplot-B2PRZDKV.js +93 -0
  240. package/dist/plot.boxplot-J7ET34FY.js +143 -0
  241. package/dist/plot.brainImaging-ISY4P6RT.js +51 -0
  242. package/dist/plot.disco-D7AL42PW.js +100 -0
  243. package/dist/plot.dzi-O32LH65U.js +33 -0
  244. package/dist/plot.ssgq-WF7262IZ.js +130 -0
  245. package/dist/plot.vaf2cov-OB6UKSFQ.js +250 -0
  246. package/dist/plot.wsi-J5S4YYXN.js +36 -0
  247. package/dist/polar-LIJORXR6.js +179 -0
  248. package/dist/profile.spec-3KE4CREI.js +71 -0
  249. package/dist/profileBarchart-UQHOJB5V.js +260 -0
  250. package/dist/profileForms-WTYVTIUN.js +365 -0
  251. package/dist/profilePlot-SOXXEUAT.js +50 -0
  252. package/dist/profileRadar-2OHJ2RIU.js +256 -0
  253. package/dist/profileRadarFacility-GHLG3QNG.js +256 -0
  254. package/dist/qualitative-B3OY7A7P.js +34 -0
  255. package/dist/regression-HO2TO4XT.js +57 -0
  256. package/dist/regression.inputs-JN3ZMIOP.js +49 -0
  257. package/dist/regression.inputs.term-67HVMXFZ.js +49 -0
  258. package/dist/regression.inputs.values.table-JXJK2YZT.js +46 -0
  259. package/dist/regression.integration.spec-L54ZS5VY.js +777 -0
  260. package/dist/regression.results-3ZSFKUNN.js +31 -0
  261. package/dist/regression.spec-SVWCQX2U.js +699 -0
  262. package/dist/report-IHX7XSOI.js +220 -0
  263. package/dist/runChart-QLQMK3OE.js +54 -0
  264. package/dist/runchart.integration.spec-5NVY5GHR.js +362 -0
  265. package/dist/sampleScatter.spec-4Q5CQQWH.js +193 -0
  266. package/dist/sampleView-7WHDFHB5.js +42 -0
  267. package/dist/samplelst-34GJVLVD.js +102 -0
  268. package/dist/samplematrix-L2HOSLUT.js +2189 -0
  269. package/dist/scatter-X6AAM2LJ.js +55 -0
  270. package/dist/scatter.integration.spec-QSH3PLBK.js +1026 -0
  271. package/dist/selectGenomeWithTklst-AJS2IPPW.js +125 -0
  272. package/dist/singleCellPlot-7JEWDVSR.js +50 -0
  273. package/dist/singlecell-IC5KU72L.js +1563 -0
  274. package/dist/singlecell-NWANPXWM.js +80 -0
  275. package/dist/snp-PSRNMTL6.js +73 -0
  276. package/dist/snplocus-QCAVDYLR.js +199 -0
  277. package/dist/spliceevent.a53ss.diagram-SGDJKUEC.js +142 -0
  278. package/dist/spliceevent.exonskip.diagram-BUYTHCK5.js +268 -0
  279. package/dist/spliceevent.noeventdiagram-OJZJUHXP.js +451 -0
  280. package/dist/ssGSEA-UUZG57MF.js +53 -0
  281. package/dist/stattable-324FS2HA.js +89 -0
  282. package/dist/summarizeCnvGeneexp-ZVZYWP43.js +136 -0
  283. package/dist/summarizeGeneexpSurvival-7XJRMT6M.js +90 -0
  284. package/dist/summarizeMutationDiagnosis-ZKLXOVY2.js +32 -0
  285. package/dist/summarizeMutationSurvival-S4YPGLWA.js +92 -0
  286. package/dist/summary-RVG7JL6Y.js +55 -0
  287. package/dist/summary.integration.spec-SCD35GO4.js +405 -0
  288. package/dist/summaryInput-DMN6DTSW.js +170 -0
  289. package/dist/sunburst-QZXYILRC.js +275 -0
  290. package/dist/survival-6CWEBRSF.js +41 -0
  291. package/dist/survival-J657VYLI.js +49 -0
  292. package/dist/survival.integration.spec-S5WE4V6M.js +601 -0
  293. package/dist/svgraph-NEKJL24M.js +1378 -0
  294. package/dist/svmr-5RQ5JQF2.js +3833 -0
  295. package/dist/table-CG6Z6NCJ.js +193 -0
  296. package/dist/termCollection-FOQNVXB7.js +80 -0
  297. package/dist/termInfo-5USFZGDB.js +9 -0
  298. package/dist/tk-2O7XOVGJ.js +37 -0
  299. package/dist/tp.ui-S4YUVCZH.js +1450 -0
  300. package/dist/tvs.dtcnv.continuous-7BPIXZ6C.js +65 -0
  301. package/dist/tvs.numeric-FCC2EY62.js +355 -0
  302. package/dist/tvs.samplelst-PKGFTULN.js +95 -0
  303. package/dist/violin-C7IBRTYP.js +47 -0
  304. package/dist/violin.integration.spec-WXRD3Z4E.js +1425 -0
  305. package/dist/violin.interactivity-BMG4TG5L.js +39 -0
  306. package/dist/violin.renderer-WUNW6ULV.js +31 -0
  307. package/dist/vocabulary-UUNEEBM3.js +32 -0
  308. package/package.json +3 -3
  309. package/dist/2dmaf-E4NOGWWO.js +0 -1364
  310. package/dist/AIProjectAdmin-3QDXMCOK.js +0 -780
  311. package/dist/AppHeader-IFZ57DJE.js +0 -813
  312. package/dist/BoxPlot-GXDTPRA5.js +0 -44
  313. package/dist/CorrelationVolcano-S4GUYIPT.js +0 -616
  314. package/dist/DifferentialAnalysis-YLKYWPUT.js +0 -237
  315. package/dist/Disco-OQMP3HRQ.js +0 -3089
  316. package/dist/Disco.UI-XB3XQP33.js +0 -238
  317. package/dist/DziViewer-UIRNTFNS.js +0 -16328
  318. package/dist/GB-KDPJTOLP.js +0 -1099
  319. package/dist/HicApp-XJERMLKH.js +0 -2218
  320. package/dist/NumBinaryEditor-5MWWWNLW.js +0 -259
  321. package/dist/NumBinaryEditor.unit.spec-ROGT5FOH.js +0 -277
  322. package/dist/NumContEditor-RRCB4CKG.js +0 -98
  323. package/dist/NumContEditor.unit.spec-AJTKOF7W.js +0 -160
  324. package/dist/NumCustomBinEditor-3GJITZ7V.js +0 -29
  325. package/dist/NumCustomBinEditor.unit.spec-DNBDZSHT.js +0 -275
  326. package/dist/NumDiscreteEditor-TARWA6CZ.js +0 -145
  327. package/dist/NumDiscreteEditor.unit.spec-TCSLTQ25.js +0 -193
  328. package/dist/NumRegularBinEditor-QF5ALVV4.js +0 -29
  329. package/dist/NumRegularBinEditor.unit.spec-GFNDBWNM.js +0 -220
  330. package/dist/NumSplineEditor-MOEUXR34.js +0 -181
  331. package/dist/NumSplineEditor.unit.spec-XPJOOXS4.js +0 -190
  332. package/dist/NumericDensity-JDE263EQ.js +0 -29
  333. package/dist/NumericDensity.unit.spec-RX6UGV56.js +0 -212
  334. package/dist/NumericHandler-XM7LUYHN.js +0 -30
  335. package/dist/NumericHandler.unit.spec-5EYRMII7.js +0 -210
  336. package/dist/SC-Z4KBNK7P.js +0 -714
  337. package/dist/Volcano-WYJLKM4K.js +0 -1018
  338. package/dist/WSIViewer-3RMG3VOA.js +0 -46959
  339. package/dist/WsiSamplesPlot-PAWNKI7R.js +0 -153
  340. package/dist/adSandbox-7H5H46SE.js +0 -29
  341. package/dist/alphaGenome-PODWDV5T.js +0 -170
  342. package/dist/app-JPURIGQW.js +0 -28
  343. package/dist/app-YL7S55T5.js +0 -54
  344. package/dist/bam-XEO47VYA.js +0 -842
  345. package/dist/barchart-B5M6SSJH.js +0 -48
  346. package/dist/barchart.data-6A6WVV4Y.js +0 -30
  347. package/dist/barchart.events-2GNB5KWY.js +0 -44
  348. package/dist/barchart.integration.spec-JEOTKIWC.js +0 -1600
  349. package/dist/bars.renderer-NLUBMQEO.js +0 -12
  350. package/dist/bars.settings-UQZ63KU4.js +0 -8
  351. package/dist/block-B7WMYLPO.js +0 -6291
  352. package/dist/block.init-KCIXEYQC.js +0 -29
  353. package/dist/block.mds.expressionrank-RYZXAH5Y.js +0 -350
  354. package/dist/block.mds.geneboxplot-LNWUEI6N.js +0 -819
  355. package/dist/block.mds.junction-CVIY7QMD.js +0 -1536
  356. package/dist/block.mds.svcnv-EUGWHSCA.js +0 -6792
  357. package/dist/block.svg-QBLNIGUF.js +0 -155
  358. package/dist/block.tk.aicheck-U6NG22FX.js +0 -274
  359. package/dist/block.tk.ase-U3TRZAOH.js +0 -356
  360. package/dist/block.tk.bam-6Y6YFVR2.js +0 -1897
  361. package/dist/block.tk.bedgraphdot-O3VCFX6K.js +0 -375
  362. package/dist/block.tk.bigwig.ui-DNBJAF72.js +0 -202
  363. package/dist/block.tk.hicstraw-2EIFJX7E.js +0 -814
  364. package/dist/block.tk.junction-UXSO5EJP.js +0 -2355
  365. package/dist/block.tk.junction.textmatrixui-HQ6ZKCHM.js +0 -190
  366. package/dist/block.tk.ld-NEB4F3UG.js +0 -90
  367. package/dist/block.tk.menu-BN4JPJSD.js +0 -1020
  368. package/dist/block.tk.pgv-A4QFVSPF.js +0 -935
  369. package/dist/brainImaging-ESQGNGZH.js +0 -417
  370. package/dist/chat-AY7RCQYY.js +0 -145
  371. package/dist/chat-AY7RCQYY.js.map +0 -7
  372. package/dist/chunk-236ZRGXA.js +0 -297
  373. package/dist/chunk-2DZWOGEH.js +0 -272
  374. package/dist/chunk-2HQJMZNY.js +0 -14
  375. package/dist/chunk-2MRZFUHZ.js +0 -165
  376. package/dist/chunk-2ZEORJCF.js +0 -215
  377. package/dist/chunk-3WA7SJTR.js +0 -82
  378. package/dist/chunk-47HG7LGD.js +0 -133
  379. package/dist/chunk-47X254B7.js +0 -91
  380. package/dist/chunk-4TPDYPGD.js +0 -1098
  381. package/dist/chunk-4TPDYPGD.js.map +0 -7
  382. package/dist/chunk-4WA2H5DE.js +0 -75
  383. package/dist/chunk-4WA2H5DE.js.map +0 -7
  384. package/dist/chunk-4XDKCFFT.js +0 -613
  385. package/dist/chunk-5CJJLBUZ.js +0 -229
  386. package/dist/chunk-5TDKRZN5.js +0 -1931
  387. package/dist/chunk-5TDKRZN5.js.map +0 -7
  388. package/dist/chunk-6MSJ3TLQ.js +0 -1151
  389. package/dist/chunk-7JAFXNAL.js +0 -256
  390. package/dist/chunk-7JAFXNAL.js.map +0 -7
  391. package/dist/chunk-7LKSKJCV.js +0 -480
  392. package/dist/chunk-7P67W6NF.js +0 -190
  393. package/dist/chunk-7RIC35AF.js +0 -129
  394. package/dist/chunk-A76B53VT.js +0 -158
  395. package/dist/chunk-AZ276Z7T.js +0 -2327
  396. package/dist/chunk-B662XJMJ.js +0 -748
  397. package/dist/chunk-BK7GIOC5.js +0 -4924
  398. package/dist/chunk-BK7GIOC5.js.map +0 -7
  399. package/dist/chunk-BP2F2GRB.js +0 -2676
  400. package/dist/chunk-BRO4KZSZ.js +0 -417
  401. package/dist/chunk-BRO4KZSZ.js.map +0 -7
  402. package/dist/chunk-C5YNONHQ.js +0 -144
  403. package/dist/chunk-CT3LPTWW.js +0 -1197
  404. package/dist/chunk-CZTC4MTE.js +0 -161
  405. package/dist/chunk-DA5VGV5L.js +0 -280
  406. package/dist/chunk-DA5VGV5L.js.map +0 -7
  407. package/dist/chunk-DPU66MZ7.js +0 -381
  408. package/dist/chunk-E6NE5IWR.js +0 -102
  409. package/dist/chunk-ECKWM4HB.js +0 -1536
  410. package/dist/chunk-EEX5VPJG.js +0 -467
  411. package/dist/chunk-EIMEUZP2.js +0 -323
  412. package/dist/chunk-ETFPL4UP.js +0 -4172
  413. package/dist/chunk-F3FTQWTA.js +0 -303
  414. package/dist/chunk-F4APZ34G.js +0 -55
  415. package/dist/chunk-FOXJTDTH.js +0 -166
  416. package/dist/chunk-FYTZCTJC.js +0 -1157
  417. package/dist/chunk-FYTZCTJC.js.map +0 -7
  418. package/dist/chunk-GBS5I24E.js +0 -1706
  419. package/dist/chunk-GBS5I24E.js.map +0 -7
  420. package/dist/chunk-GBWRKJAH.js +0 -413
  421. package/dist/chunk-GG67VPVD.js +0 -238
  422. package/dist/chunk-GZ2B634M.js +0 -123
  423. package/dist/chunk-HEFXMCSF.js +0 -6364
  424. package/dist/chunk-I26R4NJJ.js +0 -228
  425. package/dist/chunk-I2GCD26Y.js +0 -55
  426. package/dist/chunk-I2GCD26Y.js.map +0 -7
  427. package/dist/chunk-ICNJQHQZ.js +0 -117
  428. package/dist/chunk-IPAGDFO4.js +0 -80
  429. package/dist/chunk-J2E4FALN.js +0 -1415
  430. package/dist/chunk-JXHU2FIA.js +0 -2789
  431. package/dist/chunk-K7LZ77GD.js +0 -468
  432. package/dist/chunk-K7LZ77GD.js.map +0 -7
  433. package/dist/chunk-KACWSU3U.js +0 -487
  434. package/dist/chunk-KACWSU3U.js.map +0 -7
  435. package/dist/chunk-KGSCQRQ5.js +0 -203
  436. package/dist/chunk-KGYPMYQD.js +0 -1143
  437. package/dist/chunk-L3PMRBTA.js +0 -422
  438. package/dist/chunk-M7QVMSRW.js +0 -293
  439. package/dist/chunk-MG6GRQKO.js +0 -459
  440. package/dist/chunk-N5VBIEH5.js +0 -1412
  441. package/dist/chunk-NRYOB7WU.js +0 -252
  442. package/dist/chunk-NXOWHUR4.js +0 -311
  443. package/dist/chunk-NXOWHUR4.js.map +0 -7
  444. package/dist/chunk-OFQV6PRB.js +0 -1275
  445. package/dist/chunk-OMO754MK.js +0 -177
  446. package/dist/chunk-OQSP66C6.js +0 -226
  447. package/dist/chunk-OS46MR72.js +0 -368
  448. package/dist/chunk-PBJFLQGL.js +0 -142
  449. package/dist/chunk-PMZS3SHH.js +0 -2877
  450. package/dist/chunk-PPJSDC3Z.js +0 -157
  451. package/dist/chunk-QIS45Z4Y.js +0 -2784
  452. package/dist/chunk-RCVZ4L7K.js +0 -402
  453. package/dist/chunk-ROWCKPNW.js +0 -1088
  454. package/dist/chunk-RQUXELHE.js +0 -276
  455. package/dist/chunk-RYRCMHYR.js +0 -196
  456. package/dist/chunk-S7EKSDVS.js +0 -258
  457. package/dist/chunk-SN5QKRXO.js +0 -85
  458. package/dist/chunk-TZRD3FPN.js +0 -634
  459. package/dist/chunk-U5QRRS7K.js +0 -619
  460. package/dist/chunk-UOMRXQNW.js +0 -401
  461. package/dist/chunk-UT6W4ZZL.js +0 -15048
  462. package/dist/chunk-UT6W4ZZL.js.map +0 -7
  463. package/dist/chunk-UZV3QI5M.js +0 -518
  464. package/dist/chunk-VALBVQXS.js +0 -217
  465. package/dist/chunk-VDR5JXI2.js +0 -444
  466. package/dist/chunk-VDR5JXI2.js.map +0 -7
  467. package/dist/chunk-W4D2EYE4.js +0 -95
  468. package/dist/chunk-XATIKUGU.js +0 -142
  469. package/dist/chunk-ZHWC5SJP.js +0 -797
  470. package/dist/chunk-ZHWC5SJP.js.map +0 -7
  471. package/dist/chunk-ZL4CNBYY.js +0 -149
  472. package/dist/chunk-ZQ7L66GP.js +0 -31
  473. package/dist/condition-24HPVH23.js +0 -323
  474. package/dist/controls-5CSAKANR.js +0 -35
  475. package/dist/controls.btns-QLLBCT65.js +0 -10
  476. package/dist/controls.config-H4FMU5LI.js +0 -31
  477. package/dist/correlation-RB77VSXB.js +0 -102
  478. package/dist/cuminc-YZSLH5IO.js +0 -1143
  479. package/dist/cuminc.integration.spec-MZPT3Y5A.js +0 -669
  480. package/dist/customdata.inputui-CBTZFODT.js +0 -278
  481. package/dist/dataDownload-ZTGRVI4Q.js +0 -320
  482. package/dist/dataDownload.integration.spec-Q6GUTUYD.js +0 -184
  483. package/dist/databrowser.ui-V7E6CLUZ.js +0 -426
  484. package/dist/dictionary-RPC5OZMM.js +0 -90
  485. package/dist/e2pca-WDQHMAUM.js +0 -341
  486. package/dist/ep-NAM34BBI.js +0 -1247
  487. package/dist/expclust.gdc.spec-QB4GVDJA.js +0 -298
  488. package/dist/facet-DOXBBIG6.js +0 -437
  489. package/dist/frequencyChart-GLOIGP3T.js +0 -371
  490. package/dist/frequencyChart.integration.spec-B7NBBLH2.js +0 -301
  491. package/dist/geneExpClustering-B4S6GFNT.js +0 -242
  492. package/dist/geneExpression-DMU4AQP6.js +0 -310
  493. package/dist/geneExpression-MVVXRNEY.js +0 -54
  494. package/dist/geneORA-XDAITCQF.js +0 -272
  495. package/dist/geneVariant-N6IGEIRR.js +0 -29
  496. package/dist/geneVariant-QYLA2V6J.js +0 -32
  497. package/dist/genefusion.ui-FRBMNK7V.js +0 -242
  498. package/dist/geneset-GZYNBG7Y.js +0 -186
  499. package/dist/genomeBrowser.spec-WFIVQSE7.js +0 -272
  500. package/dist/grin2-I6GJF35U.js +0 -882
  501. package/dist/grin2-I6GJF35U.js.map +0 -7
  502. package/dist/grin2-ZKNNZXON.js +0 -1547
  503. package/dist/gsea-GFGAEC4K.js +0 -43
  504. package/dist/hierCluster-MF4TI3E4.js +0 -60
  505. package/dist/hierCluster-SDJMQLOQ.js +0 -56
  506. package/dist/hierCluster.config-RMEX3VTC.js +0 -32
  507. package/dist/hierCluster.integration.spec-3H63OHMU.js +0 -389
  508. package/dist/hierCluster.interactivity-4DZBRQ6P.js +0 -45
  509. package/dist/hierCluster.renderers-UOW7BI6N.js +0 -21
  510. package/dist/imagePlot-P2UHJRSL.js +0 -134
  511. package/dist/importPlot-PPCMNVOW.js +0 -8
  512. package/dist/launch.adhoc-RJWUEVRA.js +0 -36
  513. package/dist/leftlabel.sample-OYP6MICL.js +0 -249
  514. package/dist/lollipop-BXQOWLGO.js +0 -159
  515. package/dist/maf-YJJO773K.js +0 -448
  516. package/dist/maf-YJJO773K.js.map +0 -7
  517. package/dist/maftimeline-GHKDDWYR.js +0 -584
  518. package/dist/matrix-FWDLHZYR.js +0 -60
  519. package/dist/matrix-YMJFP53F.js +0 -55
  520. package/dist/matrix.cells-JH7FPY3E.js +0 -30
  521. package/dist/matrix.config-HIHOLDCE.js +0 -33
  522. package/dist/matrix.controls-EKZ543FY.js +0 -31
  523. package/dist/matrix.data-NKAZI2BF.js +0 -35
  524. package/dist/matrix.dom-RGZ52GJ2.js +0 -11
  525. package/dist/matrix.groups-BO53ZXXV.js +0 -26
  526. package/dist/matrix.integration.spec-BXTATNAC.js +0 -2936
  527. package/dist/matrix.interactivity-UGUMKCFN.js +0 -36
  528. package/dist/matrix.layout-WBIF5QTG.js +0 -35
  529. package/dist/matrix.legend-P3GFCXXK.js +0 -22
  530. package/dist/matrix.renderers-I54IHQ3S.js +0 -29
  531. package/dist/matrix.serieses-R2T57OYI.js +0 -21
  532. package/dist/matrix.sort-3GCA2GDU.js +0 -27
  533. package/dist/matrix.sort.unit.spec-AXGPCZZD.js +0 -464
  534. package/dist/matrix.sorterUi-QWRK6OGE.js +0 -18
  535. package/dist/matrix.sorterUi.unit.spec-H7GUVWRJ.js +0 -335
  536. package/dist/mavb-4EECWXYX.js +0 -723
  537. package/dist/mds.fimo-NHZOY43X.js +0 -509
  538. package/dist/mds.samplescatterplot-7A5IZ6W7.js +0 -1541
  539. package/dist/mds.survivalplot-SQDPUFQE.js +0 -474
  540. package/dist/mutationSignature-QH7PZYKL.js +0 -72
  541. package/dist/numericDictTermCluster-X5SGSC5K.js +0 -72
  542. package/dist/oncomatrix-M4C4XPQK.js +0 -287
  543. package/dist/oncomatrix.spec-3C642O7O.js +0 -439
  544. package/dist/plot.2dvaf-TILP7J53.js +0 -368
  545. package/dist/plot.app-DE2UQP2M.js +0 -35
  546. package/dist/plot.barplot-FJHS765K.js +0 -93
  547. package/dist/plot.boxplot-YRSHGNYZ.js +0 -143
  548. package/dist/plot.brainImaging-JV4OUVJY.js +0 -51
  549. package/dist/plot.disco-DBVPBMLG.js +0 -100
  550. package/dist/plot.dzi-O2OA4EBK.js +0 -33
  551. package/dist/plot.ssgq-YFQEZQYK.js +0 -130
  552. package/dist/plot.vaf2cov-YNFP5LJ4.js +0 -250
  553. package/dist/plot.wsi-DJB7TDIS.js +0 -36
  554. package/dist/polar-K5Z5FYKV.js +0 -179
  555. package/dist/profile.spec-A6EADWEC.js +0 -71
  556. package/dist/profileBarchart-EFLPJK2P.js +0 -260
  557. package/dist/profileForms-TG35YNLD.js +0 -365
  558. package/dist/profilePlot-2EW2XVTK.js +0 -50
  559. package/dist/profileRadar-AKUYC2O5.js +0 -256
  560. package/dist/profileRadarFacility-EAT66XTX.js +0 -256
  561. package/dist/qualitative-PHQU5DXE.js +0 -34
  562. package/dist/regression-EOMJRRDO.js +0 -57
  563. package/dist/regression.inputs-LIH5X2JM.js +0 -49
  564. package/dist/regression.inputs.term-OO4RZ3QB.js +0 -49
  565. package/dist/regression.inputs.values.table-E7WCTO2L.js +0 -46
  566. package/dist/regression.integration.spec-62VEQP6X.js +0 -777
  567. package/dist/regression.results-WAHFJ6NA.js +0 -31
  568. package/dist/regression.spec-IBIOTZVX.js +0 -699
  569. package/dist/report-MKDJXHGY.js +0 -220
  570. package/dist/runChart-ETM2EETF.js +0 -54
  571. package/dist/runchart.integration.spec-QFA4XBKB.js +0 -362
  572. package/dist/sampleScatter.spec-N4N7ZGZF.js +0 -193
  573. package/dist/sampleView-JTY3RV7I.js +0 -42
  574. package/dist/samplelst-RRUMBVT6.js +0 -102
  575. package/dist/samplematrix-L37O664Y.js +0 -2189
  576. package/dist/scatter-E5QHW32W.js +0 -55
  577. package/dist/scatter.integration.spec-FNVAJSVU.js +0 -1026
  578. package/dist/selectGenomeWithTklst-J6VXCYGG.js +0 -125
  579. package/dist/singleCellPlot-S6S6CKYX.js +0 -50
  580. package/dist/singlecell-4BMIKFY4.js +0 -80
  581. package/dist/singlecell-B4TNI23F.js +0 -1563
  582. package/dist/snp-PAUQ24NZ.js +0 -73
  583. package/dist/snplocus-HVFYZTEE.js +0 -199
  584. package/dist/spliceevent.a53ss.diagram-GGGHVNBF.js +0 -142
  585. package/dist/spliceevent.exonskip.diagram-HLMFD6LJ.js +0 -268
  586. package/dist/spliceevent.noeventdiagram-CKZ3BZ7Y.js +0 -451
  587. package/dist/ssGSEA-UGT4GH55.js +0 -53
  588. package/dist/stattable-6JWMALGB.js +0 -89
  589. package/dist/summarizeCnvGeneexp-BJOQY62E.js +0 -136
  590. package/dist/summarizeGeneexpSurvival-4HDHL7PE.js +0 -90
  591. package/dist/summarizeMutationDiagnosis-TDWO5CKU.js +0 -32
  592. package/dist/summarizeMutationSurvival-CJJFABOX.js +0 -92
  593. package/dist/summary-WOAXXIHG.js +0 -55
  594. package/dist/summary.integration.spec-GM73ERMN.js +0 -405
  595. package/dist/summaryInput-FD4SONTY.js +0 -170
  596. package/dist/sunburst-3LCJTBRN.js +0 -275
  597. package/dist/survival-A3A7IVXT.js +0 -41
  598. package/dist/survival-XF72VMM6.js +0 -49
  599. package/dist/survival.integration.spec-AU7MCAQV.js +0 -601
  600. package/dist/svgraph-BEMS4JDJ.js +0 -1378
  601. package/dist/svmr-CDEMTZPK.js +0 -3833
  602. package/dist/table-WYF6QCGB.js +0 -193
  603. package/dist/termCollection-BVQMNVY7.js +0 -80
  604. package/dist/termInfo-JXLIVCSO.js +0 -9
  605. package/dist/tk-TGIIJYBO.js +0 -37
  606. package/dist/tp.ui-USYF67P7.js +0 -1450
  607. package/dist/tvs.dtcnv.continuous-7SCTSFK3.js +0 -65
  608. package/dist/tvs.numeric-OLVW6US3.js +0 -355
  609. package/dist/tvs.samplelst-BHZHCX5V.js +0 -95
  610. package/dist/violin-OEOWVIZF.js +0 -47
  611. package/dist/violin.integration.spec-AW2U3RHO.js +0 -1425
  612. package/dist/violin.interactivity-3O2UDNPQ.js +0 -39
  613. package/dist/violin.renderer-W26FA6M7.js +0 -31
  614. package/dist/vocabulary-BIQYDKVY.js +0 -32
  615. /package/dist/{2dmaf-E4NOGWWO.js.map → 2dmaf-6M6QWXAQ.js.map} +0 -0
  616. /package/dist/{AIProjectAdmin-3QDXMCOK.js.map → AIProjectAdmin-2NHMC3IV.js.map} +0 -0
  617. /package/dist/{AppHeader-IFZ57DJE.js.map → AppHeader-CTHEWSZD.js.map} +0 -0
  618. /package/dist/{BoxPlot-GXDTPRA5.js.map → BoxPlot-3U6ZAKKO.js.map} +0 -0
  619. /package/dist/{CorrelationVolcano-S4GUYIPT.js.map → CorrelationVolcano-2ASIR6KY.js.map} +0 -0
  620. /package/dist/{DifferentialAnalysis-YLKYWPUT.js.map → DifferentialAnalysis-C3NYGF7U.js.map} +0 -0
  621. /package/dist/{Disco-OQMP3HRQ.js.map → Disco-2QLBZ3X5.js.map} +0 -0
  622. /package/dist/{Disco.UI-XB3XQP33.js.map → Disco.UI-GPIIPM2P.js.map} +0 -0
  623. /package/dist/{DziViewer-UIRNTFNS.js.map → DziViewer-OHPZOH72.js.map} +0 -0
  624. /package/dist/{GB-KDPJTOLP.js.map → GB-FH6YQGHI.js.map} +0 -0
  625. /package/dist/{HicApp-XJERMLKH.js.map → HicApp-TI2II3SZ.js.map} +0 -0
  626. /package/dist/{NumBinaryEditor-5MWWWNLW.js.map → NumBinaryEditor-O42T63EX.js.map} +0 -0
  627. /package/dist/{NumBinaryEditor.unit.spec-ROGT5FOH.js.map → NumBinaryEditor.unit.spec-UMB2PHT5.js.map} +0 -0
  628. /package/dist/{NumContEditor-RRCB4CKG.js.map → NumContEditor-7NOUKPCV.js.map} +0 -0
  629. /package/dist/{NumContEditor.unit.spec-AJTKOF7W.js.map → NumContEditor.unit.spec-JGXJ2HLE.js.map} +0 -0
  630. /package/dist/{NumCustomBinEditor-3GJITZ7V.js.map → NumCustomBinEditor-6CHN3KX3.js.map} +0 -0
  631. /package/dist/{NumCustomBinEditor.unit.spec-DNBDZSHT.js.map → NumCustomBinEditor.unit.spec-RJPQLE3E.js.map} +0 -0
  632. /package/dist/{NumDiscreteEditor-TARWA6CZ.js.map → NumDiscreteEditor-AFTUKU4K.js.map} +0 -0
  633. /package/dist/{NumDiscreteEditor.unit.spec-TCSLTQ25.js.map → NumDiscreteEditor.unit.spec-GKR6ZNBQ.js.map} +0 -0
  634. /package/dist/{NumRegularBinEditor-QF5ALVV4.js.map → NumRegularBinEditor-UJ5WQPHR.js.map} +0 -0
  635. /package/dist/{NumRegularBinEditor.unit.spec-GFNDBWNM.js.map → NumRegularBinEditor.unit.spec-5HGJQEX7.js.map} +0 -0
  636. /package/dist/{NumSplineEditor-MOEUXR34.js.map → NumSplineEditor-JANA2DUE.js.map} +0 -0
  637. /package/dist/{NumSplineEditor.unit.spec-XPJOOXS4.js.map → NumSplineEditor.unit.spec-UYAMAKZD.js.map} +0 -0
  638. /package/dist/{NumericDensity-JDE263EQ.js.map → NumericDensity-YE5R4CNP.js.map} +0 -0
  639. /package/dist/{NumericDensity.unit.spec-RX6UGV56.js.map → NumericDensity.unit.spec-SVEB5U2S.js.map} +0 -0
  640. /package/dist/{NumericHandler-XM7LUYHN.js.map → NumericHandler-WW4M7YW2.js.map} +0 -0
  641. /package/dist/{NumericHandler.unit.spec-5EYRMII7.js.map → NumericHandler.unit.spec-2BWDFO53.js.map} +0 -0
  642. /package/dist/{SC-Z4KBNK7P.js.map → SC-UGJGMBL7.js.map} +0 -0
  643. /package/dist/{Volcano-WYJLKM4K.js.map → Volcano-IU76MEIL.js.map} +0 -0
  644. /package/dist/{WSIViewer-3RMG3VOA.js.map → WSIViewer-3S7N4UDO.js.map} +0 -0
  645. /package/dist/{WsiSamplesPlot-PAWNKI7R.js.map → WsiSamplesPlot-4CAOHWCL.js.map} +0 -0
  646. /package/dist/{adSandbox-7H5H46SE.js.map → adSandbox-AEBS3RTL.js.map} +0 -0
  647. /package/dist/{alphaGenome-PODWDV5T.js.map → alphaGenome-F2PB4SGI.js.map} +0 -0
  648. /package/dist/{app-JPURIGQW.js.map → app-6SKETLMT.js.map} +0 -0
  649. /package/dist/{app-YL7S55T5.js.map → app-GBEF2HBR.js.map} +0 -0
  650. /package/dist/{bam-XEO47VYA.js.map → bam-5SE6XQJV.js.map} +0 -0
  651. /package/dist/{barchart-B5M6SSJH.js.map → barchart-AUSOT2XB.js.map} +0 -0
  652. /package/dist/{barchart.data-6A6WVV4Y.js.map → barchart.data-GYCNBRPY.js.map} +0 -0
  653. /package/dist/{barchart.events-2GNB5KWY.js.map → barchart.events-QTSWNYXO.js.map} +0 -0
  654. /package/dist/{barchart.integration.spec-JEOTKIWC.js.map → barchart.integration.spec-LORJLJVX.js.map} +0 -0
  655. /package/dist/{bars.renderer-NLUBMQEO.js.map → bars.renderer-4N4QOUNI.js.map} +0 -0
  656. /package/dist/{bars.settings-UQZ63KU4.js.map → bars.settings-SDU7PZOS.js.map} +0 -0
  657. /package/dist/{block-B7WMYLPO.js.map → block-QLSIELXK.js.map} +0 -0
  658. /package/dist/{block.init-KCIXEYQC.js.map → block.init-OOLEA6ZK.js.map} +0 -0
  659. /package/dist/{block.mds.expressionrank-RYZXAH5Y.js.map → block.mds.expressionrank-D2KUISXZ.js.map} +0 -0
  660. /package/dist/{block.mds.geneboxplot-LNWUEI6N.js.map → block.mds.geneboxplot-AMYBWXPS.js.map} +0 -0
  661. /package/dist/{block.mds.junction-CVIY7QMD.js.map → block.mds.junction-OG335MBK.js.map} +0 -0
  662. /package/dist/{block.mds.svcnv-EUGWHSCA.js.map → block.mds.svcnv-WYDBQ6FV.js.map} +0 -0
  663. /package/dist/{block.svg-QBLNIGUF.js.map → block.svg-OH73245R.js.map} +0 -0
  664. /package/dist/{block.tk.aicheck-U6NG22FX.js.map → block.tk.aicheck-CG5THFW2.js.map} +0 -0
  665. /package/dist/{block.tk.ase-U3TRZAOH.js.map → block.tk.ase-G2L3G5MQ.js.map} +0 -0
  666. /package/dist/{block.tk.bam-6Y6YFVR2.js.map → block.tk.bam-DXWCA6EU.js.map} +0 -0
  667. /package/dist/{block.tk.bedgraphdot-O3VCFX6K.js.map → block.tk.bedgraphdot-LF3TFPNL.js.map} +0 -0
  668. /package/dist/{block.tk.bigwig.ui-DNBJAF72.js.map → block.tk.bigwig.ui-JKXZ3VDF.js.map} +0 -0
  669. /package/dist/{block.tk.hicstraw-2EIFJX7E.js.map → block.tk.hicstraw-ZK4RKFB6.js.map} +0 -0
  670. /package/dist/{block.tk.junction-UXSO5EJP.js.map → block.tk.junction-ZB7Q2NLB.js.map} +0 -0
  671. /package/dist/{block.tk.junction.textmatrixui-HQ6ZKCHM.js.map → block.tk.junction.textmatrixui-ZYNQWKIW.js.map} +0 -0
  672. /package/dist/{block.tk.ld-NEB4F3UG.js.map → block.tk.ld-7H64HGER.js.map} +0 -0
  673. /package/dist/{block.tk.menu-BN4JPJSD.js.map → block.tk.menu-WFVKAH74.js.map} +0 -0
  674. /package/dist/{block.tk.pgv-A4QFVSPF.js.map → block.tk.pgv-632LLSBI.js.map} +0 -0
  675. /package/dist/{brainImaging-ESQGNGZH.js.map → brainImaging-AEPTHIQF.js.map} +0 -0
  676. /package/dist/{chunk-U5QRRS7K.js.map → chunk-22O6F463.js.map} +0 -0
  677. /package/dist/{chunk-NRYOB7WU.js.map → chunk-2HJ7OD7H.js.map} +0 -0
  678. /package/dist/{chunk-PMZS3SHH.js.map → chunk-2MN5JLZB.js.map} +0 -0
  679. /package/dist/{chunk-7LKSKJCV.js.map → chunk-37CK5IGW.js.map} +0 -0
  680. /package/dist/{chunk-IPAGDFO4.js.map → chunk-3JFEWVHR.js.map} +0 -0
  681. /package/dist/{chunk-47HG7LGD.js.map → chunk-3MGBC64I.js.map} +0 -0
  682. /package/dist/{chunk-HEFXMCSF.js.map → chunk-3NWLWH4G.js.map} +0 -0
  683. /package/dist/{chunk-XATIKUGU.js.map → chunk-4GKQ5PWY.js.map} +0 -0
  684. /package/dist/{chunk-OQSP66C6.js.map → chunk-4PHD5H4A.js.map} +0 -0
  685. /package/dist/{chunk-GBWRKJAH.js.map → chunk-56IFQMJK.js.map} +0 -0
  686. /package/dist/{chunk-A76B53VT.js.map → chunk-5DMFTXUZ.js.map} +0 -0
  687. /package/dist/{chunk-W4D2EYE4.js.map → chunk-5QJDZHRU.js.map} +0 -0
  688. /package/dist/{chunk-OFQV6PRB.js.map → chunk-5WAVKWL6.js.map} +0 -0
  689. /package/dist/{chunk-C5YNONHQ.js.map → chunk-6ISTNHM6.js.map} +0 -0
  690. /package/dist/{chunk-ECKWM4HB.js.map → chunk-6VQ4C735.js.map} +0 -0
  691. /package/dist/{chunk-5CJJLBUZ.js.map → chunk-74WMSW3E.js.map} +0 -0
  692. /package/dist/{chunk-MG6GRQKO.js.map → chunk-AFU66YOW.js.map} +0 -0
  693. /package/dist/{chunk-2HQJMZNY.js.map → chunk-AUJ2YUXV.js.map} +0 -0
  694. /package/dist/{chunk-UZV3QI5M.js.map → chunk-B65X5UQH.js.map} +0 -0
  695. /package/dist/{chunk-TZRD3FPN.js.map → chunk-B6I64LSV.js.map} +0 -0
  696. /package/dist/{chunk-SN5QKRXO.js.map → chunk-BTYCW3D5.js.map} +0 -0
  697. /package/dist/{chunk-J2E4FALN.js.map → chunk-CCB5KYFQ.js.map} +0 -0
  698. /package/dist/{chunk-EEX5VPJG.js.map → chunk-CKLYFA7H.js.map} +0 -0
  699. /package/dist/{chunk-2DZWOGEH.js.map → chunk-CLYRJ466.js.map} +0 -0
  700. /package/dist/{chunk-3WA7SJTR.js.map → chunk-CPHCZZWT.js.map} +0 -0
  701. /package/dist/{chunk-VALBVQXS.js.map → chunk-CUADOD2T.js.map} +0 -0
  702. /package/dist/{chunk-L3PMRBTA.js.map → chunk-CV6ID6T7.js.map} +0 -0
  703. /package/dist/{chunk-7P67W6NF.js.map → chunk-CWHBWY3B.js.map} +0 -0
  704. /package/dist/{chunk-GG67VPVD.js.map → chunk-D53HBTYQ.js.map} +0 -0
  705. /package/dist/{chunk-RYRCMHYR.js.map → chunk-DKI7YOTJ.js.map} +0 -0
  706. /package/dist/{chunk-2MRZFUHZ.js.map → chunk-DNU4IPD2.js.map} +0 -0
  707. /package/dist/{chunk-AZ276Z7T.js.map → chunk-H6HP4H3U.js.map} +0 -0
  708. /package/dist/{chunk-GZ2B634M.js.map → chunk-HPEMEDXB.js.map} +0 -0
  709. /package/dist/{chunk-6MSJ3TLQ.js.map → chunk-HUDESZGX.js.map} +0 -0
  710. /package/dist/{chunk-FOXJTDTH.js.map → chunk-J7IU77CA.js.map} +0 -0
  711. /package/dist/{chunk-DPU66MZ7.js.map → chunk-JMO7ENSD.js.map} +0 -0
  712. /package/dist/{chunk-7RIC35AF.js.map → chunk-JTPN3BRG.js.map} +0 -0
  713. /package/dist/{chunk-EIMEUZP2.js.map → chunk-KCAMFDJH.js.map} +0 -0
  714. /package/dist/{chunk-OMO754MK.js.map → chunk-LD45BCVM.js.map} +0 -0
  715. /package/dist/{chunk-N5VBIEH5.js.map → chunk-LMELY5Z2.js.map} +0 -0
  716. /package/dist/{chunk-2ZEORJCF.js.map → chunk-LVQK62CV.js.map} +0 -0
  717. /package/dist/{chunk-PPJSDC3Z.js.map → chunk-MCVLRF66.js.map} +0 -0
  718. /package/dist/{chunk-4XDKCFFT.js.map → chunk-MLD7DW5I.js.map} +0 -0
  719. /package/dist/{chunk-JXHU2FIA.js.map → chunk-NEF7LGNE.js.map} +0 -0
  720. /package/dist/{chunk-UOMRXQNW.js.map → chunk-OARG7PAV.js.map} +0 -0
  721. /package/dist/{chunk-B662XJMJ.js.map → chunk-OGWY4MOB.js.map} +0 -0
  722. /package/dist/{chunk-QIS45Z4Y.js.map → chunk-PQD6K5W5.js.map} +0 -0
  723. /package/dist/{chunk-47X254B7.js.map → chunk-Q4FYGFTQ.js.map} +0 -0
  724. /package/dist/{chunk-F3FTQWTA.js.map → chunk-RA2KI64U.js.map} +0 -0
  725. /package/dist/{chunk-ROWCKPNW.js.map → chunk-RHHLAKYS.js.map} +0 -0
  726. /package/dist/{chunk-S7EKSDVS.js.map → chunk-RKV3CP4C.js.map} +0 -0
  727. /package/dist/{chunk-OS46MR72.js.map → chunk-RL7RU2V7.js.map} +0 -0
  728. /package/dist/{chunk-CZTC4MTE.js.map → chunk-RQ7CE7SK.js.map} +0 -0
  729. /package/dist/{chunk-KGYPMYQD.js.map → chunk-RX552WU6.js.map} +0 -0
  730. /package/dist/{chunk-RQUXELHE.js.map → chunk-S7V4SFKB.js.map} +0 -0
  731. /package/dist/{chunk-PBJFLQGL.js.map → chunk-SEL5UNRC.js.map} +0 -0
  732. /package/dist/{chunk-236ZRGXA.js.map → chunk-SRBO57AD.js.map} +0 -0
  733. /package/dist/{chunk-CT3LPTWW.js.map → chunk-SYGLOTOV.js.map} +0 -0
  734. /package/dist/{chunk-KGSCQRQ5.js.map → chunk-UZ466XO3.js.map} +0 -0
  735. /package/dist/{chunk-ZL4CNBYY.js.map → chunk-VDF5W47R.js.map} +0 -0
  736. /package/dist/{chunk-ZQ7L66GP.js.map → chunk-WTPVXDJT.js.map} +0 -0
  737. /package/dist/{chunk-I26R4NJJ.js.map → chunk-XRIM2YJZ.js.map} +0 -0
  738. /package/dist/{chunk-F4APZ34G.js.map → chunk-YSWMQO23.js.map} +0 -0
  739. /package/dist/{chunk-RCVZ4L7K.js.map → chunk-ZBZXIWSK.js.map} +0 -0
  740. /package/dist/{chunk-ICNJQHQZ.js.map → chunk-ZFFHOEBE.js.map} +0 -0
  741. /package/dist/{chunk-E6NE5IWR.js.map → chunk-ZG63ZUDE.js.map} +0 -0
  742. /package/dist/{chunk-BP2F2GRB.js.map → chunk-ZGQ3BMLW.js.map} +0 -0
  743. /package/dist/{chunk-M7QVMSRW.js.map → chunk-ZNINQ3FN.js.map} +0 -0
  744. /package/dist/{chunk-ETFPL4UP.js.map → chunk-ZQZWM544.js.map} +0 -0
  745. /package/dist/{condition-24HPVH23.js.map → condition-4FVKPSQ2.js.map} +0 -0
  746. /package/dist/{controls-5CSAKANR.js.map → controls-ZWBN566I.js.map} +0 -0
  747. /package/dist/{controls.btns-QLLBCT65.js.map → controls.btns-H4TWTHTW.js.map} +0 -0
  748. /package/dist/{controls.config-H4FMU5LI.js.map → controls.config-YU4W3CDL.js.map} +0 -0
  749. /package/dist/{correlation-RB77VSXB.js.map → correlation-VADB4SQO.js.map} +0 -0
  750. /package/dist/{cuminc-YZSLH5IO.js.map → cuminc-4BXE2YS6.js.map} +0 -0
  751. /package/dist/{cuminc.integration.spec-MZPT3Y5A.js.map → cuminc.integration.spec-XQREKHVA.js.map} +0 -0
  752. /package/dist/{customdata.inputui-CBTZFODT.js.map → customdata.inputui-VBQWT3M7.js.map} +0 -0
  753. /package/dist/{dataDownload-ZTGRVI4Q.js.map → dataDownload-QIZKBKH7.js.map} +0 -0
  754. /package/dist/{dataDownload.integration.spec-Q6GUTUYD.js.map → dataDownload.integration.spec-MLJEHLYD.js.map} +0 -0
  755. /package/dist/{databrowser.ui-V7E6CLUZ.js.map → databrowser.ui-6UIR4ULJ.js.map} +0 -0
  756. /package/dist/{dictionary-RPC5OZMM.js.map → dictionary-FLWIWAC6.js.map} +0 -0
  757. /package/dist/{e2pca-WDQHMAUM.js.map → e2pca-NKWSJRXM.js.map} +0 -0
  758. /package/dist/{ep-NAM34BBI.js.map → ep-EPN3AR6D.js.map} +0 -0
  759. /package/dist/{expclust.gdc.spec-QB4GVDJA.js.map → expclust.gdc.spec-ZRUH5E6E.js.map} +0 -0
  760. /package/dist/{facet-DOXBBIG6.js.map → facet-BM7SLACF.js.map} +0 -0
  761. /package/dist/{frequencyChart-GLOIGP3T.js.map → frequencyChart-HBXRIBAW.js.map} +0 -0
  762. /package/dist/{frequencyChart.integration.spec-B7NBBLH2.js.map → frequencyChart.integration.spec-YJUYZWM6.js.map} +0 -0
  763. /package/dist/{geneExpClustering-B4S6GFNT.js.map → geneExpClustering-4VD5PAWN.js.map} +0 -0
  764. /package/dist/{geneExpression-MVVXRNEY.js.map → geneExpression-6OT2Y4P6.js.map} +0 -0
  765. /package/dist/{geneExpression-DMU4AQP6.js.map → geneExpression-EAMEZXJQ.js.map} +0 -0
  766. /package/dist/{geneORA-XDAITCQF.js.map → geneORA-RI2AG7JT.js.map} +0 -0
  767. /package/dist/{geneVariant-N6IGEIRR.js.map → geneVariant-FYYEOTWA.js.map} +0 -0
  768. /package/dist/{geneVariant-QYLA2V6J.js.map → geneVariant-PAKVDVC4.js.map} +0 -0
  769. /package/dist/{genefusion.ui-FRBMNK7V.js.map → genefusion.ui-QWC42XWQ.js.map} +0 -0
  770. /package/dist/{geneset-GZYNBG7Y.js.map → geneset-XA6IWP3Q.js.map} +0 -0
  771. /package/dist/{genomeBrowser.spec-WFIVQSE7.js.map → genomeBrowser.spec-LRKXWXNT.js.map} +0 -0
  772. /package/dist/{grin2-ZKNNZXON.js.map → grin2-WLB7BY3S.js.map} +0 -0
  773. /package/dist/{gsea-GFGAEC4K.js.map → gsea-ZM4WOPSQ.js.map} +0 -0
  774. /package/dist/{hierCluster-MF4TI3E4.js.map → hierCluster-LD43LLRC.js.map} +0 -0
  775. /package/dist/{hierCluster-SDJMQLOQ.js.map → hierCluster-ZGYRS2WV.js.map} +0 -0
  776. /package/dist/{hierCluster.config-RMEX3VTC.js.map → hierCluster.config-O5HUOFNH.js.map} +0 -0
  777. /package/dist/{hierCluster.integration.spec-3H63OHMU.js.map → hierCluster.integration.spec-37UNKHTH.js.map} +0 -0
  778. /package/dist/{hierCluster.interactivity-4DZBRQ6P.js.map → hierCluster.interactivity-B27ETKRP.js.map} +0 -0
  779. /package/dist/{hierCluster.renderers-UOW7BI6N.js.map → hierCluster.renderers-GWFH5ZX7.js.map} +0 -0
  780. /package/dist/{imagePlot-P2UHJRSL.js.map → imagePlot-LJZVGNDJ.js.map} +0 -0
  781. /package/dist/{importPlot-PPCMNVOW.js.map → importPlot-RMVENQRD.js.map} +0 -0
  782. /package/dist/{launch.adhoc-RJWUEVRA.js.map → launch.adhoc-S3XHRSLN.js.map} +0 -0
  783. /package/dist/{leftlabel.sample-OYP6MICL.js.map → leftlabel.sample-J6PCA3UB.js.map} +0 -0
  784. /package/dist/{lollipop-BXQOWLGO.js.map → lollipop-OZTV4C7A.js.map} +0 -0
  785. /package/dist/{maftimeline-GHKDDWYR.js.map → maftimeline-6F2LQJU6.js.map} +0 -0
  786. /package/dist/{matrix-FWDLHZYR.js.map → matrix-FIXOFAB4.js.map} +0 -0
  787. /package/dist/{matrix-YMJFP53F.js.map → matrix-O5KPDLM2.js.map} +0 -0
  788. /package/dist/{matrix.cells-JH7FPY3E.js.map → matrix.cells-SCLZA3P4.js.map} +0 -0
  789. /package/dist/{matrix.config-HIHOLDCE.js.map → matrix.config-WG7HFJL4.js.map} +0 -0
  790. /package/dist/{matrix.controls-EKZ543FY.js.map → matrix.controls-QQLBUUYP.js.map} +0 -0
  791. /package/dist/{matrix.data-NKAZI2BF.js.map → matrix.data-6JLF5HVI.js.map} +0 -0
  792. /package/dist/{matrix.dom-RGZ52GJ2.js.map → matrix.dom-QO7BXZ27.js.map} +0 -0
  793. /package/dist/{matrix.groups-BO53ZXXV.js.map → matrix.groups-QMZMZ6Q7.js.map} +0 -0
  794. /package/dist/{matrix.integration.spec-BXTATNAC.js.map → matrix.integration.spec-ZJYWNQ57.js.map} +0 -0
  795. /package/dist/{matrix.interactivity-UGUMKCFN.js.map → matrix.interactivity-ZZY5ET4E.js.map} +0 -0
  796. /package/dist/{matrix.layout-WBIF5QTG.js.map → matrix.layout-XKFB4PKY.js.map} +0 -0
  797. /package/dist/{matrix.legend-P3GFCXXK.js.map → matrix.legend-CS6DNC5V.js.map} +0 -0
  798. /package/dist/{matrix.renderers-I54IHQ3S.js.map → matrix.renderers-4LST6PBA.js.map} +0 -0
  799. /package/dist/{matrix.serieses-R2T57OYI.js.map → matrix.serieses-3SERD6CV.js.map} +0 -0
  800. /package/dist/{matrix.sort-3GCA2GDU.js.map → matrix.sort-UVS6WHIS.js.map} +0 -0
  801. /package/dist/{matrix.sort.unit.spec-AXGPCZZD.js.map → matrix.sort.unit.spec-CTSUNUWB.js.map} +0 -0
  802. /package/dist/{matrix.sorterUi-QWRK6OGE.js.map → matrix.sorterUi-JDGLTLJM.js.map} +0 -0
  803. /package/dist/{matrix.sorterUi.unit.spec-H7GUVWRJ.js.map → matrix.sorterUi.unit.spec-VQFMHIYI.js.map} +0 -0
  804. /package/dist/{mavb-4EECWXYX.js.map → mavb-ECQ2CQ7F.js.map} +0 -0
  805. /package/dist/{mds.fimo-NHZOY43X.js.map → mds.fimo-JDYDT5NK.js.map} +0 -0
  806. /package/dist/{mds.samplescatterplot-7A5IZ6W7.js.map → mds.samplescatterplot-PEJBVSTO.js.map} +0 -0
  807. /package/dist/{mds.survivalplot-SQDPUFQE.js.map → mds.survivalplot-GYK6VRQT.js.map} +0 -0
  808. /package/dist/{mutationSignature-QH7PZYKL.js.map → mutationSignature-43SECPTY.js.map} +0 -0
  809. /package/dist/{numericDictTermCluster-X5SGSC5K.js.map → numericDictTermCluster-2ER4FUKO.js.map} +0 -0
  810. /package/dist/{oncomatrix-M4C4XPQK.js.map → oncomatrix-ZXDJMLN3.js.map} +0 -0
  811. /package/dist/{oncomatrix.spec-3C642O7O.js.map → oncomatrix.spec-HOPRIG3I.js.map} +0 -0
  812. /package/dist/{plot.2dvaf-TILP7J53.js.map → plot.2dvaf-Y4SZUHLD.js.map} +0 -0
  813. /package/dist/{plot.app-DE2UQP2M.js.map → plot.app-W5Z3C7P5.js.map} +0 -0
  814. /package/dist/{plot.barplot-FJHS765K.js.map → plot.barplot-B2PRZDKV.js.map} +0 -0
  815. /package/dist/{plot.boxplot-YRSHGNYZ.js.map → plot.boxplot-J7ET34FY.js.map} +0 -0
  816. /package/dist/{plot.brainImaging-JV4OUVJY.js.map → plot.brainImaging-ISY4P6RT.js.map} +0 -0
  817. /package/dist/{plot.disco-DBVPBMLG.js.map → plot.disco-D7AL42PW.js.map} +0 -0
  818. /package/dist/{plot.dzi-O2OA4EBK.js.map → plot.dzi-O32LH65U.js.map} +0 -0
  819. /package/dist/{plot.ssgq-YFQEZQYK.js.map → plot.ssgq-WF7262IZ.js.map} +0 -0
  820. /package/dist/{plot.vaf2cov-YNFP5LJ4.js.map → plot.vaf2cov-OB6UKSFQ.js.map} +0 -0
  821. /package/dist/{plot.wsi-DJB7TDIS.js.map → plot.wsi-J5S4YYXN.js.map} +0 -0
  822. /package/dist/{polar-K5Z5FYKV.js.map → polar-LIJORXR6.js.map} +0 -0
  823. /package/dist/{profile.spec-A6EADWEC.js.map → profile.spec-3KE4CREI.js.map} +0 -0
  824. /package/dist/{profileBarchart-EFLPJK2P.js.map → profileBarchart-UQHOJB5V.js.map} +0 -0
  825. /package/dist/{profileForms-TG35YNLD.js.map → profileForms-WTYVTIUN.js.map} +0 -0
  826. /package/dist/{profilePlot-2EW2XVTK.js.map → profilePlot-SOXXEUAT.js.map} +0 -0
  827. /package/dist/{profileRadar-AKUYC2O5.js.map → profileRadar-2OHJ2RIU.js.map} +0 -0
  828. /package/dist/{profileRadarFacility-EAT66XTX.js.map → profileRadarFacility-GHLG3QNG.js.map} +0 -0
  829. /package/dist/{qualitative-PHQU5DXE.js.map → qualitative-B3OY7A7P.js.map} +0 -0
  830. /package/dist/{regression-EOMJRRDO.js.map → regression-HO2TO4XT.js.map} +0 -0
  831. /package/dist/{regression.inputs-LIH5X2JM.js.map → regression.inputs-JN3ZMIOP.js.map} +0 -0
  832. /package/dist/{regression.inputs.term-OO4RZ3QB.js.map → regression.inputs.term-67HVMXFZ.js.map} +0 -0
  833. /package/dist/{regression.inputs.values.table-E7WCTO2L.js.map → regression.inputs.values.table-JXJK2YZT.js.map} +0 -0
  834. /package/dist/{regression.integration.spec-62VEQP6X.js.map → regression.integration.spec-L54ZS5VY.js.map} +0 -0
  835. /package/dist/{regression.results-WAHFJ6NA.js.map → regression.results-3ZSFKUNN.js.map} +0 -0
  836. /package/dist/{regression.spec-IBIOTZVX.js.map → regression.spec-SVWCQX2U.js.map} +0 -0
  837. /package/dist/{report-MKDJXHGY.js.map → report-IHX7XSOI.js.map} +0 -0
  838. /package/dist/{runChart-ETM2EETF.js.map → runChart-QLQMK3OE.js.map} +0 -0
  839. /package/dist/{runchart.integration.spec-QFA4XBKB.js.map → runchart.integration.spec-5NVY5GHR.js.map} +0 -0
  840. /package/dist/{sampleScatter.spec-N4N7ZGZF.js.map → sampleScatter.spec-4Q5CQQWH.js.map} +0 -0
  841. /package/dist/{sampleView-JTY3RV7I.js.map → sampleView-7WHDFHB5.js.map} +0 -0
  842. /package/dist/{samplelst-RRUMBVT6.js.map → samplelst-34GJVLVD.js.map} +0 -0
  843. /package/dist/{samplematrix-L37O664Y.js.map → samplematrix-L2HOSLUT.js.map} +0 -0
  844. /package/dist/{scatter-E5QHW32W.js.map → scatter-X6AAM2LJ.js.map} +0 -0
  845. /package/dist/{scatter.integration.spec-FNVAJSVU.js.map → scatter.integration.spec-QSH3PLBK.js.map} +0 -0
  846. /package/dist/{selectGenomeWithTklst-J6VXCYGG.js.map → selectGenomeWithTklst-AJS2IPPW.js.map} +0 -0
  847. /package/dist/{singleCellPlot-S6S6CKYX.js.map → singleCellPlot-7JEWDVSR.js.map} +0 -0
  848. /package/dist/{singlecell-B4TNI23F.js.map → singlecell-IC5KU72L.js.map} +0 -0
  849. /package/dist/{singlecell-4BMIKFY4.js.map → singlecell-NWANPXWM.js.map} +0 -0
  850. /package/dist/{snp-PAUQ24NZ.js.map → snp-PSRNMTL6.js.map} +0 -0
  851. /package/dist/{snplocus-HVFYZTEE.js.map → snplocus-QCAVDYLR.js.map} +0 -0
  852. /package/dist/{spliceevent.a53ss.diagram-GGGHVNBF.js.map → spliceevent.a53ss.diagram-SGDJKUEC.js.map} +0 -0
  853. /package/dist/{spliceevent.exonskip.diagram-HLMFD6LJ.js.map → spliceevent.exonskip.diagram-BUYTHCK5.js.map} +0 -0
  854. /package/dist/{spliceevent.noeventdiagram-CKZ3BZ7Y.js.map → spliceevent.noeventdiagram-OJZJUHXP.js.map} +0 -0
  855. /package/dist/{ssGSEA-UGT4GH55.js.map → ssGSEA-UUZG57MF.js.map} +0 -0
  856. /package/dist/{stattable-6JWMALGB.js.map → stattable-324FS2HA.js.map} +0 -0
  857. /package/dist/{summarizeCnvGeneexp-BJOQY62E.js.map → summarizeCnvGeneexp-ZVZYWP43.js.map} +0 -0
  858. /package/dist/{summarizeGeneexpSurvival-4HDHL7PE.js.map → summarizeGeneexpSurvival-7XJRMT6M.js.map} +0 -0
  859. /package/dist/{summarizeMutationDiagnosis-TDWO5CKU.js.map → summarizeMutationDiagnosis-ZKLXOVY2.js.map} +0 -0
  860. /package/dist/{summarizeMutationSurvival-CJJFABOX.js.map → summarizeMutationSurvival-S4YPGLWA.js.map} +0 -0
  861. /package/dist/{summary-WOAXXIHG.js.map → summary-RVG7JL6Y.js.map} +0 -0
  862. /package/dist/{summary.integration.spec-GM73ERMN.js.map → summary.integration.spec-SCD35GO4.js.map} +0 -0
  863. /package/dist/{summaryInput-FD4SONTY.js.map → summaryInput-DMN6DTSW.js.map} +0 -0
  864. /package/dist/{sunburst-3LCJTBRN.js.map → sunburst-QZXYILRC.js.map} +0 -0
  865. /package/dist/{survival-A3A7IVXT.js.map → survival-6CWEBRSF.js.map} +0 -0
  866. /package/dist/{survival-XF72VMM6.js.map → survival-J657VYLI.js.map} +0 -0
  867. /package/dist/{survival.integration.spec-AU7MCAQV.js.map → survival.integration.spec-S5WE4V6M.js.map} +0 -0
  868. /package/dist/{svgraph-BEMS4JDJ.js.map → svgraph-NEKJL24M.js.map} +0 -0
  869. /package/dist/{svmr-CDEMTZPK.js.map → svmr-5RQ5JQF2.js.map} +0 -0
  870. /package/dist/{table-WYF6QCGB.js.map → table-CG6Z6NCJ.js.map} +0 -0
  871. /package/dist/{termCollection-BVQMNVY7.js.map → termCollection-FOQNVXB7.js.map} +0 -0
  872. /package/dist/{termInfo-JXLIVCSO.js.map → termInfo-5USFZGDB.js.map} +0 -0
  873. /package/dist/{tk-TGIIJYBO.js.map → tk-2O7XOVGJ.js.map} +0 -0
  874. /package/dist/{tp.ui-USYF67P7.js.map → tp.ui-S4YUVCZH.js.map} +0 -0
  875. /package/dist/{tvs.dtcnv.continuous-7SCTSFK3.js.map → tvs.dtcnv.continuous-7BPIXZ6C.js.map} +0 -0
  876. /package/dist/{tvs.numeric-OLVW6US3.js.map → tvs.numeric-FCC2EY62.js.map} +0 -0
  877. /package/dist/{tvs.samplelst-BHZHCX5V.js.map → tvs.samplelst-PKGFTULN.js.map} +0 -0
  878. /package/dist/{violin-OEOWVIZF.js.map → violin-C7IBRTYP.js.map} +0 -0
  879. /package/dist/{violin.integration.spec-AW2U3RHO.js.map → violin.integration.spec-WXRD3Z4E.js.map} +0 -0
  880. /package/dist/{violin.interactivity-3O2UDNPQ.js.map → violin.interactivity-BMG4TG5L.js.map} +0 -0
  881. /package/dist/{violin.renderer-W26FA6M7.js.map → violin.renderer-WUNW6ULV.js.map} +0 -0
  882. /package/dist/{vocabulary-BIQYDKVY.js.map → vocabulary-UUNEEBM3.js.map} +0 -0
@@ -0,0 +1,2327 @@
1
+ import {
2
+ vcf2dstk
3
+ } from "./chunk-UZ466XO3.js";
4
+ import {
5
+ getsjcharts
6
+ } from "./chunk-MKAF2BHB.js";
7
+ import {
8
+ parseheader,
9
+ parseline
10
+ } from "./chunk-S7V4SFKB.js";
11
+ import {
12
+ bulk_badline,
13
+ disappear2 as disappear,
14
+ filetypeselect,
15
+ newpane,
16
+ newpane3,
17
+ renderSandboxFormDiv,
18
+ sayerror,
19
+ tkt
20
+ } from "./chunk-W5EG334J.js";
21
+ import {
22
+ invalidcoord,
23
+ string2pos
24
+ } from "./chunk-HJ6L54YS.js";
25
+ import {
26
+ dofetch,
27
+ init_bulk_flag,
28
+ parsesample
29
+ } from "./chunk-MK7RRJTX.js";
30
+ import {
31
+ dtcloss,
32
+ dtcnv,
33
+ dtdel,
34
+ dtfusionrna,
35
+ dtitd,
36
+ dtnloss,
37
+ dtsnvindel,
38
+ dtsv,
39
+ mclasscloss,
40
+ mclasscnvgain,
41
+ mclasscnvloh,
42
+ mclasscnvloss,
43
+ mclassdel,
44
+ mclassfusionrna,
45
+ mclassitd,
46
+ mclassnloss,
47
+ mclasssv,
48
+ mclasstester,
49
+ validtkt
50
+ } from "./chunk-6VQ4C735.js";
51
+ import {
52
+ category10_default
53
+ } from "./chunk-2MN5JLZB.js";
54
+ import {
55
+ ordinal
56
+ } from "./chunk-W2IWHXLL.js";
57
+ import {
58
+ select_default
59
+ } from "./chunk-NDWTN4U5.js";
60
+
61
+ // ../shared/utils/src/bulk.snv.js
62
+ function parseheader2(line, flag2) {
63
+ const header = line.toLowerCase().split(" ");
64
+ if (header.length <= 1) return "invalid file header for snv/indel";
65
+ const htry = (...args) => {
66
+ for (const s of args) {
67
+ const i2 = header.indexOf(s);
68
+ if (i2 != -1) return i2;
69
+ }
70
+ return -1;
71
+ };
72
+ let i = htry("annovar_gene", "annovar_sj_gene", "gene", "genename", "gene_symbol", "hugo_symbol");
73
+ if (i == -1) return "gene missing from header";
74
+ header[i] = "gene";
75
+ i = htry("annovar_aachange", "amino_acid_change", "annovar_sj_aachange", "aachange", "protein_change", "variant");
76
+ if (i == -1) return "amino_acid_change missing from header";
77
+ header[i] = "mname";
78
+ i = htry("annovar_class", "class", "mclass", "variant_class", "variant_classification", "annovar_sj_class");
79
+ if (i == -1) return "variant_class missing from header";
80
+ header[i] = "class";
81
+ i = htry("chromosome", "chr");
82
+ if (i == -1) return "chromosome missing from header";
83
+ header[i] = "chr";
84
+ i = htry("wu_hg19_pos", "start", "start_position", "chr_position", "position");
85
+ if (i == -1) return "start missing from header";
86
+ header[i] = "pos";
87
+ i = htry(
88
+ "annovar_isoform",
89
+ "mrna_accession",
90
+ "mrna accession",
91
+ "refseq_mrna_id",
92
+ "annovar_sj_filter_isoform",
93
+ "refseq",
94
+ "isoform"
95
+ );
96
+ if (i == -1) return "isoform missing from header";
97
+ header[i] = "isoform";
98
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
99
+ if (i != -1) header[i] = "sample";
100
+ i = htry("patient", "donor", "target_case_id");
101
+ if (i != -1) header[i] = "patient";
102
+ i = htry("quantitative_measurements");
103
+ if (i != -1) header[i] = "qmset";
104
+ i = htry("mutant_reads_in_case", "mutant_in_tumor", "tumor_readcount_alt");
105
+ if (i != -1) header[i] = "maf_tumor_v1";
106
+ i = htry("total_reads_in_case", "total_in_tumor", "tumor_readcount_total");
107
+ if (i != -1) header[i] = "maf_tumor_v2";
108
+ i = htry("mutant_reads_in_control", "mutant_in_normal", "normal_readcount_alt");
109
+ if (i != -1) header[i] = "maf_normal_v1";
110
+ i = htry("total_reads_in_control", "total_in_normal", "normal_readcount_total");
111
+ if (i != -1) header[i] = "maf_normal_v2";
112
+ i = htry("cdna_change");
113
+ if (i != -1) header[i] = "cdna_change";
114
+ i = htry("sampletype", "sample type", "sample_type");
115
+ if (i != -1) header[i] = "sampletype";
116
+ i = htry("origin");
117
+ if (i != -1) header[i] = "origin";
118
+ i = htry("cancer", "disease", "diagnosis");
119
+ if (i != -1) header[i] = "disease";
120
+ flag2.snv.header = header;
121
+ flag2.snv.loaded = true;
122
+ return false;
123
+ }
124
+ function parseline2(linei, line, flag2) {
125
+ if (line == "" || line[0] == "#") return;
126
+ const lst = line.split(" ");
127
+ const m = {};
128
+ for (let j = 0; j < flag2.snv.header.length; j++) {
129
+ if (lst[j] == void 0) break;
130
+ m[flag2.snv.header[j]] = lst[j];
131
+ }
132
+ if (!m.gene) {
133
+ flag2.snv.badlines.push([linei, "missing gene", lst]);
134
+ return;
135
+ }
136
+ if (m.gene.toUpperCase() == "UNKNOWN") {
137
+ flag2.snv.badlines.push([linei, "gene name is UNKNOWN", lst]);
138
+ return;
139
+ }
140
+ if (!m.isoform) {
141
+ flag2.snv.badlines.push([linei, "missing isoform", lst]);
142
+ return;
143
+ }
144
+ if (!m.mname) {
145
+ m.mname = m.cdna_change;
146
+ if (!m.mname) {
147
+ flag2.snv.badlines.push([linei, "missing amino acid change", lst]);
148
+ return;
149
+ }
150
+ } else {
151
+ if (m.mname.indexOf("p.") == 0) {
152
+ m.mname = m.mname.replace(/^p\./, "");
153
+ }
154
+ }
155
+ if (!m.class) {
156
+ flag2.snv.badlines.push([linei, "missing mutation class", lst]);
157
+ return;
158
+ }
159
+ let _c = flag2.mclasslabel2key[m.class.toUpperCase()];
160
+ if (_c) {
161
+ m.class = _c;
162
+ } else {
163
+ _c = mclasstester(m.class);
164
+ if (_c) {
165
+ m.class = _c;
166
+ } else {
167
+ flag2.snv.badlines.push([linei, "wrong mutation class: " + m.class, lst]);
168
+ return;
169
+ }
170
+ }
171
+ if (parsesample(m, flag2, linei, lst, flag2.snv.badlines)) {
172
+ return;
173
+ }
174
+ if (!m.chr) {
175
+ flag2.snv.badlines.push([linei, "missing chromosome", lst]);
176
+ return;
177
+ }
178
+ if (m.chr.toLowerCase().indexOf("chr") != 0) {
179
+ m.chr = "chr" + m.chr;
180
+ }
181
+ if (!m.pos) {
182
+ flag2.snv.badlines.push([linei, "missing chromosome position", lst]);
183
+ return;
184
+ }
185
+ const v = Number.parseInt(m.pos);
186
+ if (Number.isNaN(v)) {
187
+ flag2.snv.badlines.push([linei, "invalid chromosome position", lst]);
188
+ return;
189
+ }
190
+ m.pos = v - 1;
191
+ if (m.maf_tumor_v2 != void 0 && m.maf_tumor_v1 != void 0) {
192
+ if (m.maf_tumor_v2 == "") {
193
+ } else {
194
+ let v1 = Number.parseInt(m.maf_tumor_v1), v2 = Number.parseInt(m.maf_tumor_v2);
195
+ if (Number.isNaN(v1) || Number.isNaN(v2)) {
196
+ flag2.snv.badlines.push([linei, "invalid maf_tumor mutant and/or total read count", lst]);
197
+ return;
198
+ }
199
+ m.maf_tumor = { f: v1 / v2, v1, v2 };
200
+ }
201
+ delete m.maf_tumor_v1;
202
+ delete m.maf_tumor_v2;
203
+ }
204
+ if (m.maf_normal_v1 != void 0 && m.maf_normal_v2 != void 0) {
205
+ if (m.maf_normal_v2 == "") {
206
+ } else {
207
+ let v1 = Number.parseInt(m.maf_normal_v1), v2 = Number.parseInt(m.maf_normal_v2);
208
+ if (Number.isNaN(v1) || Number.isNaN(v2)) {
209
+ flag2.snv.badlines.push([linei, "invalid maf_normal mutant and/or total read count", lst]);
210
+ return;
211
+ }
212
+ m.maf_normal = { f: v1 / v2, v1, v2 };
213
+ }
214
+ delete m.maf_normal_v1;
215
+ delete m.maf_normal_v2;
216
+ }
217
+ flag2.good++;
218
+ if (m.class == "M") {
219
+ flag2.snv.missense++;
220
+ } else if (m.class == "S") {
221
+ flag2.snv.silent++;
222
+ }
223
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
224
+ if (!flag2.data[n]) {
225
+ flag2.data[n] = [];
226
+ }
227
+ m.dt = dtsnvindel;
228
+ flag2.data[n].push(m);
229
+ }
230
+
231
+ // ../shared/utils/src/bulk.svjson.js
232
+ function parseheader3(line, flag2) {
233
+ const header = line.toLowerCase().split(" ");
234
+ if (header.length <= 1) return "invalid file header for svjson";
235
+ const htry = (...lst) => {
236
+ for (const a of lst) {
237
+ const j = header.indexOf(a);
238
+ if (j != -1) return j;
239
+ }
240
+ return -1;
241
+ };
242
+ let i = htry("sample");
243
+ if (i != -1) header[i] = "sample";
244
+ i = htry("sampletype");
245
+ if (i != -1) header[i] = "sampletype";
246
+ i = htry("patient");
247
+ if (i != -1) header[i] = "patient";
248
+ i = htry("json", "jsontext");
249
+ if (i == -1) return ["json missing from header"];
250
+ header[i] = "jsontext";
251
+ return [null, header];
252
+ }
253
+ function parseline3(i, line, flag2, header) {
254
+ if (line == "" || line[0] == "#") return;
255
+ const lst = line.split(" ");
256
+ const m = {};
257
+ const badlines = flag2.svjson.badlines;
258
+ for (let j = 0; j < header.length; j++) {
259
+ m[header[j]] = lst[j];
260
+ }
261
+ if (!m.jsontext) {
262
+ badlines.push([i, "missing jsontext", lst]);
263
+ return;
264
+ }
265
+ if (parsesample(m, flag2, i, lst, badlines)) {
266
+ return;
267
+ }
268
+ let json;
269
+ try {
270
+ json = JSON.parse(m.jsontext);
271
+ } catch (e) {
272
+ badlines.push([i, "invalid JSON text", lst]);
273
+ return;
274
+ }
275
+ if (Array.isArray(json)) {
276
+ for (const pair of json) {
277
+ if (pair.a && pair.a.name && pair.a.isoform) {
278
+ flag2.good++;
279
+ const m2 = {
280
+ dt: dtfusionrna,
281
+ class: mclassfusionrna,
282
+ isoform: pair.a.isoform,
283
+ mname: pair.b.name
284
+ };
285
+ for (const k in m) {
286
+ if (k != "jsontext") m2[k] = m[k];
287
+ }
288
+ m2.pairlst = duplicate(json);
289
+ const n = pair.a.name.toUpperCase();
290
+ if (!flag2.data[n]) {
291
+ flag2.data[n] = [];
292
+ }
293
+ flag2.data[n].push(m2);
294
+ }
295
+ if (pair.b && pair.b.name && pair.b.isoform) {
296
+ flag2.good++;
297
+ const m2 = {
298
+ dt: dtfusionrna,
299
+ class: mclassfusionrna,
300
+ isoform: pair.b.isoform,
301
+ mname: pair.a.name
302
+ };
303
+ for (const k in m) {
304
+ if (k != "jsontext") m2[k] = m[k];
305
+ }
306
+ m2.pairlst = duplicate(json);
307
+ const n = pair.b.name.toUpperCase();
308
+ if (!flag2.data[n]) {
309
+ flag2.data[n] = [];
310
+ }
311
+ flag2.data[n].push(m2);
312
+ }
313
+ }
314
+ } else {
315
+ json.dt = json.typecode;
316
+ delete json.typecode;
317
+ switch (json.dt) {
318
+ case dtitd:
319
+ json.class = mclassitd;
320
+ json.mname = "ITD";
321
+ break;
322
+ case dtnloss:
323
+ json.class = mclassnloss;
324
+ json.mname = "N-loss";
325
+ break;
326
+ case dtcloss:
327
+ json.class = mclasscloss;
328
+ json.mname = "C-loss";
329
+ break;
330
+ case dtdel:
331
+ json.class = mclassdel;
332
+ json.mname = "Del";
333
+ break;
334
+ case dtsv:
335
+ json.class = mclasssv;
336
+ json.mname = "SV";
337
+ break;
338
+ default:
339
+ badlines.push([i, "unknown datatype", lst]);
340
+ return;
341
+ }
342
+ if (!json.gene) {
343
+ badlines.push([i, "json.gene missing", lst]);
344
+ return;
345
+ }
346
+ flag2.good++;
347
+ for (const k in m) {
348
+ if (k != "jsontext") {
349
+ json[k] = m[k];
350
+ }
351
+ }
352
+ const n = flag2.geneToUpper ? json.gene.toUpperCase() : json.gene.toUpperCase();
353
+ if (!flag2.data[n]) {
354
+ flag2.data[n] = [];
355
+ }
356
+ flag2.data[n].push(json);
357
+ }
358
+ }
359
+ function duplicate(lst) {
360
+ const d = [];
361
+ for (const pair of lst) {
362
+ const p = { a: {}, b: {} };
363
+ for (const k in pair) {
364
+ if (k != "a" && k != "b") p[k] = pair[k];
365
+ }
366
+ for (const k in pair.a) {
367
+ p.a[k] = pair.a[k];
368
+ }
369
+ for (const k in pair.b) {
370
+ p.b[k] = pair.b[k];
371
+ }
372
+ d.push(p);
373
+ }
374
+ return d;
375
+ }
376
+
377
+ // ../shared/utils/src/bulk.cnv.js
378
+ function parseheader4(line, flag2) {
379
+ const header = line.toLowerCase().split(" ");
380
+ if (header.length <= 1) return "invalid file header for CNV";
381
+ const htry = (...lst) => {
382
+ for (const i2 of lst) {
383
+ const j = header.indexOf(i2);
384
+ if (j != -1) return j;
385
+ }
386
+ return -1;
387
+ };
388
+ let i = htry("gene");
389
+ if (i == -1) return "gene missing from header";
390
+ header[i] = "gene";
391
+ i = htry("cnv");
392
+ if (i == -1) return "CNV missing from header";
393
+ header[i] = "cnv";
394
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
395
+ if (i != -1) header[i] = "sample";
396
+ i = htry("patient", "donor", "target_case_id");
397
+ if (i != -1) header[i] = "patient";
398
+ i = htry("disease");
399
+ if (i != -1) header[i] = "disease";
400
+ i = htry("origin");
401
+ if (i != -1) header[i] = "origin";
402
+ i = htry("sampletype", "sample type", "sample_type");
403
+ if (i != -1) header[i] = "sampletype";
404
+ flag2.cnv.header = header;
405
+ flag2.cnv.loaded = true;
406
+ return false;
407
+ }
408
+ function parseline4(i, line, flag2) {
409
+ if (line == "" || line[0] == "#") return;
410
+ const lst = line.split(" ");
411
+ const m = {};
412
+ for (let j = 0; j < flag2.cnv.header.length; j++) {
413
+ m[flag2.cnv.header[j]] = lst[j];
414
+ }
415
+ if (!m.gene) {
416
+ flag2.cnv.badlines.push([i, "missing gene", lst]);
417
+ return;
418
+ }
419
+ if (!m.cnv) {
420
+ flag2.cnv.badlines.push([i, "missing cnv value", lst]);
421
+ return;
422
+ }
423
+ const value = m.cnv.toLowerCase();
424
+ switch (value) {
425
+ case "amplification":
426
+ case "gain":
427
+ m.class = mclasscnvgain;
428
+ break;
429
+ case "deletion":
430
+ case "loss":
431
+ m.class = mclasscnvloss;
432
+ break;
433
+ case "loh":
434
+ m.class = mclasscnvloh;
435
+ break;
436
+ default:
437
+ flag2.cnv.badlines.push([i, "invalid cnv value: " + m.cnv, lst]);
438
+ m.class = null;
439
+ }
440
+ if (!m.class) {
441
+ return;
442
+ }
443
+ if (parsesample(m, flag2, i, lst, flag2.cnv.badlines)) {
444
+ return;
445
+ }
446
+ m.dt = dtcnv;
447
+ flag2.good++;
448
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
449
+ if (!(n in flag2.data)) {
450
+ flag2.data[n] = [];
451
+ }
452
+ flag2.data[n].push(m);
453
+ }
454
+
455
+ // ../shared/utils/src/bulk.itd.js
456
+ function parseheader5(line, flag2) {
457
+ const header = line.toLowerCase().split(" ");
458
+ if (header.length <= 1) return "invalid header line for ITD";
459
+ const htry = (...lst) => {
460
+ for (const i2 of lst) {
461
+ const j = header.indexOf(i2);
462
+ if (j != -1) return j;
463
+ }
464
+ return -1;
465
+ };
466
+ let i = htry("gene");
467
+ if (i == -1) return "gene missing from header";
468
+ header[i] = "gene";
469
+ i = htry(
470
+ "annovar_isoform",
471
+ "mrna_accession",
472
+ "mrna accession",
473
+ "refseq_mrna_id",
474
+ "annovar_sj_filter_isoform",
475
+ "refseq",
476
+ "isoform"
477
+ );
478
+ if (i == -1) return "isoform missing from header";
479
+ header[i] = "isoform";
480
+ i = htry("rnaposition");
481
+ if (i != -1) {
482
+ header[i] = "rnaposition";
483
+ i = htry("rnaduplength");
484
+ if (i == -1) return "rnaduplength is required when rnaposition is present";
485
+ header[i] = "rnaduplength";
486
+ }
487
+ i = htry("chromosome", "chr");
488
+ if (i != -1) {
489
+ header[i] = "chr";
490
+ i = htry("chr_start");
491
+ if (i == -1) return "chr_start is required when chr is present";
492
+ header[i] = "chrpos1";
493
+ i = htry("chr_stop");
494
+ if (i == -1) return "chr_stop is required when chr is present";
495
+ header[i] = "chrpos2";
496
+ }
497
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
498
+ if (i != -1) header[i] = "sample";
499
+ i = htry("patient", "donor", "target_case_id");
500
+ if (i != -1) header[i] = "patient";
501
+ i = htry("disease");
502
+ if (i != -1) header[i] = "disease";
503
+ i = htry("origin");
504
+ if (i != -1) header[i] = "origin";
505
+ i = htry("sampletype", "sample type", "sample_type");
506
+ if (i != -1) header[i] = "sampletype";
507
+ flag2.itd.header = header;
508
+ flag2.itd.loaded = true;
509
+ return false;
510
+ }
511
+ function parseline5(i, line, flag2) {
512
+ if (line == "" || line[0] == "#") return;
513
+ const lst = line.split(" ");
514
+ const m = {};
515
+ for (let j = 0; j < flag2.itd.header.length; j++) {
516
+ if (lst[j] == void 0) break;
517
+ m[flag2.itd.header[j]] = lst[j];
518
+ }
519
+ if (!m.gene) {
520
+ flag2.itd.badlines.push([i, "missing gene", lst]);
521
+ return;
522
+ }
523
+ if (m.rnaposition) {
524
+ let v = Number.parseInt(m.rnaposition);
525
+ if (Number.isNaN(v) || v < 0) {
526
+ flag2.itd.badlines.push([i, "invalid rnaPosition value", lst]);
527
+ return;
528
+ }
529
+ m.rnaposition = v;
530
+ if (!m.rnaduplength) {
531
+ flag2.itd.badlines.push([i, "missing rnaDuplength value", lst]);
532
+ return;
533
+ }
534
+ v = Number.parseInt(m.rnaduplength);
535
+ if (Number.isNaN(v) || v < 0) {
536
+ flag2.itd.badlines.push([i, "invalid rnaDuplength value", lst]);
537
+ return;
538
+ }
539
+ m.rnaduplength = v;
540
+ }
541
+ if (m.chr) {
542
+ let v = Number.parseInt(m.chrpos1);
543
+ if (Number.isNaN(v) || v < 0) {
544
+ flag2.itd.badlines.push([i, "invalid chr_start value", lst]);
545
+ return;
546
+ }
547
+ m.chrpos1 = v;
548
+ v = Number.parseInt(m.chrpos2);
549
+ if (Number.isNaN(v) || v < 0) {
550
+ flag2.itd.badlines.push([i, "invalid chr_stop value", lst]);
551
+ return;
552
+ }
553
+ m.chrpos2 = v;
554
+ }
555
+ if (parsesample(m, flag2, i, lst, flag2.itd.badlines)) {
556
+ return;
557
+ }
558
+ m.dt = dtitd;
559
+ m.class = mclassitd;
560
+ m.mname = "ITD";
561
+ flag2.good++;
562
+ var n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
563
+ if (!(n in flag2.data)) {
564
+ flag2.data[n] = [];
565
+ }
566
+ flag2.data[n].push(m);
567
+ }
568
+
569
+ // ../shared/utils/src/bulk.del.js
570
+ function parseheader6(line, flag2) {
571
+ const header = line.toLowerCase().split(" ");
572
+ if (header.length <= 1) return "invalid header line for intragenic deletion";
573
+ const htry = (...lst) => {
574
+ for (const i2 of lst) {
575
+ const j = header.indexOf(i2);
576
+ if (j != -1) return j;
577
+ }
578
+ return -1;
579
+ };
580
+ let i = htry("gene");
581
+ if (i == -1) return "gene missing from header";
582
+ header[i] = "gene";
583
+ i = htry(
584
+ "annovar_isoform",
585
+ "mrna_accession",
586
+ "mrna accession",
587
+ "refseq_mrna_id",
588
+ "annovar_sj_filter_isoform",
589
+ "refseq",
590
+ "isoform"
591
+ );
592
+ if (i == -1) return "isoform missing from header";
593
+ header[i] = "isoform";
594
+ i = htry("rnaposition");
595
+ if (i != -1) {
596
+ header[i] = "rnaposition";
597
+ i = htry("rnadellength");
598
+ if (i == -1) return "rnadellength is required when rnaPosition is used";
599
+ header[i] = "rnadellength";
600
+ }
601
+ i = htry("chromosome", "chr");
602
+ if (i != -1) {
603
+ header[i] = "chr";
604
+ i = htry("chr_start");
605
+ if (i == -1) return "chr_start is required when chr is used";
606
+ header[i] = "chrpos1";
607
+ i = htry("chr_stop");
608
+ if (i == -1) return "chr_stop is required when chr is used";
609
+ header[i] = "chrpos2";
610
+ }
611
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
612
+ if (i != -1) header[i] = "sample";
613
+ i = htry("patient", "donor", "target_case_id");
614
+ if (i != -1) header[i] = "patient";
615
+ i = htry("disease");
616
+ if (i != -1) header[i] = "disease";
617
+ i = htry("origin");
618
+ if (i != -1) header[i] = "origin";
619
+ i = htry("sampletype", "sample type", "sample_type");
620
+ if (i != -1) header[i] = "sampletype";
621
+ flag2.del.header = header;
622
+ flag2.del.loaded = true;
623
+ return false;
624
+ }
625
+ function parseline6(i, line, flag2) {
626
+ if (line == "" || line[0] == "#") return;
627
+ const lst = line.split(" ");
628
+ const m = {};
629
+ for (let j = 0; j < flag2.del.header.length; j++) {
630
+ if (lst[j] == void 0) break;
631
+ m[flag2.del.header[j]] = lst[j];
632
+ }
633
+ if (!m.gene) {
634
+ flag2.del.badlines.push([i, "missing gene", lst]);
635
+ return;
636
+ }
637
+ if (m.rnaposition) {
638
+ let v = Number.parseInt(m.rnaposition);
639
+ if (Number.isNaN(v) || v < 0) {
640
+ flag2.del.badlines.push([i, "invalid rnaPosition value", lst]);
641
+ return;
642
+ }
643
+ m.rnaposition = v;
644
+ if (!m.rnadellength) {
645
+ flag2.del.badlines.push([i, "missing rnaDellength value", lst]);
646
+ return;
647
+ }
648
+ v = Number.parseInt(m.rnadellength);
649
+ if (Number.isNaN(v) || v < 0) {
650
+ flag2.del.badlines.push([i, "invalid rnaDellength value", lst]);
651
+ return;
652
+ }
653
+ m.rnadellength = v;
654
+ }
655
+ if (m.chr) {
656
+ let v = Number.parseInt(m.chrpos1);
657
+ if (Number.isNaN(v) || v < 0) {
658
+ flag2.del.badlines.push([i, "invalid chr_start value", lst]);
659
+ return;
660
+ }
661
+ m.chrpos1 = v;
662
+ v = Number.parseInt(m.chrpos2);
663
+ if (Number.isNaN(v) || v < 0) {
664
+ flag2.del.badlines.push([i, "invalid chr_stop value", lst]);
665
+ return;
666
+ }
667
+ m.chrpos2 = v;
668
+ }
669
+ if (parsesample(m, flag2, i, lst, flag2.del.badlines)) {
670
+ return;
671
+ }
672
+ m.dt = dtdel;
673
+ m.class = mclassdel;
674
+ m.mname = "DEL";
675
+ flag2.good++;
676
+ var n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
677
+ if (!(n in flag2.data)) {
678
+ flag2.data[n] = [];
679
+ }
680
+ flag2.data[n].push(m);
681
+ }
682
+
683
+ // ../shared/utils/src/bulk.trunc.js
684
+ function parseheader7(line, flag2) {
685
+ const header = line.toLowerCase().split(" ");
686
+ if (header.length <= 1) return "invalid header line for truncation";
687
+ const htry = (...lst) => {
688
+ for (const e of lst) {
689
+ const j = header.indexOf(e);
690
+ if (j != -1) return j;
691
+ }
692
+ return -1;
693
+ };
694
+ let i = htry("gene");
695
+ if (i == -1) return "gene missing from header";
696
+ header[i] = "gene";
697
+ i = htry(
698
+ "annovar_isoform",
699
+ "mrna_accession",
700
+ "mrna accession",
701
+ "refseq_mrna_id",
702
+ "annovar_sj_filter_isoform",
703
+ "refseq",
704
+ "isoform"
705
+ );
706
+ if (i == -1) return "isoform missing from header";
707
+ header[i] = "isoform";
708
+ let hasrnapos = false;
709
+ i = htry("rnaposition");
710
+ if (i != -1) {
711
+ header[i] = "rnaposition";
712
+ hasrnapos = true;
713
+ }
714
+ i = htry("losstype");
715
+ if (i == -1) return "lossType missing from header";
716
+ header[i] = "losstype";
717
+ let hasgenomic = false;
718
+ i = htry("chromosome", "chr");
719
+ if (i != -1) {
720
+ header[i] = "chr";
721
+ i = htry("start", "start_position", "wu_hg19_pos", "chr_position", "position");
722
+ if (i == -1) {
723
+ return "genomic position missing from header";
724
+ }
725
+ header[i] = "pos";
726
+ hasgenomic = true;
727
+ }
728
+ if (!hasrnapos && !hasgenomic) {
729
+ return "neither rnaposition nor genomic position is given";
730
+ }
731
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
732
+ if (i != -1) header[i] = "sample";
733
+ i = htry("patient", "donor", "target_case_id");
734
+ if (i != -1) header[i] = "patient";
735
+ i = htry("disease");
736
+ if (i != -1) header[i] = "disease";
737
+ i = htry("origin");
738
+ if (i != -1) header[i] = "origin";
739
+ i = htry("sampletype", "sample type", "sample_type");
740
+ if (i != -1) header[i] = "sampletype";
741
+ flag2.truncation.header = header;
742
+ flag2.truncation.loaded = true;
743
+ return false;
744
+ }
745
+ function parseline7(i, line, flag2) {
746
+ if (line == "" || line[0] == "#") return;
747
+ const lst = line.split(" ");
748
+ const m = {};
749
+ for (let j = 0; j < flag2.truncation.header.length; j++) {
750
+ m[flag2.truncation.header[j]] = lst[j];
751
+ }
752
+ if (!m.gene) {
753
+ flag2.truncation.badlines.push([i, "missing gene", lst]);
754
+ return;
755
+ }
756
+ if (m.rnaposition) {
757
+ const v = Number.parseInt(m.rnaposition);
758
+ if (Number.isNaN(v) || v < 0) {
759
+ flag2.truncation.badlines.push([i, "invalid rnaPosition value", lst]);
760
+ return;
761
+ }
762
+ m.rnaposition = v;
763
+ }
764
+ if (m.pos) {
765
+ const v = Number.parseInt(m.pos);
766
+ if (Number.isNaN(v) || v < 0) {
767
+ flag2.truncation.badlines.push([i, "invalid genomic position", lst]);
768
+ return;
769
+ }
770
+ m.pos = v;
771
+ }
772
+ if (!m.losstype) {
773
+ flag2.truncation.badlines.push([i, "missing lossType value", lst]);
774
+ return;
775
+ }
776
+ if (m.losstype != "n" && m.losstype != "c") {
777
+ flag2.truncation.badlines.push([i, 'lossType value not "n" or "c"', lst]);
778
+ return;
779
+ }
780
+ if (parsesample(m, flag2, i, lst, flag2.truncation.badlines)) {
781
+ return;
782
+ }
783
+ if (m.losstype == "n") {
784
+ m.dt = dtnloss;
785
+ m.class = mclassnloss;
786
+ m.mname = "N-loss";
787
+ } else {
788
+ m.dt = dtcloss;
789
+ m.class = mclasscloss;
790
+ m.mname = "C-loss";
791
+ }
792
+ flag2.good++;
793
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
794
+ if (!(n in flag2.data)) {
795
+ flag2.data[n] = [];
796
+ }
797
+ flag2.data[n].push(m);
798
+ }
799
+
800
+ // src/bulk.project.js
801
+ var schemaNames = ["heatmapJSON", "piebarJSON", "survivalJSON", "discoJSON", "riverJSON"];
802
+ var typeIndex = {
803
+ snvindel: 0,
804
+ si: 0,
805
+ sv: 1,
806
+ fusion: 2,
807
+ itd: 3,
808
+ deletion: 4,
809
+ truncation: 5,
810
+ cnv: 6
811
+ };
812
+ var urlProjectLoaded = false;
813
+ var ProjectHandler = class {
814
+ /*
815
+ Create a handler for multiple uploaded or fetched
816
+ files in a project
817
+
818
+ bt = {
819
+ flag: closured flag inside bulkui.bulkui,
820
+ bulkin: bulkui.bulkin,
821
+ content2flag: bulkui.content2flag,
822
+ flag2tp: closured flat2tp,
823
+ filediv: (optional) d3-wrapped container for file-input
824
+ }
825
+ */
826
+ constructor(bt) {
827
+ this.bt = bt;
828
+ this.err = this.errHandler();
829
+ if (!urlProjectLoaded) {
830
+ const params = getParams();
831
+ if (params.project) {
832
+ this.getData(params.project);
833
+ urlProjectLoaded = true;
834
+ }
835
+ }
836
+ if (bt.filediv) {
837
+ this.projectByInput(bt.filediv);
838
+ }
839
+ }
840
+ /*
841
+ Process data files sequentially for rendering
842
+ into a TP div
843
+
844
+ data = {
845
+ schemas: object {
846
+ heatmapJSON (optional),
847
+ piebarJSON (optional),
848
+ survivalJSON (optional)
849
+ },
850
+ files: [] array of {
851
+ name: string
852
+ typeL one of the typeIndex values
853
+ content: string
854
+ }
855
+ }
856
+ */
857
+ processData(data) {
858
+ const file = data.files.pop();
859
+ const i = data.expectedFileNames.indexOf(file.name);
860
+ if (i == -1) {
861
+ if (data.files.length)
862
+ setTimeout(() => {
863
+ this.processData(data);
864
+ }, 1);
865
+ return;
866
+ }
867
+ data.expectedFileNames.splice(i, 1);
868
+ this.cohort = {
869
+ name: "project",
870
+ genome: this.bt.genomes[this.bt.gselect.options[this.bt.gselect.selectedIndex].innerHTML]
871
+ };
872
+ if (!this.flag) {
873
+ this.flag = this.bt.init_bulk_flag(this.cohort.genome);
874
+ }
875
+ const error = this.bt.content2flag(file.content, file.type, this.flag);
876
+ if (error) {
877
+ this.err(error);
878
+ this.processData(data);
879
+ } else if (!data.files.length) {
880
+ if (data.expectedFileNames.length) {
881
+ this.err('These referenced files were not found: "' + data.expectedFileNames.join('", "') + '".');
882
+ }
883
+ this.bt.flag2tp(this.flag, { name: "project" }, Object.assign(this.cohort, data.schema), this.ds);
884
+ return;
885
+ } else {
886
+ if (!this.ds) {
887
+ for (const k in this.cohort.dsset) {
888
+ this.ds = this.cohort.dsset[k];
889
+ break;
890
+ }
891
+ }
892
+ const error1 = this.bt.bulkin(
893
+ {
894
+ flag: this.flag,
895
+ cohort: this.cohort,
896
+ flag2thisds: this.ds,
897
+ filename: "project"
898
+ },
899
+ () => {
900
+ this.processData(data);
901
+ }
902
+ );
903
+ if (error1) {
904
+ this.err("Error with " + file.name + ": " + error1);
905
+ return;
906
+ }
907
+ if (this.flag.good === 0) {
908
+ this.err(file.name + ": no data loaded");
909
+ return;
910
+ }
911
+ }
912
+ }
913
+ getData(project) {
914
+ const [projectname, _refname] = project.split("/");
915
+ const refname = _refname && _refname.trim() ? _refname.trim() : "ref.txt";
916
+ this.gettext("/data/projects/" + projectname + "/" + refname, (text) => {
917
+ const fileNameToType = {};
918
+ const nameToSchemaType = {};
919
+ const data = { schema: {}, files: [], expectedFileNames: [] };
920
+ let schemaFileName = "";
921
+ let numProcessedFiles = 0;
922
+ let numFiles = 0;
923
+ text.trim().split("\n").forEach((line) => {
924
+ const [type, filename] = line.trim().split(" ");
925
+ if (schemaNames.includes(type)) {
926
+ nameToSchemaType[filename] = type;
927
+ numFiles += 1;
928
+ } else if (!typeIndex[type] && typeIndex[type] !== 0) {
929
+ this.err("Unrecognized type " + type + " for file " + filename + " in reference.txt.");
930
+ } else {
931
+ fileNameToType[filename] = typeIndex[type];
932
+ numFiles += 1;
933
+ }
934
+ });
935
+ data.expectedFileNames = Object.keys(fileNameToType);
936
+ const tracker = this.getTracker(numFiles, () => this.processData(data));
937
+ Object.keys(nameToSchemaType).forEach((filename) => {
938
+ this.getjson("/data/projects/" + projectname + "/" + filename, (json) => {
939
+ data.schema[nameToSchemaType[filename]] = json;
940
+ tracker();
941
+ });
942
+ });
943
+ Object.keys(fileNameToType).forEach((filename) => {
944
+ this.gettext("/data/projects/" + projectname + "/" + filename, (text2) => {
945
+ data.files.push({
946
+ name: filename,
947
+ type: fileNameToType[filename],
948
+ content: text2
949
+ });
950
+ tracker();
951
+ });
952
+ });
953
+ });
954
+ }
955
+ gettext(url, callback) {
956
+ fetch(url).then((response) => {
957
+ if (response.ok) return response.text();
958
+ else this.err("File request error: " + url);
959
+ }).then(callback).catch((error) => this.err("File request error: " + url + " " + error));
960
+ }
961
+ getjson(url, callback) {
962
+ fetch(url).then((response) => {
963
+ if (response.ok) return response.json();
964
+ else this.err("Network error for " + url);
965
+ }).then(callback).catch((error) => this.err("file request error: " + url + " " + error));
966
+ }
967
+ getTracker(numFiles, callback) {
968
+ let numProcessedFiles = 0;
969
+ return function tracker() {
970
+ numProcessedFiles += 1;
971
+ if (numProcessedFiles == numFiles) {
972
+ callback();
973
+ }
974
+ };
975
+ }
976
+ projectByInput(filediv) {
977
+ this.tp = null;
978
+ const advancedDiv = filediv.append("div");
979
+ advancedDiv.append("span").html("Project: reference &nbsp;");
980
+ this.refNameInput = advancedDiv.append("input").attr("type", "text").property("value", "ref.txt").style("margin-right", "20px").style("padding-left", "7px");
981
+ const buttlabel = advancedDiv.append("label").attr("for", "sja-pp-bulk-ui-project-btn").attr("class", "sja_btn").style("padding", "3px 5px").html("Choose folder");
982
+ const butt = advancedDiv.append("input").attr("type", "file").attr("id", "sja-pp-bulk-ui-project-btn").property("multiple", true).property("webkitdirectory", true).property("directory", true).on("change", (event) => this.readFiles(event));
983
+ advancedDiv.append("div").style("margin", "10px 10px 10px 0").html(`<a href="https://docs.google.com/document/d/1wlfGzyhxFYtWu9Fyf3FK7pgvS3rVb9_vrfYUBUOUrw4/edit?usp=sharing" target="new">Project user guide</a> |
984
+ <a href='https://proteinpaint.stjude.org/ppdemo/projects/target-tall-project/ref.txt' target=_blank>Example project reference file</a>`);
985
+ advancedDiv.append("div").style("margin", "20px").style("width", "100%").html("-- OR --");
986
+ }
987
+ /* to be used as a file input (FileList) handler */
988
+ readFiles(event) {
989
+ const self = this;
990
+ const refFileName = self.refNameInput.property("value");
991
+ const files = Array.from(event.target.files);
992
+ const ref = files.filter((f) => f.name == refFileName)[0];
993
+ if (!ref) {
994
+ self.err("Missing reference file='" + refFileName + "'.");
995
+ return;
996
+ }
997
+ const fileNameToType = {};
998
+ const nameToSchemaType = {};
999
+ const data = { schema: {}, files: [], expectedFileNames: [] };
1000
+ const reader = new FileReader();
1001
+ let schemaFileName = "";
1002
+ let numProcessedFiles = 0;
1003
+ reader.onload = (event2) => {
1004
+ event2.target.result.trim().split("\n").forEach((line) => {
1005
+ const [type, filename] = line.trim().split(" ");
1006
+ if (schemaNames.includes(type)) {
1007
+ nameToSchemaType[filename] = type;
1008
+ } else if (!typeIndex[type] && typeIndex[type] !== 0) {
1009
+ self.err("Unrecognized type " + type + " for file " + filename + " in reference.txt.");
1010
+ } else {
1011
+ fileNameToType[filename] = typeIndex[type];
1012
+ }
1013
+ });
1014
+ data.expectedFileNames = Object.keys(fileNameToType);
1015
+ const schemaFiles = files.filter((file) => file.name in nameToSchemaType);
1016
+ let numProcessedSchemas = 0;
1017
+ if (!schemaFiles.length) {
1018
+ files.forEach(processFile);
1019
+ } else {
1020
+ schemaFiles.forEach((file) => {
1021
+ const reader2 = new FileReader();
1022
+ reader2.onload = (event3) => {
1023
+ const schema = JSON.parse(event3.target.result);
1024
+ numProcessedSchemas += 1;
1025
+ if (!schema) {
1026
+ self.err('Unable to parse schema file="' + file.name + '".');
1027
+ } else {
1028
+ data.schema[nameToSchemaType[file.name]] = schema;
1029
+ }
1030
+ if (numProcessedSchemas == schemaFiles.length) {
1031
+ files.forEach(processFile);
1032
+ }
1033
+ };
1034
+ reader2.onerror = () => {
1035
+ self.err("Error reading schema.txt.");
1036
+ };
1037
+ reader2.readAsText(file, "utf8");
1038
+ });
1039
+ }
1040
+ function processFile(file) {
1041
+ if (!data.expectedFileNames.includes(file.name)) {
1042
+ numProcessedFiles += 1;
1043
+ return;
1044
+ }
1045
+ if (!file) {
1046
+ self.err("Error reading file.");
1047
+ numProcessedFiles += 1;
1048
+ return;
1049
+ }
1050
+ if (file.size == 0) {
1051
+ self.err("Wrong file: " + file.name);
1052
+ numProcessedFiles += 1;
1053
+ return;
1054
+ }
1055
+ if (!fileNameToType[file.name] && fileNameToType[file.name] !== 0 && file.name != schemaFileName) {
1056
+ self.err("Missing or invalid type assigned to file " + file.name + ".");
1057
+ numProcessedFiles += 1;
1058
+ return;
1059
+ }
1060
+ const reader2 = new FileReader();
1061
+ reader2.onload = (event3) => {
1062
+ numProcessedFiles += 1;
1063
+ data.files.push({
1064
+ name: file.name,
1065
+ type: fileNameToType[file.name],
1066
+ content: event3.target.result
1067
+ });
1068
+ if (numProcessedFiles == files.length) {
1069
+ self.processData(data);
1070
+ }
1071
+ };
1072
+ reader2.onerror = () => {
1073
+ numProcessedFiles += 1;
1074
+ self.err("Error reading file " + file.name);
1075
+ if (numProcessedFiles == files.length) {
1076
+ self.processData(data);
1077
+ }
1078
+ };
1079
+ reader2.readAsText(file, "utf8");
1080
+ }
1081
+ };
1082
+ reader.onerror = () => {
1083
+ self.err("Error reading reference.txt.");
1084
+ };
1085
+ reader.readAsText(ref, "utf8");
1086
+ }
1087
+ // function to track and display accumulated error messages
1088
+ errHandler() {
1089
+ const errdiv = select_default("body").append("div");
1090
+ let mssg = "";
1091
+ return function(m) {
1092
+ if (!m) return;
1093
+ sayerror(errdiv, m);
1094
+ };
1095
+ }
1096
+ };
1097
+ function getParams() {
1098
+ const params = {};
1099
+ window.location.search.substr(1).split("&").forEach((kv) => {
1100
+ const [key, value] = kv.split("=");
1101
+ params[key] = value;
1102
+ });
1103
+ return params;
1104
+ }
1105
+
1106
+ // src/bulk.ui.js
1107
+ function bulkui(x, y, genomes, hostURL, holder, header) {
1108
+ let pane, inputdiv, gselect, filediv, saydiv, visualdiv;
1109
+ if (holder !== void 0) [inputdiv, gselect, filediv, saydiv, visualdiv] = renderSandboxFormDiv(holder, genomes);
1110
+ else {
1111
+ ;
1112
+ [pane, inputdiv, gselect, filediv, saydiv, visualdiv] = newpane3(x, y, genomes);
1113
+ pane.header.text("Load mutation from text files");
1114
+ }
1115
+ inputdiv.append("div").style("margin", "20px 0px").style("color", "#858585").html(`
1116
+ <p>Choose one file and upload to initiate the display panel.<br>From there you can add additional files.</p>
1117
+ <div>Supported data types:</div>
1118
+ <ul>
1119
+ <li>SNV and indel</li>
1120
+ <ul>
1121
+ <li><a href=https://drive.google.com/open?id=1OJ9aXq2_-a3BfIQdKLYCYzrJRTpu4_9i3gephTY-Z38 target=_blank>Format</a>,
1122
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.snvindel.txt target=_blank>example file</a></li>
1123
+ </ul>
1124
+ <li>SV or fusion transcript</li>
1125
+ <ul>
1126
+ <li><a href=https://drive.google.com/open?id=1klDZ0MHVkQTW2-lCu_AvpRE4_FcbhdB-yI17wNdPaOM target=_blank>Tabular format</a>,
1127
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.svfusion.txt target=_blank>example file</a>
1128
+ </li>
1129
+ <li>JSON-format, to come</li>
1130
+ </ul>
1131
+ <li>CNV, gene-level</li>
1132
+ <ul>
1133
+ <li><a href=https://drive.google.com/open?id=1WHptqOWNf96V0bYEDpj-EsKZGYnbBNc9aQIrhzdEJaU target=_blank>Format</a>,
1134
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.cnv.txt target=_blank>example file</a>
1135
+ </li>
1136
+ </ul>
1137
+ <li>ITD</li>
1138
+ <ul>
1139
+ <li>Internal tandem duplication, in-frame</li>
1140
+ <li><a href=https://drive.google.com/open?id=1Bh9awBsraoHbV8iWXv_3oDeXMsjIAHaOKHr973IJyZc target=_blank>Format</a>,
1141
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.itd.txt target=_blank>example file</a>
1142
+ </li>
1143
+ </ul>
1144
+ <li>Intragenic deletion, in-frame</li>
1145
+ <ul>
1146
+ <li><a href=https://drive.google.com/open?id=1tWbf3rg3BmVIZPGGPk023P0aBkDw_ry5XuZLGyGodyg target=_blank>Format</a>,
1147
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.deletion.txt target=_blank>example file</a>
1148
+ </li>
1149
+ </ul>
1150
+ <li>Truncation</li>
1151
+ <ul>
1152
+ <li>Either N-terminus loss or C-terminus loss</li>
1153
+ <li><a href=https://drive.google.com/open?id=1P1g-Y8r30pSKfan1BhYZcsUtSk7wRb4plaO1S-JCJr4 target=_blank>Format</a>,
1154
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.truncation.txt target=_blank>example file</a>
1155
+ </li>
1156
+ </ul>
1157
+ </ul>`);
1158
+ const fileui = () => {
1159
+ filediv.selectAll("*").remove();
1160
+ new ProjectHandler({
1161
+ bulkin,
1162
+ genomes,
1163
+ gselect,
1164
+ content2flag,
1165
+ flag2tp,
1166
+ filediv,
1167
+ init_bulk_flag
1168
+ });
1169
+ filediv.append("span").html("Select data type&nbsp;");
1170
+ const typeselect = filetypeselect(filediv).style("margin-right", "20px");
1171
+ const butt = filediv.append("input").attr("type", "file").on("change", (event) => {
1172
+ const flag2 = init_bulk_flag(genomes[gselect.options[gselect.selectedIndex].innerHTML]);
1173
+ flag2.geneToUpper = geneToUpper.property("checked");
1174
+ saydiv.text("");
1175
+ const file = event.target.files[0];
1176
+ if (!file) {
1177
+ fileui();
1178
+ return;
1179
+ }
1180
+ if (file.size == 0) {
1181
+ saydiv.text("Wrong file: " + file.name);
1182
+ fileui();
1183
+ return;
1184
+ }
1185
+ const reader = new FileReader();
1186
+ reader.onload = (event2) => {
1187
+ const error = content2flag(event2.target.result, typeselect.node().selectedIndex, flag2);
1188
+ if (error) {
1189
+ saydiv.text("Error: " + error);
1190
+ fileui();
1191
+ return;
1192
+ }
1193
+ flag2tp(flag2, file);
1194
+ };
1195
+ reader.onerror = function() {
1196
+ saydiv.text("Error reading file " + file.name);
1197
+ fileui();
1198
+ return;
1199
+ };
1200
+ saydiv.text("Parsing file " + file.name + " ...");
1201
+ reader.readAsText(file, "utf8");
1202
+ });
1203
+ setTimeout(() => butt.node().focus(), 1100);
1204
+ };
1205
+ fileui();
1206
+ filediv.append("span").html("<br/>Convert gene name to uppercase &nbsp;");
1207
+ const geneToUpper = filediv.append("span").append("input").attr("type", "checkbox").property("checked", true);
1208
+ function flag2tp(flag2, file, _cohort = null, ds = null) {
1209
+ if (typeof flag2 == "string") {
1210
+ saydiv.text(flag2);
1211
+ fileui();
1212
+ return;
1213
+ }
1214
+ saydiv.text("");
1215
+ fileui();
1216
+ const cohort = _cohort ? _cohort : Object.assign({
1217
+ genome: flag2.genome,
1218
+ name: file.name
1219
+ });
1220
+ const err2 = bulkin({
1221
+ flag: flag2,
1222
+ filename: file.name,
1223
+ cohort,
1224
+ flag2thisds: ds
1225
+ });
1226
+ if (err2) {
1227
+ saydiv.text("Error with " + file.name + ": " + err2);
1228
+ return;
1229
+ }
1230
+ if (flag2.good == 0) {
1231
+ saydiv.text("No mutations can be loaded");
1232
+ return;
1233
+ }
1234
+ let visual_holder;
1235
+ if (pane) {
1236
+ disappear(pane.pane);
1237
+ const pane2 = newpane({ x: 100, y: 100, toshrink: true });
1238
+ pane2.header.html('<span style="opacity:.5">FILE</span> ' + file.name);
1239
+ visual_holder = pane2.body;
1240
+ }
1241
+ if (holder !== void 0) {
1242
+ visual_holder = visualdiv.append("div").html('<span style="opacity:.5">FILE</span> ' + file.name);
1243
+ }
1244
+ inputdiv.selectAll("*").remove();
1245
+ import("./tp.ui-S4YUVCZH.js").then((tpui) => {
1246
+ tpui.default(cohort, visual_holder, hostURL);
1247
+ });
1248
+ return cohort;
1249
+ }
1250
+ return function content2flag2tp(file, type) {
1251
+ const error = content2flag(file.content, type, flag);
1252
+ if (error) {
1253
+ saydiv.text("Error: " + error);
1254
+ fileui();
1255
+ return;
1256
+ }
1257
+ flag2tp(flag, file);
1258
+ };
1259
+ }
1260
+ function content2flag(text, type, flag2) {
1261
+ if (!flag2) return "should not happen!";
1262
+ let err2;
1263
+ switch (type) {
1264
+ case 0:
1265
+ err2 = parse_snvindel(text, flag2);
1266
+ if (err2) return err2;
1267
+ break;
1268
+ case 1:
1269
+ err2 = parse_sv(text, flag2, true);
1270
+ if (err2) return err2;
1271
+ break;
1272
+ case 2:
1273
+ err2 = parse_sv(text, flag2, false);
1274
+ if (err2) return err2;
1275
+ break;
1276
+ case 3:
1277
+ err2 = parse_itd(text, flag2);
1278
+ if (err2) return err2;
1279
+ break;
1280
+ case 4:
1281
+ err2 = parse_del(text, flag2);
1282
+ if (err2) return err2;
1283
+ break;
1284
+ case 5:
1285
+ err2 = parse_trunc(text, flag2);
1286
+ if (err2) return err2;
1287
+ break;
1288
+ case 6:
1289
+ err2 = parse_cnv(text, flag2);
1290
+ if (err2) return err2;
1291
+ break;
1292
+ default:
1293
+ return "unknown option array index from file type <select>: " + type;
1294
+ }
1295
+ }
1296
+ function bulkin(p, callback = null) {
1297
+ const flag2 = p.flag;
1298
+ const cohort = p.cohort;
1299
+ if (!cohort.p2st) {
1300
+ cohort.p2st = {};
1301
+ }
1302
+ if (!cohort.dsset) {
1303
+ cohort.dsset = {};
1304
+ }
1305
+ if (!cohort.assaylst) {
1306
+ cohort.assaylst = [];
1307
+ }
1308
+ if (flag2.variantgene) {
1309
+ if (cohort.variantgene) {
1310
+ return "variantgene already set for this cohort";
1311
+ }
1312
+ cohort.variantgene = flag2.variantgene;
1313
+ }
1314
+ if (flag2.snv.badlines.length > 0) {
1315
+ bulk_badline(flag2.snv.header, flag2.snv.badlines);
1316
+ }
1317
+ if (flag2.fusion.badlines.length > 0) {
1318
+ bulk_badline(flag2.fusion.header, flag2.fusion.badlines);
1319
+ }
1320
+ if (flag2.sv.badlines.length > 0) {
1321
+ bulk_badline(flag2.sv.header, flag2.sv.badlines);
1322
+ }
1323
+ if (flag2.cnv.badlines.length > 0) {
1324
+ bulk_badline(flag2.cnv.header, flag2.cnv.badlines);
1325
+ }
1326
+ if (flag2.itd.badlines.length > 0) {
1327
+ bulk_badline(flag2.itd.header, flag2.itd.badlines);
1328
+ }
1329
+ if (flag2.del.badlines.length > 0) {
1330
+ bulk_badline(flag2.del.header, flag2.del.badlines);
1331
+ }
1332
+ if (flag2.truncation.badlines.length > 0) {
1333
+ bulk_badline(flag2.truncation.header, flag2.truncation.badlines);
1334
+ }
1335
+ if (flag2.good == 0) {
1336
+ return false;
1337
+ }
1338
+ const tmp = {};
1339
+ let hastumormaf = false;
1340
+ if (flag2.snv.loaded) {
1341
+ for (const i of flag2.snv.header) {
1342
+ tmp[i] = 1;
1343
+ }
1344
+ if ("maf_tumor_v1" in tmp && "maf_tumor_v2" in tmp) {
1345
+ hastumormaf = true;
1346
+ }
1347
+ }
1348
+ if (flag2.cnv.loaded) {
1349
+ for (const i of flag2.cnv.header) {
1350
+ tmp[i] = 1;
1351
+ }
1352
+ }
1353
+ if (flag2.fusion.loaded) {
1354
+ for (const i of flag2.fusion.header) {
1355
+ tmp[i] = 1;
1356
+ }
1357
+ }
1358
+ if (flag2.sv.loaded) {
1359
+ for (const i of flag2.sv.header) {
1360
+ tmp[i] = 1;
1361
+ }
1362
+ }
1363
+ if (flag2.itd.loaded) {
1364
+ for (const i of flag2.itd.header) {
1365
+ tmp[i] = 1;
1366
+ }
1367
+ }
1368
+ if (flag2.del.loaded) {
1369
+ for (const i of flag2.del.header) {
1370
+ tmp[i] = 1;
1371
+ }
1372
+ }
1373
+ if (flag2.truncation.loaded) {
1374
+ for (const i of flag2.truncation.header) {
1375
+ tmp[i] = 1;
1376
+ }
1377
+ }
1378
+ const hassample = "sample" in tmp || "patient" in tmp;
1379
+ const hasdisease = "disease" in tmp;
1380
+ const hasst = "sampletype" in tmp;
1381
+ let dsc;
1382
+ if (p.flag2thisds) {
1383
+ dsc = p.flag2thisds;
1384
+ if (hassample && !dsc.hassample) {
1385
+ return '"sample" column found in new data but not in existing data';
1386
+ }
1387
+ if (!hassample && dsc.hassample) {
1388
+ return '"sample" column found in existing data but not in new data';
1389
+ }
1390
+ if (hasdisease && !dsc.hasdisease) {
1391
+ return '"disease" column found in new data but not in existing data';
1392
+ }
1393
+ if (!hasdisease && dsc.hasdisease) {
1394
+ return '"disease" column found in existing data but not in new data';
1395
+ }
1396
+ if (hasst && !dsc.hasst) {
1397
+ return '"sampletype" column found in new data but not in existing data';
1398
+ }
1399
+ if (!hasst && dsc.hasst) {
1400
+ return '"sampletype" column found in existing data but not in new data';
1401
+ }
1402
+ for (const genename in flag2.data) {
1403
+ const lst = dsc.bulkdata[genename];
1404
+ if (lst) {
1405
+ dsc.bulkdata[genename] = lst.concat(flag2.data[genename]);
1406
+ } else {
1407
+ dsc.bulkdata[genename] = flag2.data[genename];
1408
+ }
1409
+ }
1410
+ } else {
1411
+ let dsname = p.filename + (flag2.tpsetname ? "_" + flag2.tpsetname : "");
1412
+ if (dsname in flag2.genome.datasets) {
1413
+ let j = 1;
1414
+ let n2 = dsname + " " + j;
1415
+ while (n2 in flag2.genome.datasets) {
1416
+ j++;
1417
+ n2 = dsname + " " + j;
1418
+ }
1419
+ dsname = n2;
1420
+ }
1421
+ dsc = {
1422
+ label: dsname,
1423
+ bulkdata: flag2.data,
1424
+ // official dataset don't have this
1425
+ hassample,
1426
+ hasdisease,
1427
+ hastumormaf,
1428
+ hasst,
1429
+ genome: cohort.genome,
1430
+ import: {},
1431
+ imported: {},
1432
+ importsilent: flag2.snv.silent == 0 ? false : flag2.snv.missense / flag2.snv.silent >= 5 ? false : true
1433
+ };
1434
+ flag2.genome.datasets[dsname] = dsc;
1435
+ cohort.dsset[dsname] = dsc;
1436
+ if (cohort.dbexpression) {
1437
+ if (cohort.dbexpression.tidy) {
1438
+ try {
1439
+ cohort.dbexpression.tidy = new Function(...cohort.dbexpression.tidy);
1440
+ } catch (e) {
1441
+ err("invalid JavaScript for dbexpression.tidy");
1442
+ delete cohort.dbexpression;
1443
+ }
1444
+ }
1445
+ dsc.dbexpression = cohort.dbexpression;
1446
+ }
1447
+ if (hasdisease) {
1448
+ dsc.stratify = [
1449
+ {
1450
+ label: "disease",
1451
+ attr1: { k: "disease", label: "disease" }
1452
+ }
1453
+ ];
1454
+ }
1455
+ }
1456
+ if (hassample) {
1457
+ for (const gene in flag2.data) {
1458
+ for (const m of flag2.data[gene]) {
1459
+ let pn = m.patient;
1460
+ if (!pn) {
1461
+ pn = m.sample;
1462
+ if (!pn) {
1463
+ continue;
1464
+ }
1465
+ }
1466
+ if (!cohort.p2st[pn]) {
1467
+ cohort.p2st[pn] = {};
1468
+ }
1469
+ let st = m.sampletype;
1470
+ if (!st) {
1471
+ st = pn;
1472
+ }
1473
+ if (!cohort.p2st[pn][st]) {
1474
+ cohort.p2st[pn][st] = {
1475
+ dsset: {},
1476
+ tktemplate: []
1477
+ };
1478
+ }
1479
+ if (!cohort.p2st[pn][st].dsset[dsc.label]) {
1480
+ cohort.p2st[pn][st].dsset[dsc.label] = [];
1481
+ }
1482
+ cohort.p2st[pn][st].dsset[dsc.label].push(m);
1483
+ }
1484
+ }
1485
+ }
1486
+ if (callback) callback();
1487
+ return false;
1488
+ }
1489
+ function bulkembed(arg) {
1490
+ if (!arg.name) arg.name = "Unnamed dataset";
1491
+ let holder = arg.holder;
1492
+ if (!holder) {
1493
+ const pane = newpane({ x: 100, y: 100 });
1494
+ holder = pane.body;
1495
+ }
1496
+ const saydiv = holder.append("div");
1497
+ new Promise((resolve, reject) => {
1498
+ const cohort = {
1499
+ dsset: {}
1500
+ };
1501
+ for (const k in arg) {
1502
+ if (k == "snvindel" || k == "svjson" || k == "cnv" || k == "sv" || k == "mutationset") {
1503
+ continue;
1504
+ }
1505
+ cohort[k] = arg[k];
1506
+ }
1507
+ resolve(cohort);
1508
+ }).then((cohort) => {
1509
+ if (!arg.snvindel && !arg.svjson && !arg.cnv && !arg.sv) return cohort;
1510
+ const flag2 = init_bulk_flag(cohort.genome);
1511
+ if (arg.snvindel) {
1512
+ const e = parse_snvindel(arg.snvindel, flag2);
1513
+ if (e) throw { message: "error in snvindel data: " + e };
1514
+ delete arg.snvindel;
1515
+ }
1516
+ if (arg.svjson) {
1517
+ const e = parse_svjson(arg.svjson, flag2);
1518
+ if (e) throw { message: "error in svjson data: " + e };
1519
+ delete arg.svjson;
1520
+ }
1521
+ if (arg.sv) {
1522
+ const e = parse_sv(arg.sv, flag2);
1523
+ if (e) throw { message: "error in svjson data: " + e };
1524
+ delete arg.sv;
1525
+ }
1526
+ if (arg.cnv) {
1527
+ const e = parse_cnv(arg.cnv, flag2);
1528
+ if (e) throw { message: "error in cnv data: " + e };
1529
+ delete arg.cnv;
1530
+ }
1531
+ const err2 = bulkin({
1532
+ flag: flag2,
1533
+ filename: arg.name,
1534
+ cohort
1535
+ });
1536
+ if (err2) throw { message: "Error parsing data: " + err2 };
1537
+ return cohort;
1538
+ }).then((cohort) => {
1539
+ if (!arg.mutationset) return cohort;
1540
+ if (!Array.isArray(arg.mutationset)) throw { message: "mutationset is not an array" };
1541
+ const tasks2 = [];
1542
+ for (const mset of arg.mutationset) {
1543
+ const flag2 = init_bulk_flag(cohort.genome);
1544
+ const tasks = [];
1545
+ if (mset.snvindel) {
1546
+ const req = new Request(arg.hostURL + "/textfile", {
1547
+ method: "POST",
1548
+ body: '{"file":"' + mset.snvindel + '"}'
1549
+ });
1550
+ const task = fetch(req).then((data) => {
1551
+ return data.json();
1552
+ }).then((data) => {
1553
+ if (data.error) throw { message: "error with snvindel file: " + data.error };
1554
+ const e = parse_snvindel(data.text, flag2);
1555
+ if (e) throw { message: "error with snvindel file: " + e };
1556
+ });
1557
+ tasks.push(task);
1558
+ }
1559
+ if (mset.snvindel_url) {
1560
+ tasks.push(
1561
+ dofetch("urltextfile", { url: mset.snvindel_url }).then((data) => {
1562
+ if (data.error) throw { message: "cannot get snvindel file from url" };
1563
+ const e = parse_snvindel(data.text, flag2);
1564
+ if (e) throw { message: "error with snvindel file: " + e };
1565
+ })
1566
+ );
1567
+ }
1568
+ if (mset.cnv) {
1569
+ const req = new Request(arg.hostURL + "/textfile", {
1570
+ method: "POST",
1571
+ body: '{"file":"' + mset.cnv + '"}'
1572
+ });
1573
+ const task = fetch(req).then((data) => {
1574
+ return data.json();
1575
+ }).then((data) => {
1576
+ if (data.error) throw { message: "error with cnv file: " + data.error };
1577
+ const e = parse_cnv(data.text, flag2);
1578
+ if (e) throw { message: "error with cnv file: " + e };
1579
+ });
1580
+ tasks.push(task);
1581
+ }
1582
+ if (mset.cnv_url) {
1583
+ tasks.push(
1584
+ dofetch("urltextfile", { url: mset.cnv_url }).then((data) => {
1585
+ if (data.error) throw { message: "cannot get cnv file from url" };
1586
+ const e = parse_cnv(data.text, flag2);
1587
+ if (e) throw { message: "error with cnv file: " + e };
1588
+ })
1589
+ );
1590
+ }
1591
+ if (mset.sv) {
1592
+ const req = new Request(arg.hostURL + "/textfile", {
1593
+ method: "POST",
1594
+ body: '{"file":"' + mset.sv + '"}'
1595
+ });
1596
+ const task = fetch(req).then((data) => {
1597
+ return data.json();
1598
+ }).then((data) => {
1599
+ if (data.error) throw { message: "error with sv file: " + data.error };
1600
+ const e = parse_sv(data.text, flag2, true);
1601
+ if (e) throw { message: "error with sv file: " + e };
1602
+ });
1603
+ tasks.push(task);
1604
+ }
1605
+ if (mset.sv_url) {
1606
+ tasks.push(
1607
+ dofetch("urltextfile", { url: mset.sv_url }).then((data) => {
1608
+ if (data.error) throw { message: "cannot get sv file from url" };
1609
+ const e = parse_sv(data.text, flag2);
1610
+ if (e) throw { message: "error with sv file: " + e };
1611
+ })
1612
+ );
1613
+ }
1614
+ if (mset.fusion) {
1615
+ const req = new Request(arg.hostURL + "/textfile", {
1616
+ method: "POST",
1617
+ body: '{"file":"' + mset.fusion + '"}'
1618
+ });
1619
+ const task = fetch(req).then((data) => {
1620
+ return data.json();
1621
+ }).then((data) => {
1622
+ if (data.error) throw { message: "error with fusion file: " + data.error };
1623
+ const e = parse_sv(data.text, flag2, false);
1624
+ if (e) throw { message: "error with fusion file: " + e };
1625
+ });
1626
+ tasks.push(task);
1627
+ }
1628
+ if (mset.svjson) {
1629
+ const req = new Request(arg.hostURL + "/textfile", {
1630
+ method: "POST",
1631
+ body: '{"file":"' + mset.svjson + '"}'
1632
+ });
1633
+ const task = fetch(req).then((data) => {
1634
+ return data.json();
1635
+ }).then((data) => {
1636
+ if (data.error) throw { message: "error with svjson file: " + data.error };
1637
+ const e = parse_svjson(data.text, flag2, false);
1638
+ if (e) throw { message: "error with svjson file: " + e };
1639
+ });
1640
+ tasks.push(task);
1641
+ }
1642
+ if (mset.deletion) {
1643
+ const req = new Request(arg.hostURL + "/textfile", {
1644
+ method: "POST",
1645
+ body: '{"file":"' + mset.deletion + '"}'
1646
+ });
1647
+ const task = fetch(req).then((data) => {
1648
+ return data.json();
1649
+ }).then((data) => {
1650
+ if (data.error) throw { message: "error with deletion file: " + data.error };
1651
+ const e = parse_del(data.text, flag2, false);
1652
+ if (e) throw { message: "error with deletion file: " + e };
1653
+ });
1654
+ tasks.push(task);
1655
+ }
1656
+ if (mset.deletion_url) {
1657
+ tasks.push(
1658
+ dofetch("urltextfile", { url: mset.deletion_url }).then((data) => {
1659
+ if (data.error) throw { message: "cannot get deletion file from url" };
1660
+ const e = parse_del(data.text, flag2);
1661
+ if (e) throw { message: "error with deletion file: " + e };
1662
+ })
1663
+ );
1664
+ }
1665
+ if (mset.truncation) {
1666
+ const req = new Request(arg.hostURL + "/textfile", {
1667
+ method: "POST",
1668
+ body: '{"file":"' + mset.truncation + '"}'
1669
+ });
1670
+ const task = fetch(req).then((data) => {
1671
+ return data.json();
1672
+ }).then((data) => {
1673
+ if (data.error) throw { message: "error with truncation file: " + data.error };
1674
+ const e = parse_trunc(data.text, flag2, false);
1675
+ if (e) throw { message: "error with truncation file: " + e };
1676
+ });
1677
+ tasks.push(task);
1678
+ }
1679
+ if (mset.truncation_url) {
1680
+ tasks.push(
1681
+ dofetch("urltextfile", { url: mset.truncation_url }).then((data) => {
1682
+ if (data.error) throw { message: "cannot get truncation file from url" };
1683
+ const e = parse_trunc(data.text, flag2, false);
1684
+ if (e) throw { message: "error with truncation file: " + e };
1685
+ })
1686
+ );
1687
+ }
1688
+ if (mset.itd) {
1689
+ const req = new Request(arg.hostURL + "/textfile", {
1690
+ method: "POST",
1691
+ body: '{"file":"' + mset.itd + '"}'
1692
+ });
1693
+ const task = fetch(req).then((data) => {
1694
+ return data.json();
1695
+ }).then((data) => {
1696
+ if (data.error) throw { message: "error with itd file: " + data.error };
1697
+ const e = parse_itd(data.text, flag2, false);
1698
+ if (e) throw { message: "error with itd file: " + e };
1699
+ });
1700
+ tasks.push(task);
1701
+ }
1702
+ if (mset.itd_url) {
1703
+ tasks.push(
1704
+ dofetch("urltextfile", { url: mset.itd_url }).then((data) => {
1705
+ if (data.error) throw { message: "cannot get itd file from url" };
1706
+ const e = parse_itd(data.text, flag2, false);
1707
+ if (e) throw { message: "error with itd file: " + e };
1708
+ })
1709
+ );
1710
+ }
1711
+ const task2 = Promise.all(tasks).then((data) => {
1712
+ const err2 = bulkin({
1713
+ flag: flag2,
1714
+ filename: arg.name,
1715
+ cohort
1716
+ });
1717
+ if (err2) throw { message: "Error parsing data from " + mset.name + ": " + err2 };
1718
+ });
1719
+ tasks2.push(task2);
1720
+ }
1721
+ return Promise.all(tasks2).then((data) => {
1722
+ return cohort;
1723
+ });
1724
+ }).then((cohort) => {
1725
+ const err2 = tpinit(cohort);
1726
+ if (err2) throw { message: "Error parsing study: " + err2 };
1727
+ saydiv.text("");
1728
+ import("./tp.ui-S4YUVCZH.js").then((p) => {
1729
+ p.default(cohort, holder, arg.hostURL);
1730
+ });
1731
+ }).catch((err2) => {
1732
+ saydiv.text(err2.message);
1733
+ if (err2.stack) {
1734
+ console.log(err2.stack);
1735
+ }
1736
+ });
1737
+ }
1738
+ function parse_snvindel(text, flag2) {
1739
+ const lines = text.trim().split(/\r?\n/);
1740
+ let headerline = lines[0];
1741
+ let lineidx = 0;
1742
+ while (headerline[0] == "#") {
1743
+ lineidx++;
1744
+ headerline = lines[lineidx];
1745
+ }
1746
+ if (!headerline) return "no header line";
1747
+ const err2 = parseheader2(headerline, flag2);
1748
+ if (err2) return "header error: " + err2;
1749
+ for (let i = lineidx + 1; i < lines.length; i++) {
1750
+ if (lines[i] == "") continue;
1751
+ if (lines[i][0] == "#") continue;
1752
+ parseline2(i, lines[i], flag2);
1753
+ }
1754
+ }
1755
+ function parse_svjson(text, flag2) {
1756
+ const lines = text.split(/\r?\n/);
1757
+ let headerline = lines[0];
1758
+ let lineidx = 0;
1759
+ while (headerline[0] == "#") {
1760
+ lineidx++;
1761
+ headerline = lines[lineidx];
1762
+ }
1763
+ if (!headerline) return "no header line";
1764
+ const [err2, header] = parseheader3(headerline, flag2);
1765
+ if (err2) return "header error: " + err2;
1766
+ for (let i = lineidx + 1; i < lines.length; i++) {
1767
+ if (lines[i] == "") continue;
1768
+ if (lines[i][0] == "#") continue;
1769
+ parseline3(i, lines[i], flag2, header);
1770
+ }
1771
+ }
1772
+ function parse_cnv(text, flag2) {
1773
+ const lines = text.split(/\r?\n/);
1774
+ let headerline = lines[0];
1775
+ let lineidx = 0;
1776
+ while (headerline[0] == "#") {
1777
+ lineidx++;
1778
+ headerline = lines[lineidx];
1779
+ }
1780
+ if (!headerline) return "no header line";
1781
+ const err2 = parseheader4(headerline, flag2);
1782
+ if (err2) return "header error: " + err2;
1783
+ for (let i = lineidx + 1; i < lines.length; i++) {
1784
+ if (lines[i] == "") continue;
1785
+ if (lines[i][0] == "#") continue;
1786
+ parseline4(i, lines[i], flag2);
1787
+ }
1788
+ }
1789
+ function parse_itd(text, flag2) {
1790
+ const lines = text.split(/\r?\n/);
1791
+ let headerline = lines[0];
1792
+ let lineidx = 0;
1793
+ while (headerline[0] == "#") {
1794
+ lineidx++;
1795
+ headerline = lines[lineidx];
1796
+ }
1797
+ if (!headerline) return "no header line";
1798
+ const err2 = parseheader5(headerline, flag2);
1799
+ if (err2) return "header error: " + err2;
1800
+ for (let i = lineidx + 1; i < lines.length; i++) {
1801
+ if (lines[i] == "") continue;
1802
+ if (lines[i][0] == "#") continue;
1803
+ parseline5(i, lines[i], flag2);
1804
+ }
1805
+ }
1806
+ function parse_del(text, flag2) {
1807
+ const lines = text.split(/\r?\n/);
1808
+ let headerline = lines[0];
1809
+ let lineidx = 0;
1810
+ while (headerline[0] == "#") {
1811
+ lineidx++;
1812
+ headerline = lines[lineidx];
1813
+ }
1814
+ if (!headerline) return "no header line";
1815
+ const err2 = parseheader6(headerline, flag2);
1816
+ if (err2) return "header error: " + err2;
1817
+ for (let i = lineidx + 1; i < lines.length; i++) {
1818
+ if (lines[i] == "") continue;
1819
+ if (lines[i][0] == "#") continue;
1820
+ parseline6(i, lines[i], flag2);
1821
+ }
1822
+ }
1823
+ function parse_trunc(text, flag2) {
1824
+ const lines = text.split(/\r?\n/);
1825
+ let headerline = lines[0];
1826
+ let lineidx = 0;
1827
+ while (headerline[0] == "#") {
1828
+ lineidx++;
1829
+ headerline = lines[lineidx];
1830
+ }
1831
+ if (!headerline) return "no header line";
1832
+ const err2 = parseheader7(headerline, flag2);
1833
+ if (err2) return "header error: " + err2;
1834
+ for (let i = lineidx + 1; i < lines.length; i++) {
1835
+ if (lines[i] == "") continue;
1836
+ if (lines[i][0] == "#") continue;
1837
+ parseline7(i, lines[i], flag2);
1838
+ }
1839
+ }
1840
+ function parse_sv(text, flag2, isSv) {
1841
+ const lines = text.split(/\r?\n/);
1842
+ let headerline = lines[0];
1843
+ let lineidx = 0;
1844
+ while (headerline[0] == "#") {
1845
+ lineidx++;
1846
+ headerline = lines[lineidx];
1847
+ }
1848
+ if (!headerline) return "no header line";
1849
+ const err2 = parseheader(headerline, flag2, isSv);
1850
+ if (err2) return "header error: " + err2;
1851
+ for (let i = lineidx + 1; i < lines.length; i++) {
1852
+ if (lines[i] == "") continue;
1853
+ if (lines[i][0] == "#") continue;
1854
+ parseline(i, lines[i], flag2, isSv);
1855
+ }
1856
+ }
1857
+
1858
+ // src/tp.init.js
1859
+ function tpinit(cohort) {
1860
+ if (!cohort.p2st) {
1861
+ cohort.p2st = {};
1862
+ }
1863
+ if (!cohort.assays) {
1864
+ cohort.assays = [];
1865
+ }
1866
+ if (!Array.isArray(cohort.assays)) {
1867
+ return ".assays should be an array";
1868
+ }
1869
+ cohort.assaylst = [];
1870
+ let assaynum = 0;
1871
+ for (const assayname of cohort.assays) {
1872
+ const rawassay = cohort[assayname];
1873
+ if (!rawassay) {
1874
+ return 'Assay "' + assayname + '" not found in cohort';
1875
+ }
1876
+ const config = rawassay.config;
1877
+ if (!config) {
1878
+ return '.config object missing for assay "' + assayname + '"';
1879
+ }
1880
+ delete rawassay.config;
1881
+ if (!config.type) {
1882
+ return '.config.type missing for assay "' + assayname + '"';
1883
+ }
1884
+ if (config.type.toLowerCase() == "vcf") {
1885
+ config.type = tkt.ds;
1886
+ config.isvcf = true;
1887
+ } else {
1888
+ if (!validtkt(config.type)) {
1889
+ return 'unknown .config.type "' + config.type + '" for assay "' + assayname + '"';
1890
+ }
1891
+ }
1892
+ config.id = (++assaynum).toString();
1893
+ if (!config.name) {
1894
+ config.name = assayname;
1895
+ }
1896
+ if (config.type == tkt.junction) {
1897
+ if (config.readcountcutoff) {
1898
+ if (!Number.isInteger(config.readcountcutoff) || config.readcountcutoff < 0) {
1899
+ return 'invalid .config.readcountcutoff for assay "' + assayname + '"';
1900
+ }
1901
+ }
1902
+ }
1903
+ cohort.assaylst.push(config);
1904
+ for (const pn in rawassay) {
1905
+ if (!cohort.p2st[pn]) {
1906
+ cohort.p2st[pn] = {};
1907
+ }
1908
+ for (const st in rawassay[pn]) {
1909
+ if (!cohort.p2st[pn][st]) {
1910
+ cohort.p2st[pn][st] = {
1911
+ tktemplate: []
1912
+ };
1913
+ }
1914
+ if (config.type == tkt.vafs1) {
1915
+ for (const name in rawassay[pn][st]) {
1916
+ const tk = rawassay[pn][st][name];
1917
+ if (!tk.file && !tk.url) {
1918
+ return "no file or URL for " + name + " vafs1 of " + pn + ", " + st;
1919
+ }
1920
+ tk.type = tkt.vafs1;
1921
+ tk.patient = pn;
1922
+ tk.sampletype = st;
1923
+ tk.assayname = assayname;
1924
+ tk.id = config.id;
1925
+ tk.tkid = Math.random().toString();
1926
+ if (!tk.name) {
1927
+ tk.name = name + " vaf";
1928
+ }
1929
+ cohort.p2st[pn][st].tktemplate.push(tk);
1930
+ }
1931
+ continue;
1932
+ }
1933
+ let rawtklst = [];
1934
+ if (Array.isArray(rawassay[pn][st])) {
1935
+ rawtklst = rawassay[pn][st];
1936
+ } else {
1937
+ rawtklst.push(rawassay[pn][st]);
1938
+ }
1939
+ for (const _tk of rawtklst) {
1940
+ let tk = _tk;
1941
+ if (!tk.file && !tk.url) {
1942
+ return "track has no file or url (sample: " + pn + ", assay: " + assayname + ")";
1943
+ }
1944
+ if (tk.name) {
1945
+ } else if (tk.partname) {
1946
+ tk.name = pn + (st == pn ? "" : " " + st) + " " + assayname + " " + tk.partname;
1947
+ } else {
1948
+ tk.name = pn + (st == pn ? "" : " " + st) + " " + assayname;
1949
+ }
1950
+ if (config.isvcf) {
1951
+ const [err2, tk2] = vcf2dstk({
1952
+ name: tk.name,
1953
+ file: tk.file,
1954
+ url: tk.url
1955
+ });
1956
+ if (err2) {
1957
+ return "VCF track error: " + err2;
1958
+ }
1959
+ tk = tk2;
1960
+ } else {
1961
+ if (tk.type) {
1962
+ if (!validtkt(tk.type)) {
1963
+ return 'invalid track type "' + tk.type + '" (sample: ' + pn + ", assay: " + assayname + ")";
1964
+ }
1965
+ } else {
1966
+ tk.type = config.type;
1967
+ }
1968
+ }
1969
+ tk.patient = pn;
1970
+ tk.sampletype = st;
1971
+ tk.assayname = assayname;
1972
+ tk.id = config.id;
1973
+ tk.tkid = Math.random().toString();
1974
+ cohort.p2st[pn][st].tktemplate.push(tk);
1975
+ switch (config.type) {
1976
+ case tkt.bigwig:
1977
+ const e = tidy_qtk(tk, config);
1978
+ if (e) {
1979
+ return "Assay " + assayname + ": " + config.type + " track error: " + e;
1980
+ }
1981
+ break;
1982
+ case tkt.junction:
1983
+ tk.categories = config.categories;
1984
+ tk.readcountcutoff = config.readcountcutoff;
1985
+ break;
1986
+ }
1987
+ }
1988
+ }
1989
+ }
1990
+ }
1991
+ delete cohort.assays;
1992
+ {
1993
+ const err2 = cohort2genometkset(cohort);
1994
+ if (err2) {
1995
+ return "Error: " + err2;
1996
+ }
1997
+ }
1998
+ if (cohort.patientannotation) {
1999
+ const err2 = parse_patientannotation(cohort);
2000
+ if (err2) return err2;
2001
+ }
2002
+ if (cohort.browserview) {
2003
+ const err2 = parse_browserview(cohort);
2004
+ if (err2) return err2;
2005
+ }
2006
+ if (cohort.e2pca) {
2007
+ if (!cohort.e2pca.list) return ".list missing from e2pca";
2008
+ if (!Array.isArray(cohort.e2pca.list)) return "e2pca.list should be an array";
2009
+ if (cohort.e2pca.list.length == 0) return "e2pca.list[] length 0";
2010
+ if (!cohort.e2pca.label) {
2011
+ cohort.e2pca.label = "Expression - PCA";
2012
+ }
2013
+ for (const obj of cohort.e2pca.list) {
2014
+ if (!obj.vectorfile) return "vectorfile missing from e2pca";
2015
+ if (!obj.dbfile) return "dbfile missing from e2pca";
2016
+ }
2017
+ }
2018
+ return;
2019
+ }
2020
+ function loadstudycohort(genomes, file, holder, hostURL, jwt, noshow, app) {
2021
+ const wait = holder.append("div").style("color", "#858585");
2022
+ wait.text("Loading " + file + " ...");
2023
+ return fetch(hostURL + "/study", {
2024
+ method: "POST",
2025
+ body: JSON.stringify({ file, jwt })
2026
+ }).then((res) => res.json()).then((data) => {
2027
+ if (!data) {
2028
+ wait.text("Server error!");
2029
+ return;
2030
+ }
2031
+ if (data.error) {
2032
+ wait.text("Error loading study: " + data.error);
2033
+ return;
2034
+ }
2035
+ const cohort = data.cohort;
2036
+ if (!cohort) {
2037
+ wait.text(".cohort missing");
2038
+ return;
2039
+ }
2040
+ if (!cohort.genome) {
2041
+ wait.text("No genome specified in the cohort JSON content");
2042
+ return;
2043
+ }
2044
+ const g = genomes[cohort.genome];
2045
+ if (!g) {
2046
+ wait.text("Invalid genome from cohort: " + cohort.genome);
2047
+ return;
2048
+ }
2049
+ cohort.genome = g;
2050
+ cohort.jwt = jwt;
2051
+ if (!data.flagset) {
2052
+ wait.text(".flagset missing");
2053
+ return;
2054
+ }
2055
+ wait.text("");
2056
+ cohort.dsset = {};
2057
+ for (const k in data.flagset) {
2058
+ const flag2 = data.flagset[k];
2059
+ flag2.genome = g;
2060
+ bulkin({
2061
+ flag: flag2,
2062
+ filename: file,
2063
+ cohort,
2064
+ err: (m) => sayerror(wait, m)
2065
+ });
2066
+ }
2067
+ const err2 = tpinit(cohort);
2068
+ if (err2) {
2069
+ sayerror(wait, err2);
2070
+ }
2071
+ if (!noshow) {
2072
+ return import("./tp.ui-S4YUVCZH.js").then(async (p) => {
2073
+ getsjcharts().catch(console.error);
2074
+ p.default(cohort, holder, hostURL, app);
2075
+ return app;
2076
+ });
2077
+ }
2078
+ });
2079
+ }
2080
+ function tidy_qtk(tk, config) {
2081
+ if (!config) {
2082
+ config = {};
2083
+ }
2084
+ if (!tk.file && !tk.url) {
2085
+ return "no file or url";
2086
+ }
2087
+ if (!tk.pcolor) {
2088
+ tk.pcolor = config.pcolor || "#0066CC";
2089
+ }
2090
+ if (!tk.pcolor2) {
2091
+ tk.pcolor2 = config.pcolor2 || "#CC0000";
2092
+ }
2093
+ if (!tk.ncolor) {
2094
+ tk.ncolor = config.ncolor || "#FF850A";
2095
+ }
2096
+ if (!tk.ncolor2) {
2097
+ tk.ncolor2 = config.ncolor2 || "#0A85FF";
2098
+ }
2099
+ if (!tk.height) {
2100
+ tk.height = config.height || 50;
2101
+ }
2102
+ const scale = {};
2103
+ if (config.scale) {
2104
+ for (const k in config.scale) {
2105
+ scale[k] = config.scale[k];
2106
+ }
2107
+ }
2108
+ if (tk.scale) {
2109
+ for (const k in tk.scale) {
2110
+ scale[k] = tk.scale[k];
2111
+ }
2112
+ }
2113
+ scale.auto = true;
2114
+ if (Number.isFinite(scale.min) && Number.isFinite(scale.max)) {
2115
+ delete scale.auto;
2116
+ } else if (Number.isFinite(scale.percentile)) {
2117
+ delete scale.auto;
2118
+ }
2119
+ tk.scale = scale;
2120
+ }
2121
+ function cohort2genometkset(cohort) {
2122
+ const lst = [];
2123
+ for (const pn in cohort.p2st) {
2124
+ for (const st in cohort.p2st[pn]) {
2125
+ const templates = cohort.p2st[pn][st].tktemplate;
2126
+ if (!templates) continue;
2127
+ for (const t of templates) {
2128
+ lst.push(t);
2129
+ }
2130
+ }
2131
+ }
2132
+ if (cohort.browserview && cohort.browserview.assays) {
2133
+ for (const assayname in cohort.browserview.assays) {
2134
+ const assayview = cohort.browserview.assays[assayname];
2135
+ if (assayview.combined && assayview.combinetk) {
2136
+ lst.push(assayview.combinetk);
2137
+ }
2138
+ }
2139
+ }
2140
+ if (!cohort.genome.tkset) {
2141
+ cohort.genome.tkset = [];
2142
+ }
2143
+ const thisset = {
2144
+ name: cohort.name,
2145
+ tklst: lst
2146
+ };
2147
+ if (cohort.trackfacets) {
2148
+ if (!Array.isArray(cohort.trackfacets)) {
2149
+ return ".trackfacets is not an array";
2150
+ }
2151
+ const lst2 = [];
2152
+ for (const fc of cohort.trackfacets) {
2153
+ if (!fc.samples) {
2154
+ return "trackfacets: .samples missing from facet " + fc.name;
2155
+ }
2156
+ if (!Array.isArray(fc.samples)) {
2157
+ return "trackfacets: .samples is not array from facet " + fc.name;
2158
+ }
2159
+ if (!fc.assays) {
2160
+ return "trackfacets: .assays missing from a facet " + fc.name;
2161
+ }
2162
+ if (!Array.isArray(fc.assays)) {
2163
+ return "trackfacets: .assays is not array from a facet " + fc.name;
2164
+ }
2165
+ lst2.push(fc);
2166
+ }
2167
+ if (lst2.length) {
2168
+ thisset.facetlst = lst2;
2169
+ }
2170
+ }
2171
+ cohort.genome.tkset.push(thisset);
2172
+ return null;
2173
+ }
2174
+ function parse_browserview(cohort) {
2175
+ if (cohort.browserview.position) {
2176
+ let pos;
2177
+ if (typeof cohort.browserview.position == "string") {
2178
+ pos = string2pos(cohort.browserview.position, cohort.genome);
2179
+ if (!pos) {
2180
+ return ".browserview.position invalid value";
2181
+ }
2182
+ } else {
2183
+ pos = cohort.browserview.position;
2184
+ }
2185
+ const e = invalidcoord(cohort.genome, pos.chr, pos.start, pos.stop);
2186
+ if (e) {
2187
+ return ".browserview.position error: " + e;
2188
+ }
2189
+ cohort.browserview.position = pos;
2190
+ } else {
2191
+ cohort.browserview.position = {
2192
+ chr: cohort.genome.defaultcoord.chr,
2193
+ start: cohort.genome.defaultcoord.start,
2194
+ stop: cohort.genome.defaultcoord.stop
2195
+ };
2196
+ }
2197
+ if (cohort.browserview.assays) {
2198
+ for (const assayname in cohort.browserview.assays) {
2199
+ if (typeof cohort.browserview.assays[assayname] != "object") {
2200
+ cohort.browserview.assays[assayname] = {};
2201
+ }
2202
+ const assayview = cohort.browserview.assays[assayname];
2203
+ for (const a of cohort.assaylst) {
2204
+ if (a.name == assayname) {
2205
+ assayview.assayobj = a;
2206
+ break;
2207
+ }
2208
+ }
2209
+ if (!assayview.assayobj) {
2210
+ console.log("missing assayobj for assayview of " + assayname);
2211
+ continue;
2212
+ }
2213
+ if (assayview.sum_view) {
2214
+ delete assayview.sum_view;
2215
+ assayview.combined = true;
2216
+ }
2217
+ if (assayview.combined) {
2218
+ const combinetk = {};
2219
+ for (const k in assayview.assayobj) {
2220
+ combinetk[k] = assayview.assayobj[k];
2221
+ }
2222
+ for (const k in assayview) {
2223
+ if (k == "assayobj") continue;
2224
+ combinetk[k] = assayview[k];
2225
+ }
2226
+ if (!combinetk.name) {
2227
+ combinetk.name = assayname;
2228
+ }
2229
+ combinetk.tracks = [];
2230
+ for (const pn in cohort.p2st) {
2231
+ for (const st in cohort.p2st[pn]) {
2232
+ for (const t of cohort.p2st[pn][st].tktemplate) {
2233
+ if (t.id == assayview.assayobj.id) {
2234
+ t.patient = pn;
2235
+ t.sampletype = st;
2236
+ combinetk.tracks.push(t);
2237
+ }
2238
+ }
2239
+ }
2240
+ }
2241
+ if (combinetk.isvcf) {
2242
+ combinetk.ds = {
2243
+ id2vcf: {},
2244
+ label: combinetk.name
2245
+ };
2246
+ for (const t of combinetk.tracks) {
2247
+ for (const i in t.ds.id2vcf) {
2248
+ t.__vcfobj = t.ds.id2vcf[i];
2249
+ }
2250
+ combinetk.ds.id2vcf[t.__vcfobj.vcfid] = t.__vcfobj;
2251
+ }
2252
+ }
2253
+ assayview.combinetk = combinetk;
2254
+ }
2255
+ }
2256
+ }
2257
+ if (cohort.browserview.defaultassaytracks) {
2258
+ if (!Array.isArray(cohort.browserview.defaultassaytracks)) return ".browserview.defaultassaytracks must be array";
2259
+ for (let i = 0; i < cohort.browserview.defaultassaytracks.length; i++) {
2260
+ const t = cohort.browserview.defaultassaytracks[i];
2261
+ if (!t.assay) return ".assay missing from .defaultassaytracks #" + (i + 1);
2262
+ if (!cohort[t.assay]) return "unknown assay name from .defaultassaytracks #" + (i + 1) + ": " + t.assay;
2263
+ if (!t.level1) return ".level1 missing from .defaultassaytracks #" + (i + 1);
2264
+ if (!cohort[t.assay][t.level1])
2265
+ return "level1 not exist in assay from .defaultassaytracks #" + (i + 1) + ": " + t.level1;
2266
+ if (t.level2) {
2267
+ if (!cohort[t.assay][t.level1][t.level2])
2268
+ return "level2 not exist in assay from .defaultassaytracks #" + (i + 1) + ": " + t.level2;
2269
+ }
2270
+ }
2271
+ }
2272
+ return null;
2273
+ }
2274
+ function parse_patientannotation(cohort) {
2275
+ if (!cohort.patientannotation.annotation) {
2276
+ return ".patientannotation.annotation missing";
2277
+ }
2278
+ if (!cohort.patientannotation.metadata) {
2279
+ return ".patientannotation.metadata missing";
2280
+ }
2281
+ if (!Array.isArray(cohort.patientannotation.metadata)) {
2282
+ return ".patientannotation.metadata should be an array";
2283
+ }
2284
+ const mdh = {};
2285
+ for (const md of cohort.patientannotation.metadata) {
2286
+ if (md.key == void 0) {
2287
+ return "patientannotation: key missing for a metadata term";
2288
+ }
2289
+ if (!md.values) {
2290
+ return "patientannotation: values missing for metadata term " + md.key;
2291
+ }
2292
+ if (!Array.isArray(md.values)) {
2293
+ return "patientannotation: .values not an array for metadata term " + md.key;
2294
+ }
2295
+ if (!md.label) {
2296
+ md.label = md.key;
2297
+ }
2298
+ mdh[md.key] = {
2299
+ label: md.label,
2300
+ values: {}
2301
+ };
2302
+ const colorfunc = ordinal(category10_default);
2303
+ for (const at of md.values) {
2304
+ if (at.key == void 0) {
2305
+ return "key missing for an attribute of term " + md.key;
2306
+ }
2307
+ if (!at.label) {
2308
+ at.label = at.key;
2309
+ }
2310
+ if (!at.color) {
2311
+ at.color = colorfunc(at.key);
2312
+ }
2313
+ mdh[md.key].values[at.key] = at;
2314
+ }
2315
+ }
2316
+ cohort.patientannotation.mdh = mdh;
2317
+ return null;
2318
+ }
2319
+
2320
+ export {
2321
+ loadstudycohort,
2322
+ bulkui,
2323
+ content2flag,
2324
+ bulkin,
2325
+ bulkembed
2326
+ };
2327
+ //# sourceMappingURL=chunk-H6HP4H3U.js.map