@sjcrh/proteinpaint-client 2.181.0 → 2.182.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (950) hide show
  1. package/dist/2dmaf-SLBAWGPG.js +1371 -0
  2. package/dist/AIProjectAdmin-6SH5X3AF.js +830 -0
  3. package/dist/AppHeader-MVYNRMC7.js +833 -0
  4. package/dist/BoxPlot-HLGWW3IK.js +1295 -0
  5. package/dist/CorrelationVolcano-TZCYC3NI.js +617 -0
  6. package/dist/DE-2J2SK5UT.js +93 -0
  7. package/dist/DE-2J2SK5UT.js.map +7 -0
  8. package/dist/DEinput-QM3GOQHM.js +297 -0
  9. package/dist/DEinput-QM3GOQHM.js.map +7 -0
  10. package/dist/DifferentialAnalysis-DS7CQOT6.js +238 -0
  11. package/dist/Disco-U5I6NJUT.js +3199 -0
  12. package/dist/Disco.UI-J2B7GGEZ.js +242 -0
  13. package/dist/DmrPlot-D5W76QPY.js +640 -0
  14. package/dist/GB-LM5SGUG4.js +1125 -0
  15. package/dist/HicApp-YNBGAGKM.js +2248 -0
  16. package/dist/NumBinaryEditor-4QA5DQJT.js +268 -0
  17. package/dist/NumBinaryEditor-4QA5DQJT.js.map +7 -0
  18. package/dist/NumBinaryEditor.unit.spec-YWSIFTOJ.js +284 -0
  19. package/dist/NumContEditor-ZPLVZFLH.js +105 -0
  20. package/dist/NumContEditor.unit.spec-NBCFOCOX.js +167 -0
  21. package/dist/NumCustomBinEditor-TXEYRVPL.js +36 -0
  22. package/dist/NumCustomBinEditor.unit.spec-SQM63H4B.js +282 -0
  23. package/dist/NumDiscreteEditor-6C4OWX62.js +177 -0
  24. package/dist/NumDiscreteEditor-6C4OWX62.js.map +7 -0
  25. package/dist/NumDiscreteEditor.unit.spec-4HC4AGAM.js +200 -0
  26. package/dist/NumRegularBinEditor-VQAS3OXK.js +36 -0
  27. package/dist/NumRegularBinEditor.unit.spec-RGVEPB3Z.js +225 -0
  28. package/dist/NumSplineEditor-SXOJICHU.js +190 -0
  29. package/dist/NumSplineEditor-SXOJICHU.js.map +7 -0
  30. package/dist/NumSplineEditor.unit.spec-HF5E6ANH.js +197 -0
  31. package/dist/NumericDensity-LMLPMOSE.js +36 -0
  32. package/dist/NumericDensity.unit.spec-3ZI5EVON.js +219 -0
  33. package/dist/NumericHandler-Q6F6ANOS.js +37 -0
  34. package/dist/NumericHandler.unit.spec-E6Z5HUNZ.js +217 -0
  35. package/dist/RunChart2-XSNWNAIL.js +756 -0
  36. package/dist/SC-RA46YM57.js +733 -0
  37. package/dist/Volcano-75UDYPVB.js +1187 -0
  38. package/dist/WSIViewer-GYUUXCSJ.js +47933 -0
  39. package/dist/WsiSamplesPlot-KMI5S2EL.js +163 -0
  40. package/dist/adSandbox-JTK5XEQL.js +36 -0
  41. package/dist/alphaGenome-JRAV6WIY.js +173 -0
  42. package/dist/app-JKDZL23V.js +35 -0
  43. package/dist/app-OEARXM6E.js +47 -0
  44. package/dist/app.js +20 -20
  45. package/dist/bam-CYEPLBK4.js +857 -0
  46. package/dist/bam-CYEPLBK4.js.map +7 -0
  47. package/dist/barchart-GG5UFDG4.js +45 -0
  48. package/dist/barchart.data-KXA66FAL.js +22 -0
  49. package/dist/barchart.events-P2USOIR7.js +45 -0
  50. package/dist/barchart.integration.spec-5QSPQQLJ.js +1675 -0
  51. package/dist/block-6DVPQBSH.js +6200 -0
  52. package/dist/block-6DVPQBSH.js.map +7 -0
  53. package/dist/block.init-ZHX6DFWF.js +36 -0
  54. package/dist/block.mds.expressionrank-YMGYXXYT.js +357 -0
  55. package/dist/block.mds.geneboxplot-IAILQYX4.js +826 -0
  56. package/dist/block.mds.junction-BRNFNQMU.js +1543 -0
  57. package/dist/block.mds.svcnv-OHKC7YPO.js +6799 -0
  58. package/dist/block.svg-PNGK45HW.js +162 -0
  59. package/dist/block.tk.aicheck-SCIOJ4WN.js +281 -0
  60. package/dist/block.tk.ase-BABJ73GG.js +363 -0
  61. package/dist/block.tk.bam-LZWJ5BCQ.js +1904 -0
  62. package/dist/block.tk.bedgraphdot-7NQLC3XJ.js +382 -0
  63. package/dist/block.tk.bigwig.ui-VNY4SFD5.js +209 -0
  64. package/dist/block.tk.hicstraw-36A7VDRM.js +821 -0
  65. package/dist/block.tk.junction-D373YEMK.js +2362 -0
  66. package/dist/block.tk.junction.textmatrixui-FFII7J3X.js +197 -0
  67. package/dist/block.tk.ld-XGB6KMDO.js +97 -0
  68. package/dist/block.tk.menu-PEZANZBZ.js +1027 -0
  69. package/dist/block.tk.pgv-MU5BPTT2.js +942 -0
  70. package/dist/brainImaging-LVJON47N.js +421 -0
  71. package/dist/chat-5FDIAQJ4.js +148 -0
  72. package/dist/chunk-22NJUYET.js +281 -0
  73. package/dist/chunk-22NJUYET.js.map +7 -0
  74. package/dist/chunk-2J3566TA.js +215 -0
  75. package/dist/chunk-2J3566TA.js.map +7 -0
  76. package/dist/chunk-2OSEZCWZ.js +205 -0
  77. package/dist/chunk-5OHXYXLD.js +46 -0
  78. package/dist/chunk-5OHXYXLD.js.map +7 -0
  79. package/dist/chunk-6MSCYO7K.js +119 -0
  80. package/dist/chunk-7A7NMCQ3.js +534 -0
  81. package/dist/chunk-7FEHI46K.js +20456 -0
  82. package/dist/chunk-7FEHI46K.js.map +7 -0
  83. package/dist/chunk-AETE4F7R.js +252 -0
  84. package/dist/chunk-AZYDW5T7.js +441 -0
  85. package/dist/chunk-B6HCIAM3.js +34 -0
  86. package/dist/chunk-BEWDIM6H.js +42 -0
  87. package/dist/chunk-BEWDIM6H.js.map +7 -0
  88. package/dist/chunk-CCIZJAXB.js +2815 -0
  89. package/dist/chunk-DHZL3FBC.js +107 -0
  90. package/dist/chunk-DONWY7TP.js +39 -0
  91. package/dist/chunk-DVDDXOWT.js +815 -0
  92. package/dist/chunk-E6DRQJJT.js +480 -0
  93. package/dist/chunk-ESKU6LNC.js +36 -0
  94. package/dist/chunk-F6V4AYWP.js +177 -0
  95. package/dist/chunk-FBAJTPBU.js +302 -0
  96. package/dist/chunk-FGMPKWT5.js +371 -0
  97. package/dist/chunk-FK4MYVW2.js +261 -0
  98. package/dist/chunk-FMBJ4SKC.js +98 -0
  99. package/dist/chunk-FOEZG4VX.js +505 -0
  100. package/dist/chunk-FOEZG4VX.js.map +7 -0
  101. package/dist/chunk-FQRLSKJC.js +226 -0
  102. package/dist/chunk-G6ELKVBG.js +629 -0
  103. package/dist/chunk-GKK3CZ6H.js +4207 -0
  104. package/dist/chunk-GKK3CZ6H.js.map +7 -0
  105. package/dist/chunk-GO5SIPFE.js +194 -0
  106. package/dist/chunk-GPOECA3V.js +386 -0
  107. package/dist/chunk-GTOY3JJO.js +288 -0
  108. package/dist/chunk-GTOY3JJO.js.map +7 -0
  109. package/dist/chunk-GW7DHJYH.js +439 -0
  110. package/dist/chunk-H2D7EVUA.js +158 -0
  111. package/dist/chunk-H2D7EVUA.js.map +7 -0
  112. package/dist/chunk-H2K5KZP7.js +95 -0
  113. package/dist/chunk-H5XFH3FV.js +153 -0
  114. package/dist/chunk-HAMDFQIX.js +228 -0
  115. package/dist/chunk-HH4QLSTK.js +4952 -0
  116. package/dist/chunk-IBTPGSYI.js +526 -0
  117. package/dist/chunk-IGEQI6MR.js +1561 -0
  118. package/dist/chunk-IGEQI6MR.js.map +7 -0
  119. package/dist/chunk-IIRU6VK2.js +2672 -0
  120. package/dist/chunk-ILF2GKBY.js +1205 -0
  121. package/dist/chunk-ILF2GKBY.js.map +7 -0
  122. package/dist/chunk-IP4T477W.js +92 -0
  123. package/dist/chunk-IQIXGTQV.js +84 -0
  124. package/dist/chunk-IQIXGTQV.js.map +7 -0
  125. package/dist/chunk-IXT4U5CE.js +91 -0
  126. package/dist/chunk-IXT4U5CE.js.map +7 -0
  127. package/dist/chunk-JHOGX5VE.js +272 -0
  128. package/dist/chunk-JOXUBWN3.js +381 -0
  129. package/dist/chunk-K57RR3FD.js +142 -0
  130. package/dist/chunk-K6JLCMVL.js +129 -0
  131. package/dist/chunk-KSFSM46X.js +100 -0
  132. package/dist/chunk-KVG7FTTK.js +470 -0
  133. package/dist/chunk-LEDPPLQK.js +158 -0
  134. package/dist/chunk-LUTT3MBZ.js +1150 -0
  135. package/dist/chunk-MDL2HG3N.js +257 -0
  136. package/dist/chunk-MDL2HG3N.js.map +7 -0
  137. package/dist/chunk-MNRYCG2S.js +1271 -0
  138. package/dist/chunk-MNRYCG2S.js.map +7 -0
  139. package/dist/chunk-MPJHDHBA.js +2784 -0
  140. package/dist/chunk-MXI3NXRB.js +407 -0
  141. package/dist/chunk-MXI3NXRB.js.map +7 -0
  142. package/dist/chunk-O4PXELXF.js +615 -0
  143. package/dist/chunk-ORPCSG6T.js +14 -0
  144. package/dist/chunk-OUKDZKSZ.js +334 -0
  145. package/dist/chunk-P5HLYAHP.js +1087 -0
  146. package/dist/chunk-PIACSJPH.js +148 -0
  147. package/dist/chunk-PQABAAEZ.js +31 -0
  148. package/dist/chunk-PSMDCZET.js +46 -0
  149. package/dist/chunk-RFIVPTMS.js +217 -0
  150. package/dist/chunk-RSU37SVQ.js +54 -0
  151. package/dist/chunk-RTC4U4PH.js +2327 -0
  152. package/dist/chunk-RTC4U4PH.js.map +7 -0
  153. package/dist/chunk-RZ5JP44H.js +276 -0
  154. package/dist/chunk-RZ5JP44H.js.map +7 -0
  155. package/dist/chunk-SPAIFVM2.js +1155 -0
  156. package/dist/chunk-T2HYA2KL.js +55 -0
  157. package/dist/chunk-TCPU43TU.js +1741 -0
  158. package/dist/chunk-TCPU43TU.js.map +7 -0
  159. package/dist/chunk-TE3DK3A6.js +147 -0
  160. package/dist/chunk-TIQPSXFJ.js +237 -0
  161. package/dist/chunk-TN5GSG34.js +26 -0
  162. package/dist/chunk-UBGTQMOO.js +52 -0
  163. package/dist/chunk-UE5ZYM63.js +48 -0
  164. package/dist/chunk-UQACPOCM.js +102 -0
  165. package/dist/chunk-UR3C4SCH.js +446 -0
  166. package/dist/chunk-UWX7W22M.js +121 -0
  167. package/dist/chunk-VJ37HKM6.js +368 -0
  168. package/dist/chunk-VJ37HKM6.js.map +7 -0
  169. package/dist/chunk-VLTDUJRM.js +293 -0
  170. package/dist/chunk-W6UUEAEP.js +6364 -0
  171. package/dist/chunk-X6UPDFDX.js +229 -0
  172. package/dist/chunk-X6UPDFDX.js.map +7 -0
  173. package/dist/chunk-XD6BFNMR.js +172 -0
  174. package/dist/chunk-XD6BFNMR.js.map +7 -0
  175. package/dist/chunk-XOBD3EAM.js +1425 -0
  176. package/dist/chunk-XOBD3EAM.js.map +7 -0
  177. package/dist/chunk-Y3TDC7NU.js +170 -0
  178. package/dist/chunk-YOTWMCT5.js +824 -0
  179. package/dist/chunk-YUMPQ3CJ.js +203 -0
  180. package/dist/chunk-ZIBWLDQI.js +230 -0
  181. package/dist/chunk-ZIBWLDQI.js.map +7 -0
  182. package/dist/condition-VHP2L4GM.js +330 -0
  183. package/dist/controls-N5Q7U7JR.js +39 -0
  184. package/dist/controls.config-NJMW4SLR.js +37 -0
  185. package/dist/correlation-3LDASF5I.js +96 -0
  186. package/dist/cuminc-UWJ23W6C.js +1147 -0
  187. package/dist/cuminc.integration.spec-OZYYET3W.js +676 -0
  188. package/dist/customdata.inputui-2FVCVSE4.js +285 -0
  189. package/dist/dataDownload-4S4PE5HX.js +328 -0
  190. package/dist/dataDownload.integration.spec-B57LEKFZ.js +191 -0
  191. package/dist/databrowser.ui-N6GHEQ2P.js +419 -0
  192. package/dist/dictionary-UP46QRYZ.js +98 -0
  193. package/dist/dnaMethylation-BOGAUAWA.js +36 -0
  194. package/dist/dnaMethylation.integration.spec-UAHBJSSJ.js +179 -0
  195. package/dist/e2pca-L5EBQJNP.js +348 -0
  196. package/dist/ep-Z67ORKUX.js +1254 -0
  197. package/dist/expclust.gdc.spec-SP7VOL64.js +305 -0
  198. package/dist/facet-HDB4VDGU.js +519 -0
  199. package/dist/geneExpClustering-6ZPOLTDJ.js +246 -0
  200. package/dist/geneExpression-T6YIG4XQ.js +312 -0
  201. package/dist/geneExpression-T7QUHV5S.js +36 -0
  202. package/dist/geneExpression.unit.spec-DO52L5IB.js +100 -0
  203. package/dist/geneORA-KOUDUWUO.js +276 -0
  204. package/dist/geneVariant-FVR76F6I.js +39 -0
  205. package/dist/geneVariant-I5QUITKG.js +37 -0
  206. package/dist/geneVariant.integration.spec-D4IRM7B5.js +196 -0
  207. package/dist/genefusion.ui-35IYSZD7.js +249 -0
  208. package/dist/geneset-7ZHJ5KWK.js +194 -0
  209. package/dist/genomeBrowser.spec-VXASVLNH.js +279 -0
  210. package/dist/grin2-7NM56COO.js +1554 -0
  211. package/dist/grin2-IY26UUQI.js +1031 -0
  212. package/dist/gsea-TORO46C6.js +45 -0
  213. package/dist/hierCluster-3BKEGW6P.js +58 -0
  214. package/dist/hierCluster-HM3LOM6V.js +62 -0
  215. package/dist/hierCluster.config-LDO5IGQ5.js +38 -0
  216. package/dist/hierCluster.integration.spec-XO5R6CQT.js +374 -0
  217. package/dist/hierCluster.interactivity-NVQ6262K.js +52 -0
  218. package/dist/hierCluster.renderers-SWPPNBLU.js +21 -0
  219. package/dist/imagePlot-V4WLAPV6.js +139 -0
  220. package/dist/importPlot-NZKQEOX4.js +8 -0
  221. package/dist/isoformExpression-TIZBIGNL.js +38 -0
  222. package/dist/isoformExpression.unit.spec-WHH5LPFG.js +124 -0
  223. package/dist/isoformExpression.unit.spec-WHH5LPFG.js.map +7 -0
  224. package/dist/launch.adhoc-JYEN42NM.js +40 -0
  225. package/dist/leftlabel.sample-43DL3J3H.js +257 -0
  226. package/dist/legacyDataset-QRSNRVUA.js +119 -0
  227. package/dist/lollipop-NMWZ4FVF.js +166 -0
  228. package/dist/maf-DS3EOVGV.js +450 -0
  229. package/dist/maf-DS3EOVGV.js.map +7 -0
  230. package/dist/maftimeline-ZB2753S7.js +591 -0
  231. package/dist/matrix-RCGQWQ3C.js +57 -0
  232. package/dist/matrix-WTTEK4FT.js +62 -0
  233. package/dist/matrix.cells-UO5ASQ35.js +28 -0
  234. package/dist/matrix.config-3UQAT3QR.js +39 -0
  235. package/dist/matrix.controls-PRZ77K5L.js +37 -0
  236. package/dist/matrix.data-4W73RQ3H.js +25 -0
  237. package/dist/matrix.groups-5VMPI7SA.js +26 -0
  238. package/dist/matrix.integration.spec-2F5LDLC2.js +3070 -0
  239. package/dist/matrix.interactivity-MIPZ6ELV.js +40 -0
  240. package/dist/matrix.layout-EO5LVYRO.js +42 -0
  241. package/dist/matrix.legend-QBFBFEUG.js +22 -0
  242. package/dist/matrix.renderers-ERJXVCQL.js +36 -0
  243. package/dist/matrix.serieses-E23EPXHA.js +21 -0
  244. package/dist/matrix.sort-I4UGMEXR.js +27 -0
  245. package/dist/matrix.sort.unit.spec-CRGF6CSE.js +470 -0
  246. package/dist/matrix.sorterUi-YLSYTYLE.js +18 -0
  247. package/dist/matrix.sorterUi.unit.spec-ENG3ICOO.js +340 -0
  248. package/dist/mavb-5WR7OJHI.js +730 -0
  249. package/dist/mds.fimo-3ZRH7BBJ.js +516 -0
  250. package/dist/mds.samplescatterplot-RPXR2FVK.js +1548 -0
  251. package/dist/mds.survivalplot-WSSMYUZD.js +481 -0
  252. package/dist/oncomatrix-JKYPUJQR.js +293 -0
  253. package/dist/oncomatrix-JKYPUJQR.js.map +7 -0
  254. package/dist/oncomatrix.spec-OEGU4DYK.js +446 -0
  255. package/dist/plot.2dvaf-ZGARLQNK.js +375 -0
  256. package/dist/plot.app-TKUJH3LK.js +39 -0
  257. package/dist/plot.barplot-FEIPGDZ2.js +100 -0
  258. package/dist/plot.boxplot-6RASUMZB.js +150 -0
  259. package/dist/plot.brainImaging-ZJPFWX2W.js +51 -0
  260. package/dist/plot.disco-2KTKB3XX.js +101 -0
  261. package/dist/plot.dzi-PC34YI6Y.js +33 -0
  262. package/dist/plot.ssgq-Z4UNJKWO.js +137 -0
  263. package/dist/plot.vaf2cov-NZ4WULKT.js +257 -0
  264. package/dist/plot.wsi-YYXFAZWY.js +36 -0
  265. package/dist/polar-X2GPIBLB.js +184 -0
  266. package/dist/polar2-TZ553QQH.js +226 -0
  267. package/dist/profile.spec-VB6VMFLY.js +78 -0
  268. package/dist/profileBarchart-SKJSTC7B.js +265 -0
  269. package/dist/profileForms-RLOGSMAQ.js +438 -0
  270. package/dist/profilePlot-267ZS3RG.js +52 -0
  271. package/dist/profileRadar-KGOBHCSF.js +261 -0
  272. package/dist/profileRadarFacility-MCJKSHUM.js +261 -0
  273. package/dist/proteomeAbundance-JUYAYO5I.js +63 -0
  274. package/dist/proteomeAbundance-PGHZSVAF.js +19 -0
  275. package/dist/qualitative-3IECKKJM.js +41 -0
  276. package/dist/regression-J6FFRPXN.js +54 -0
  277. package/dist/regression.inputs-T7LWBSYZ.js +46 -0
  278. package/dist/regression.inputs.term-TT7PNX6G.js +46 -0
  279. package/dist/regression.inputs.values.table-SHFUNKCS.js +43 -0
  280. package/dist/regression.integration.spec-QKHMJTHA.js +784 -0
  281. package/dist/regression.results-D4WX6VIV.js +38 -0
  282. package/dist/regression.spec-7SW55L7X.js +706 -0
  283. package/dist/report-QYOZ4BRF.js +220 -0
  284. package/dist/sampleScatter.spec-JCHFMGNF.js +200 -0
  285. package/dist/sampleView-7RPKNAZC.js +46 -0
  286. package/dist/samplelst-4WNPHZVG.js +109 -0
  287. package/dist/samplematrix-CG52DSXJ.js +2196 -0
  288. package/dist/sc-OJSWILSA.js +84 -0
  289. package/dist/scatter-LG2RMMEC.js +800 -0
  290. package/dist/scatter.integration.spec-QPANYTKW.js +1194 -0
  291. package/dist/selectGenomeWithTklst-QXRVE6N4.js +132 -0
  292. package/dist/singleCellCellType-XBSRL33U.js +36 -0
  293. package/dist/singleCellCellType.unit.spec-YZX4CSXA.js +177 -0
  294. package/dist/singleCellGeneExpression-64ECP62X.js +36 -0
  295. package/dist/singleCellGeneExpression.unit.spec-CFHFXMA6.js +163 -0
  296. package/dist/singleCellPlot-E5F62JY6.js +51 -0
  297. package/dist/singlecell-FCY5EOUV.js +84 -0
  298. package/dist/singlecell-S7B5V7NK.js +1570 -0
  299. package/dist/snp-ACKX4GRX.js +36 -0
  300. package/dist/snp.unit.spec-QBGHKKUD.js +174 -0
  301. package/dist/snplocus-7EUOW7J7.js +206 -0
  302. package/dist/spliceevent.a53ss.diagram-ALQZA35Z.js +149 -0
  303. package/dist/spliceevent.exonskip.diagram-UF7WJA5R.js +275 -0
  304. package/dist/spliceevent.noeventdiagram-4HPGRNRR.js +458 -0
  305. package/dist/ssGSEA-FDRBBBLJ.js +36 -0
  306. package/dist/ssGSEA.unit.spec-EZEOWJVV.js +86 -0
  307. package/dist/summarizeCnvGeneexp-FTL2MGAJ.js +158 -0
  308. package/dist/summarizeGeneexpSurvival-DDIF4UW6.js +105 -0
  309. package/dist/summarizeMutationCnv-L3GL5YDY.js +159 -0
  310. package/dist/summarizeMutationDiagnosis-LALOJTHV.js +38 -0
  311. package/dist/summarizeMutationSurvival-TSNTSOBZ.js +97 -0
  312. package/dist/summary-YRHVS64T.js +47 -0
  313. package/dist/summary.integration.spec-766YQLQA.js +412 -0
  314. package/dist/summaryInput-VQ2X6GSX.js +218 -0
  315. package/dist/sunburst-XFOONS6K.js +282 -0
  316. package/dist/survival-FQXZH2MM.js +44 -0
  317. package/dist/survival-TVA3ZWVP.js +56 -0
  318. package/dist/survival.integration.spec-WFIOPD6A.js +787 -0
  319. package/dist/svgraph-4BFBO7EL.js +1385 -0
  320. package/dist/svmr-ML7GAIIA.js +3840 -0
  321. package/dist/table-SMLMUWPP.js +198 -0
  322. package/dist/termCollection-22CPTISZ.js +36 -0
  323. package/dist/termCollection-EE6AOIVA.js +177 -0
  324. package/dist/termCollection.unit.spec-4DIW3CJ3.js +206 -0
  325. package/dist/tk-ITZCKOQ5.js +44 -0
  326. package/dist/tp.ui-R6HVKCBC.js +1457 -0
  327. package/dist/tvs.density-AQ5GD437.js +18 -0
  328. package/dist/tvs.dt-2263TBEJ.js +37 -0
  329. package/dist/tvs.dtcnv.categorical-TRRHL33N.js +38 -0
  330. package/dist/tvs.dtcnv.continuous-GREYNF52.js +70 -0
  331. package/dist/tvs.dtfusion-XOX46L3M.js +38 -0
  332. package/dist/tvs.dtsnvindel-IDMXT53F.js +38 -0
  333. package/dist/tvs.dtsv-ZDWFYH2C.js +38 -0
  334. package/dist/tvs.numeric-ZN2R7BH3.js +21 -0
  335. package/dist/tvs.samplelst-GAP76HRH.js +102 -0
  336. package/dist/tvs.termCollection-GQ65UKSI.js +151 -0
  337. package/dist/violin-JGDL62YA.js +44 -0
  338. package/dist/violin.integration.spec-W4NN7LBY.js +1417 -0
  339. package/dist/violin.interactivity-H4RP4K5U.js +36 -0
  340. package/dist/violin.renderer-QPHLACDC.js +38 -0
  341. package/dist/vocabulary-7JACY4J2.js +39 -0
  342. package/package.json +2 -2
  343. package/dist/2dmaf-PFPBHIUI.js +0 -1371
  344. package/dist/AIProjectAdmin-H2GB5ZOX.js +0 -830
  345. package/dist/AppHeader-FCWML6WH.js +0 -833
  346. package/dist/BoxPlot-QKXGF76K.js +0 -1295
  347. package/dist/CorrelationVolcano-ZJ7Q6JBC.js +0 -617
  348. package/dist/DifferentialAnalysis-PWCFCWFY.js +0 -238
  349. package/dist/Disco-IE5JKIF2.js +0 -3199
  350. package/dist/Disco.UI-SR7LSJE3.js +0 -242
  351. package/dist/DmrPlot-UDY7GOSY.js +0 -640
  352. package/dist/GB-GNTOP5C6.js +0 -1125
  353. package/dist/HicApp-FZTJL3OA.js +0 -2248
  354. package/dist/NumBinaryEditor-R5QVG3C4.js +0 -266
  355. package/dist/NumBinaryEditor-R5QVG3C4.js.map +0 -7
  356. package/dist/NumBinaryEditor.unit.spec-BMVRI24W.js +0 -284
  357. package/dist/NumContEditor-6JT5D6IW.js +0 -105
  358. package/dist/NumContEditor.unit.spec-XBQF2SW6.js +0 -167
  359. package/dist/NumCustomBinEditor-MEKEFOQI.js +0 -36
  360. package/dist/NumCustomBinEditor.unit.spec-LEMQJHDT.js +0 -282
  361. package/dist/NumDiscreteEditor-U3N37XRQ.js +0 -170
  362. package/dist/NumDiscreteEditor-U3N37XRQ.js.map +0 -7
  363. package/dist/NumDiscreteEditor.unit.spec-WQM4DLKO.js +0 -200
  364. package/dist/NumRegularBinEditor-HQR5Y6P7.js +0 -36
  365. package/dist/NumRegularBinEditor.unit.spec-FL4IFT7L.js +0 -225
  366. package/dist/NumSplineEditor-OESWMWP5.js +0 -188
  367. package/dist/NumSplineEditor-OESWMWP5.js.map +0 -7
  368. package/dist/NumSplineEditor.unit.spec-HYOXO45B.js +0 -197
  369. package/dist/NumericDensity-GJZ4BBJS.js +0 -36
  370. package/dist/NumericDensity.unit.spec-6LXWAXW7.js +0 -219
  371. package/dist/NumericHandler-LZIMPOHS.js +0 -37
  372. package/dist/NumericHandler.unit.spec-ZSU35AMD.js +0 -217
  373. package/dist/RunChart2-7XV6TIFO.js +0 -756
  374. package/dist/SC-E4EYAG26.js +0 -733
  375. package/dist/Volcano-Z7TJK6PW.js +0 -1187
  376. package/dist/WSIViewer-ZH2XABLC.js +0 -47933
  377. package/dist/WsiSamplesPlot-BL47MDHQ.js +0 -163
  378. package/dist/adSandbox-V3NTKVBC.js +0 -36
  379. package/dist/alphaGenome-IQVFCSWQ.js +0 -173
  380. package/dist/app-GJLZ2G2U.js +0 -47
  381. package/dist/app-YSD2U64Q.js +0 -35
  382. package/dist/bam-TRIF3AIQ.js +0 -849
  383. package/dist/bam-TRIF3AIQ.js.map +0 -7
  384. package/dist/barchart-GLLUYTAJ.js +0 -45
  385. package/dist/barchart.data-FRYRGKH3.js +0 -22
  386. package/dist/barchart.events-WODVSHRN.js +0 -45
  387. package/dist/barchart.integration.spec-6POS3V3T.js +0 -1675
  388. package/dist/block-2QM37YSE.js +0 -6300
  389. package/dist/block-2QM37YSE.js.map +0 -7
  390. package/dist/block.init-7HDLKQVX.js +0 -36
  391. package/dist/block.mds.expressionrank-UIB25S6E.js +0 -357
  392. package/dist/block.mds.geneboxplot-4PQYO3MR.js +0 -826
  393. package/dist/block.mds.junction-DWFYZEC2.js +0 -1543
  394. package/dist/block.mds.svcnv-N3KJJ4GQ.js +0 -6799
  395. package/dist/block.svg-2HBDI7BT.js +0 -162
  396. package/dist/block.tk.aicheck-2M4522IQ.js +0 -281
  397. package/dist/block.tk.ase-URIKF6JD.js +0 -363
  398. package/dist/block.tk.bam-HTDMASHX.js +0 -1904
  399. package/dist/block.tk.bedgraphdot-RVKMSFCQ.js +0 -382
  400. package/dist/block.tk.bigwig.ui-7JPEOIKM.js +0 -209
  401. package/dist/block.tk.hicstraw-72J7UJ2J.js +0 -821
  402. package/dist/block.tk.junction-GGFMBCV5.js +0 -2362
  403. package/dist/block.tk.junction.textmatrixui-44SAYYWE.js +0 -197
  404. package/dist/block.tk.ld-XDKJFEOL.js +0 -97
  405. package/dist/block.tk.menu-46FOTM7H.js +0 -1027
  406. package/dist/block.tk.pgv-ZVONRT4B.js +0 -942
  407. package/dist/brainImaging-CSLO7ODJ.js +0 -421
  408. package/dist/chat-GMD22F3K.js +0 -148
  409. package/dist/chunk-22KWZOCN.js +0 -153
  410. package/dist/chunk-2K5DSRBJ.js +0 -84
  411. package/dist/chunk-2K5DSRBJ.js.map +0 -7
  412. package/dist/chunk-2NQ4TM74.js +0 -48
  413. package/dist/chunk-2TIYJ3PH.js +0 -815
  414. package/dist/chunk-2UWHV2SB.js +0 -261
  415. package/dist/chunk-2UWHV2SB.js.map +0 -7
  416. package/dist/chunk-3656ZY4T.js +0 -237
  417. package/dist/chunk-3TU6TRLQ.js +0 -98
  418. package/dist/chunk-4FJ5GS6P.js +0 -4202
  419. package/dist/chunk-4FJ5GS6P.js.map +0 -7
  420. package/dist/chunk-4FO7KZY2.js +0 -534
  421. package/dist/chunk-4OEOQX4L.js +0 -334
  422. package/dist/chunk-5HCB4HNL.js +0 -147
  423. package/dist/chunk-5ZICCKEH.js +0 -4952
  424. package/dist/chunk-6UU7VPDO.js +0 -272
  425. package/dist/chunk-6YLQN7FF.js +0 -441
  426. package/dist/chunk-74QJDBIP.js +0 -480
  427. package/dist/chunk-7FXPMQRW.js +0 -34
  428. package/dist/chunk-A2Y3GEUH.js +0 -228
  429. package/dist/chunk-AAEXTQT3.js +0 -330
  430. package/dist/chunk-AAEXTQT3.js.map +0 -7
  431. package/dist/chunk-AG6HVFQY.js +0 -504
  432. package/dist/chunk-AG6HVFQY.js.map +0 -7
  433. package/dist/chunk-AHLUW2BN.js +0 -129
  434. package/dist/chunk-AQ4OP4GR.js +0 -39
  435. package/dist/chunk-AYDXOUFX.js +0 -1275
  436. package/dist/chunk-AYDXOUFX.js.map +0 -7
  437. package/dist/chunk-BBIPZ2UF.js +0 -52
  438. package/dist/chunk-BBVOZ5BY.js +0 -230
  439. package/dist/chunk-BBVOZ5BY.js.map +0 -7
  440. package/dist/chunk-BHVDOW3W.js +0 -470
  441. package/dist/chunk-BNN32RI2.js +0 -36
  442. package/dist/chunk-BQLC6QOH.js +0 -368
  443. package/dist/chunk-BQLC6QOH.js.map +0 -7
  444. package/dist/chunk-C5QOWZK6.js +0 -629
  445. package/dist/chunk-CJJ6LDZM.js +0 -170
  446. package/dist/chunk-CJJ6LDZM.js.map +0 -7
  447. package/dist/chunk-D4U5X2QQ.js +0 -261
  448. package/dist/chunk-DV444SFD.js +0 -26
  449. package/dist/chunk-DWWAB4YQ.js +0 -102
  450. package/dist/chunk-FP5VKE3Z.js +0 -170
  451. package/dist/chunk-FVWCYGJL.js +0 -121
  452. package/dist/chunk-G2MAZI6I.js +0 -205
  453. package/dist/chunk-HLRNIO5K.js +0 -158
  454. package/dist/chunk-HTHH2B6D.js +0 -46
  455. package/dist/chunk-I7X6K4OL.js +0 -217
  456. package/dist/chunk-ITYEOGLB.js +0 -302
  457. package/dist/chunk-J6XKDYNZ.js +0 -276
  458. package/dist/chunk-J6XKDYNZ.js.map +0 -7
  459. package/dist/chunk-JDX4E7ZO.js +0 -381
  460. package/dist/chunk-JWX7GYHP.js +0 -95
  461. package/dist/chunk-KLFROH3F.js +0 -203
  462. package/dist/chunk-KQSN7PUK.js +0 -215
  463. package/dist/chunk-KQSN7PUK.js.map +0 -7
  464. package/dist/chunk-L2ED35QZ.js +0 -2815
  465. package/dist/chunk-L4QG7XZE.js +0 -46
  466. package/dist/chunk-L4QG7XZE.js.map +0 -7
  467. package/dist/chunk-LI7FE335.js +0 -371
  468. package/dist/chunk-LLPFFNLV.js +0 -526
  469. package/dist/chunk-LRV4VWRF.js +0 -94
  470. package/dist/chunk-LRV4VWRF.js.map +0 -7
  471. package/dist/chunk-M464GTNI.js +0 -615
  472. package/dist/chunk-MDN3K2BG.js +0 -229
  473. package/dist/chunk-MDN3K2BG.js.map +0 -7
  474. package/dist/chunk-N46WTUX7.js +0 -286
  475. package/dist/chunk-N46WTUX7.js.map +0 -7
  476. package/dist/chunk-NBMJ2UMA.js +0 -194
  477. package/dist/chunk-NI7VSKJI.js +0 -293
  478. package/dist/chunk-NTVM4ZPG.js +0 -2784
  479. package/dist/chunk-O64UTRAC.js +0 -252
  480. package/dist/chunk-OM326NV3.js +0 -100
  481. package/dist/chunk-P4ENJUBN.js +0 -386
  482. package/dist/chunk-PEKVBCIH.js +0 -824
  483. package/dist/chunk-PF6MKI4X.js +0 -92
  484. package/dist/chunk-PJTQP6RL.js +0 -54
  485. package/dist/chunk-PVSRVJBE.js +0 -1201
  486. package/dist/chunk-PVSRVJBE.js.map +0 -7
  487. package/dist/chunk-PZ3L3KM6.js +0 -55
  488. package/dist/chunk-QEHUEG4X.js +0 -1788
  489. package/dist/chunk-QEHUEG4X.js.map +0 -7
  490. package/dist/chunk-QXCVG66S.js +0 -2672
  491. package/dist/chunk-RIGZHHCP.js +0 -119
  492. package/dist/chunk-SEIANPCX.js +0 -142
  493. package/dist/chunk-SEQLC4AD.js +0 -177
  494. package/dist/chunk-SK7YVOQN.js +0 -148
  495. package/dist/chunk-SPPZB5ZQ.js +0 -158
  496. package/dist/chunk-SPPZB5ZQ.js.map +0 -7
  497. package/dist/chunk-T5KFRIP4.js +0 -1087
  498. package/dist/chunk-TTSNECVD.js +0 -1413
  499. package/dist/chunk-TTSNECVD.js.map +0 -7
  500. package/dist/chunk-TV74I3Y5.js +0 -43
  501. package/dist/chunk-TV74I3Y5.js.map +0 -7
  502. package/dist/chunk-TVXESYIR.js +0 -439
  503. package/dist/chunk-U3UR3U3F.js +0 -446
  504. package/dist/chunk-UFYU7AKL.js +0 -107
  505. package/dist/chunk-VIYGTRUZ.js +0 -6364
  506. package/dist/chunk-WCTH7CB3.js +0 -31
  507. package/dist/chunk-WGSWVYHY.js +0 -1155
  508. package/dist/chunk-WYZ4COTF.js +0 -226
  509. package/dist/chunk-WZRXJ5LL.js +0 -2370
  510. package/dist/chunk-WZRXJ5LL.js.map +0 -7
  511. package/dist/chunk-XZZLEHWC.js +0 -20328
  512. package/dist/chunk-XZZLEHWC.js.map +0 -7
  513. package/dist/chunk-Y7JAPSMG.js +0 -406
  514. package/dist/chunk-Y7JAPSMG.js.map +0 -7
  515. package/dist/chunk-YJ2HC4CP.js +0 -1150
  516. package/dist/chunk-ZLH4PJKX.js +0 -1658
  517. package/dist/chunk-ZLH4PJKX.js.map +0 -7
  518. package/dist/chunk-ZZSDYKD5.js +0 -14
  519. package/dist/condition-S52W57ZO.js +0 -330
  520. package/dist/controls-B4MTTPWO.js +0 -39
  521. package/dist/controls.config-6KBCTIPN.js +0 -37
  522. package/dist/correlation-VSBCBFFP.js +0 -96
  523. package/dist/cuminc-T5ZPAGVB.js +0 -1147
  524. package/dist/cuminc.integration.spec-2QT3IPHU.js +0 -676
  525. package/dist/customdata.inputui-5MHQQHJL.js +0 -285
  526. package/dist/dataDownload-S4EBNHMW.js +0 -328
  527. package/dist/dataDownload.integration.spec-OVSIWI34.js +0 -191
  528. package/dist/databrowser.ui-EAJS3NXV.js +0 -419
  529. package/dist/dictionary-CQHSMVYF.js +0 -98
  530. package/dist/dnaMethylation-G3F2INDH.js +0 -36
  531. package/dist/dnaMethylation.integration.spec-FWF4353K.js +0 -179
  532. package/dist/e2pca-SLXGPVHP.js +0 -348
  533. package/dist/ep-4HGUSDGJ.js +0 -1254
  534. package/dist/expclust.gdc.spec-JJ42ESKE.js +0 -305
  535. package/dist/facet-6WVTVKDV.js +0 -519
  536. package/dist/geneExpClustering-5LOZPD5X.js +0 -246
  537. package/dist/geneExpression-BJ46UGXW.js +0 -312
  538. package/dist/geneExpression-PTSZWKCM.js +0 -36
  539. package/dist/geneExpression.unit.spec-NW5HTO7F.js +0 -100
  540. package/dist/geneORA-H65EZ7QO.js +0 -276
  541. package/dist/geneVariant-T6GWOVZD.js +0 -39
  542. package/dist/geneVariant-WTDFZTXG.js +0 -37
  543. package/dist/geneVariant.integration.spec-OPSBRUM3.js +0 -196
  544. package/dist/genefusion.ui-RSBCC37C.js +0 -249
  545. package/dist/geneset-B67PAZVL.js +0 -194
  546. package/dist/genomeBrowser.spec-AUTULF4C.js +0 -279
  547. package/dist/grin2-CMBP7XVH.js +0 -1031
  548. package/dist/grin2-JVCNH3KW.js +0 -1554
  549. package/dist/gsea-H774WVPQ.js +0 -45
  550. package/dist/hierCluster-IQTXQUMI.js +0 -58
  551. package/dist/hierCluster-ZQJDXYBD.js +0 -62
  552. package/dist/hierCluster.config-ZHJTZK5L.js +0 -38
  553. package/dist/hierCluster.integration.spec-MSJ5GHHK.js +0 -374
  554. package/dist/hierCluster.interactivity-H2GNO6AA.js +0 -52
  555. package/dist/hierCluster.renderers-2TE6HMK2.js +0 -21
  556. package/dist/imagePlot-FMNMB7JZ.js +0 -139
  557. package/dist/importPlot-N66G43XX.js +0 -8
  558. package/dist/isoformExpression-B64WLO3H.js +0 -38
  559. package/dist/isoformExpression.unit.spec-D2R6CRKO.js +0 -126
  560. package/dist/isoformExpression.unit.spec-D2R6CRKO.js.map +0 -7
  561. package/dist/launch.adhoc-MPRAJ3GN.js +0 -40
  562. package/dist/leftlabel.sample-4JCKYXED.js +0 -257
  563. package/dist/legacyDataset-PBCPC5I7.js +0 -119
  564. package/dist/lollipop-25ADHT7O.js +0 -166
  565. package/dist/maf-POYTGXT4.js +0 -442
  566. package/dist/maf-POYTGXT4.js.map +0 -7
  567. package/dist/maftimeline-FOQF6O3X.js +0 -591
  568. package/dist/matrix-LHLAYDTQ.js +0 -57
  569. package/dist/matrix-ZKF7NRAD.js +0 -62
  570. package/dist/matrix.cells-H4TS74FJ.js +0 -28
  571. package/dist/matrix.config-HE7QUDER.js +0 -39
  572. package/dist/matrix.controls-VILCLNSC.js +0 -37
  573. package/dist/matrix.data-2OUWYD35.js +0 -25
  574. package/dist/matrix.groups-5BGJIOOJ.js +0 -26
  575. package/dist/matrix.integration.spec-DSXZHAEY.js +0 -3070
  576. package/dist/matrix.interactivity-VK3NWX5M.js +0 -40
  577. package/dist/matrix.layout-PUNMMNCC.js +0 -42
  578. package/dist/matrix.legend-QMERGVYU.js +0 -22
  579. package/dist/matrix.renderers-2KQ2NXSQ.js +0 -36
  580. package/dist/matrix.serieses-24G3XPJD.js +0 -21
  581. package/dist/matrix.sort-HTVT4K7C.js +0 -27
  582. package/dist/matrix.sort.unit.spec-EUVL76NB.js +0 -470
  583. package/dist/matrix.sorterUi-PJPFXWOJ.js +0 -18
  584. package/dist/matrix.sorterUi.unit.spec-QWL5Y4DQ.js +0 -340
  585. package/dist/mavb-UGM5SHEF.js +0 -730
  586. package/dist/mds.fimo-64US7RTE.js +0 -516
  587. package/dist/mds.samplescatterplot-JMXLXVIE.js +0 -1548
  588. package/dist/mds.survivalplot-RJ5UD3IU.js +0 -481
  589. package/dist/oncomatrix-ZFT3DRAP.js +0 -293
  590. package/dist/oncomatrix-ZFT3DRAP.js.map +0 -7
  591. package/dist/oncomatrix.spec-4YLKDGFE.js +0 -446
  592. package/dist/plot.2dvaf-DYSU6BBN.js +0 -375
  593. package/dist/plot.app-NFBVLAXZ.js +0 -39
  594. package/dist/plot.barplot-DBGTDK7J.js +0 -100
  595. package/dist/plot.boxplot-MCKZUROP.js +0 -150
  596. package/dist/plot.brainImaging-BBAVUEB4.js +0 -51
  597. package/dist/plot.disco-VGOEQYRL.js +0 -101
  598. package/dist/plot.dzi-YQIFOTZQ.js +0 -33
  599. package/dist/plot.ssgq-MU3BRTMC.js +0 -137
  600. package/dist/plot.vaf2cov-KDHZ7JXJ.js +0 -257
  601. package/dist/plot.wsi-G2TUGQF7.js +0 -36
  602. package/dist/polar-RCCZXZIU.js +0 -184
  603. package/dist/polar2-COQ3WIGW.js +0 -226
  604. package/dist/profile.spec-A4ZASR2T.js +0 -78
  605. package/dist/profileBarchart-GB4RK5DF.js +0 -265
  606. package/dist/profileForms-O5KBHRF6.js +0 -438
  607. package/dist/profilePlot-COCLCP5B.js +0 -52
  608. package/dist/profileRadar-4EE3YDOH.js +0 -261
  609. package/dist/profileRadarFacility-JYTSGA5H.js +0 -261
  610. package/dist/proteomeAbundance-JBVXUSD6.js +0 -19
  611. package/dist/proteomeAbundance-NQVU4DOW.js +0 -63
  612. package/dist/qualitative-QROOPDSI.js +0 -41
  613. package/dist/regression-7FQZ22OO.js +0 -54
  614. package/dist/regression.inputs-F62CES3A.js +0 -46
  615. package/dist/regression.inputs.term-BCGP7PX4.js +0 -46
  616. package/dist/regression.inputs.values.table-D3ZXZSH7.js +0 -43
  617. package/dist/regression.integration.spec-P2BBTT2O.js +0 -784
  618. package/dist/regression.results-JX6RJQQP.js +0 -38
  619. package/dist/regression.spec-ROME7T33.js +0 -706
  620. package/dist/report-B6MM4T6B.js +0 -220
  621. package/dist/sampleScatter.spec-EPCMC3SR.js +0 -200
  622. package/dist/sampleView-77EAJ75T.js +0 -46
  623. package/dist/samplelst-CX4NQWA7.js +0 -109
  624. package/dist/samplematrix-PYQFAH64.js +0 -2196
  625. package/dist/sc-X6SI5VVI.js +0 -84
  626. package/dist/scatter-ZFFHAI4F.js +0 -800
  627. package/dist/scatter.integration.spec-NN43OXRN.js +0 -1194
  628. package/dist/selectGenomeWithTklst-CZMVTBMD.js +0 -132
  629. package/dist/singleCellCellType-GOBX7JKV.js +0 -36
  630. package/dist/singleCellCellType.unit.spec-F344QMTQ.js +0 -177
  631. package/dist/singleCellGeneExpression-BLMNMEAI.js +0 -36
  632. package/dist/singleCellGeneExpression.unit.spec-6ZEPUFWC.js +0 -163
  633. package/dist/singleCellPlot-HLD7PLQH.js +0 -51
  634. package/dist/singlecell-HL4GLGIA.js +0 -1570
  635. package/dist/singlecell-JQFPINRS.js +0 -84
  636. package/dist/snp-EAUNFDAV.js +0 -36
  637. package/dist/snp.unit.spec-AVLPMAWI.js +0 -174
  638. package/dist/snplocus-2J7OA6OL.js +0 -206
  639. package/dist/spliceevent.a53ss.diagram-4DU2U7NW.js +0 -149
  640. package/dist/spliceevent.exonskip.diagram-GG5FGXOK.js +0 -275
  641. package/dist/spliceevent.noeventdiagram-T6RNIMCM.js +0 -458
  642. package/dist/ssGSEA-XJWLRVFQ.js +0 -36
  643. package/dist/ssGSEA.unit.spec-MQ23ODYO.js +0 -86
  644. package/dist/summarizeCnvGeneexp-CJPC76RM.js +0 -158
  645. package/dist/summarizeGeneexpSurvival-FGCFZTVG.js +0 -105
  646. package/dist/summarizeMutationCnv-4E7R2NHQ.js +0 -159
  647. package/dist/summarizeMutationDiagnosis-ZVX7AZK7.js +0 -38
  648. package/dist/summarizeMutationSurvival-EWXD7TCT.js +0 -97
  649. package/dist/summary-VUYBKQOC.js +0 -47
  650. package/dist/summary.integration.spec-EPBV5XCT.js +0 -412
  651. package/dist/summaryInput-YX5IRGWM.js +0 -218
  652. package/dist/sunburst-HPDML45I.js +0 -282
  653. package/dist/survival-E6SRRXBB.js +0 -44
  654. package/dist/survival-XOXDPXZR.js +0 -56
  655. package/dist/survival.integration.spec-SJBPJZGJ.js +0 -787
  656. package/dist/svgraph-D23WG3UE.js +0 -1385
  657. package/dist/svmr-UFC4TKWV.js +0 -3840
  658. package/dist/table-US2K6IYZ.js +0 -198
  659. package/dist/termCollection-E7S57CIN.js +0 -177
  660. package/dist/termCollection-ZMP3VE2G.js +0 -36
  661. package/dist/termCollection.unit.spec-MDWK6XH3.js +0 -206
  662. package/dist/tk-TLQJK6R4.js +0 -44
  663. package/dist/tp.ui-NQEAKWUH.js +0 -1457
  664. package/dist/tvs.density-HSVPDDGA.js +0 -18
  665. package/dist/tvs.dt-U2MINIBH.js +0 -37
  666. package/dist/tvs.dtcnv.categorical-2OOAZJKC.js +0 -38
  667. package/dist/tvs.dtcnv.continuous-5ETKBJ52.js +0 -70
  668. package/dist/tvs.dtfusion-EB4PPR3Y.js +0 -38
  669. package/dist/tvs.dtsnvindel-IRQPTKQF.js +0 -38
  670. package/dist/tvs.dtsv-TOVXZJCR.js +0 -38
  671. package/dist/tvs.numeric-ICUGA4WY.js +0 -21
  672. package/dist/tvs.samplelst-4SCH543Y.js +0 -102
  673. package/dist/tvs.termCollection-GGN5F6HC.js +0 -151
  674. package/dist/violin-7D7DN74I.js +0 -44
  675. package/dist/violin.integration.spec-KE76AL54.js +0 -1417
  676. package/dist/violin.interactivity-YPJ2H6SQ.js +0 -36
  677. package/dist/violin.renderer-UK7WSA2Z.js +0 -38
  678. package/dist/vocabulary-KLWZ6LRP.js +0 -39
  679. /package/dist/{2dmaf-PFPBHIUI.js.map → 2dmaf-SLBAWGPG.js.map} +0 -0
  680. /package/dist/{AIProjectAdmin-H2GB5ZOX.js.map → AIProjectAdmin-6SH5X3AF.js.map} +0 -0
  681. /package/dist/{AppHeader-FCWML6WH.js.map → AppHeader-MVYNRMC7.js.map} +0 -0
  682. /package/dist/{BoxPlot-QKXGF76K.js.map → BoxPlot-HLGWW3IK.js.map} +0 -0
  683. /package/dist/{CorrelationVolcano-ZJ7Q6JBC.js.map → CorrelationVolcano-TZCYC3NI.js.map} +0 -0
  684. /package/dist/{DifferentialAnalysis-PWCFCWFY.js.map → DifferentialAnalysis-DS7CQOT6.js.map} +0 -0
  685. /package/dist/{Disco-IE5JKIF2.js.map → Disco-U5I6NJUT.js.map} +0 -0
  686. /package/dist/{Disco.UI-SR7LSJE3.js.map → Disco.UI-J2B7GGEZ.js.map} +0 -0
  687. /package/dist/{DmrPlot-UDY7GOSY.js.map → DmrPlot-D5W76QPY.js.map} +0 -0
  688. /package/dist/{GB-GNTOP5C6.js.map → GB-LM5SGUG4.js.map} +0 -0
  689. /package/dist/{HicApp-FZTJL3OA.js.map → HicApp-YNBGAGKM.js.map} +0 -0
  690. /package/dist/{NumBinaryEditor.unit.spec-BMVRI24W.js.map → NumBinaryEditor.unit.spec-YWSIFTOJ.js.map} +0 -0
  691. /package/dist/{NumContEditor-6JT5D6IW.js.map → NumContEditor-ZPLVZFLH.js.map} +0 -0
  692. /package/dist/{NumContEditor.unit.spec-XBQF2SW6.js.map → NumContEditor.unit.spec-NBCFOCOX.js.map} +0 -0
  693. /package/dist/{NumCustomBinEditor-MEKEFOQI.js.map → NumCustomBinEditor-TXEYRVPL.js.map} +0 -0
  694. /package/dist/{NumCustomBinEditor.unit.spec-LEMQJHDT.js.map → NumCustomBinEditor.unit.spec-SQM63H4B.js.map} +0 -0
  695. /package/dist/{NumDiscreteEditor.unit.spec-WQM4DLKO.js.map → NumDiscreteEditor.unit.spec-4HC4AGAM.js.map} +0 -0
  696. /package/dist/{NumRegularBinEditor-HQR5Y6P7.js.map → NumRegularBinEditor-VQAS3OXK.js.map} +0 -0
  697. /package/dist/{NumRegularBinEditor.unit.spec-FL4IFT7L.js.map → NumRegularBinEditor.unit.spec-RGVEPB3Z.js.map} +0 -0
  698. /package/dist/{NumSplineEditor.unit.spec-HYOXO45B.js.map → NumSplineEditor.unit.spec-HF5E6ANH.js.map} +0 -0
  699. /package/dist/{NumericDensity-GJZ4BBJS.js.map → NumericDensity-LMLPMOSE.js.map} +0 -0
  700. /package/dist/{NumericDensity.unit.spec-6LXWAXW7.js.map → NumericDensity.unit.spec-3ZI5EVON.js.map} +0 -0
  701. /package/dist/{NumericHandler-LZIMPOHS.js.map → NumericHandler-Q6F6ANOS.js.map} +0 -0
  702. /package/dist/{NumericHandler.unit.spec-ZSU35AMD.js.map → NumericHandler.unit.spec-E6Z5HUNZ.js.map} +0 -0
  703. /package/dist/{RunChart2-7XV6TIFO.js.map → RunChart2-XSNWNAIL.js.map} +0 -0
  704. /package/dist/{SC-E4EYAG26.js.map → SC-RA46YM57.js.map} +0 -0
  705. /package/dist/{Volcano-Z7TJK6PW.js.map → Volcano-75UDYPVB.js.map} +0 -0
  706. /package/dist/{WSIViewer-ZH2XABLC.js.map → WSIViewer-GYUUXCSJ.js.map} +0 -0
  707. /package/dist/{WsiSamplesPlot-BL47MDHQ.js.map → WsiSamplesPlot-KMI5S2EL.js.map} +0 -0
  708. /package/dist/{adSandbox-V3NTKVBC.js.map → adSandbox-JTK5XEQL.js.map} +0 -0
  709. /package/dist/{alphaGenome-IQVFCSWQ.js.map → alphaGenome-JRAV6WIY.js.map} +0 -0
  710. /package/dist/{app-GJLZ2G2U.js.map → app-JKDZL23V.js.map} +0 -0
  711. /package/dist/{app-YSD2U64Q.js.map → app-OEARXM6E.js.map} +0 -0
  712. /package/dist/{barchart-GLLUYTAJ.js.map → barchart-GG5UFDG4.js.map} +0 -0
  713. /package/dist/{barchart.data-FRYRGKH3.js.map → barchart.data-KXA66FAL.js.map} +0 -0
  714. /package/dist/{barchart.events-WODVSHRN.js.map → barchart.events-P2USOIR7.js.map} +0 -0
  715. /package/dist/{barchart.integration.spec-6POS3V3T.js.map → barchart.integration.spec-5QSPQQLJ.js.map} +0 -0
  716. /package/dist/{block.init-7HDLKQVX.js.map → block.init-ZHX6DFWF.js.map} +0 -0
  717. /package/dist/{block.mds.expressionrank-UIB25S6E.js.map → block.mds.expressionrank-YMGYXXYT.js.map} +0 -0
  718. /package/dist/{block.mds.geneboxplot-4PQYO3MR.js.map → block.mds.geneboxplot-IAILQYX4.js.map} +0 -0
  719. /package/dist/{block.mds.junction-DWFYZEC2.js.map → block.mds.junction-BRNFNQMU.js.map} +0 -0
  720. /package/dist/{block.mds.svcnv-N3KJJ4GQ.js.map → block.mds.svcnv-OHKC7YPO.js.map} +0 -0
  721. /package/dist/{block.svg-2HBDI7BT.js.map → block.svg-PNGK45HW.js.map} +0 -0
  722. /package/dist/{block.tk.aicheck-2M4522IQ.js.map → block.tk.aicheck-SCIOJ4WN.js.map} +0 -0
  723. /package/dist/{block.tk.ase-URIKF6JD.js.map → block.tk.ase-BABJ73GG.js.map} +0 -0
  724. /package/dist/{block.tk.bam-HTDMASHX.js.map → block.tk.bam-LZWJ5BCQ.js.map} +0 -0
  725. /package/dist/{block.tk.bedgraphdot-RVKMSFCQ.js.map → block.tk.bedgraphdot-7NQLC3XJ.js.map} +0 -0
  726. /package/dist/{block.tk.bigwig.ui-7JPEOIKM.js.map → block.tk.bigwig.ui-VNY4SFD5.js.map} +0 -0
  727. /package/dist/{block.tk.hicstraw-72J7UJ2J.js.map → block.tk.hicstraw-36A7VDRM.js.map} +0 -0
  728. /package/dist/{block.tk.junction-GGFMBCV5.js.map → block.tk.junction-D373YEMK.js.map} +0 -0
  729. /package/dist/{block.tk.junction.textmatrixui-44SAYYWE.js.map → block.tk.junction.textmatrixui-FFII7J3X.js.map} +0 -0
  730. /package/dist/{block.tk.ld-XDKJFEOL.js.map → block.tk.ld-XGB6KMDO.js.map} +0 -0
  731. /package/dist/{block.tk.menu-46FOTM7H.js.map → block.tk.menu-PEZANZBZ.js.map} +0 -0
  732. /package/dist/{block.tk.pgv-ZVONRT4B.js.map → block.tk.pgv-MU5BPTT2.js.map} +0 -0
  733. /package/dist/{brainImaging-CSLO7ODJ.js.map → brainImaging-LVJON47N.js.map} +0 -0
  734. /package/dist/{chat-GMD22F3K.js.map → chat-5FDIAQJ4.js.map} +0 -0
  735. /package/dist/{chunk-G2MAZI6I.js.map → chunk-2OSEZCWZ.js.map} +0 -0
  736. /package/dist/{chunk-RIGZHHCP.js.map → chunk-6MSCYO7K.js.map} +0 -0
  737. /package/dist/{chunk-4FO7KZY2.js.map → chunk-7A7NMCQ3.js.map} +0 -0
  738. /package/dist/{chunk-O64UTRAC.js.map → chunk-AETE4F7R.js.map} +0 -0
  739. /package/dist/{chunk-6YLQN7FF.js.map → chunk-AZYDW5T7.js.map} +0 -0
  740. /package/dist/{chunk-7FXPMQRW.js.map → chunk-B6HCIAM3.js.map} +0 -0
  741. /package/dist/{chunk-L2ED35QZ.js.map → chunk-CCIZJAXB.js.map} +0 -0
  742. /package/dist/{chunk-UFYU7AKL.js.map → chunk-DHZL3FBC.js.map} +0 -0
  743. /package/dist/{chunk-AQ4OP4GR.js.map → chunk-DONWY7TP.js.map} +0 -0
  744. /package/dist/{chunk-2TIYJ3PH.js.map → chunk-DVDDXOWT.js.map} +0 -0
  745. /package/dist/{chunk-74QJDBIP.js.map → chunk-E6DRQJJT.js.map} +0 -0
  746. /package/dist/{chunk-BNN32RI2.js.map → chunk-ESKU6LNC.js.map} +0 -0
  747. /package/dist/{chunk-SEQLC4AD.js.map → chunk-F6V4AYWP.js.map} +0 -0
  748. /package/dist/{chunk-ITYEOGLB.js.map → chunk-FBAJTPBU.js.map} +0 -0
  749. /package/dist/{chunk-LI7FE335.js.map → chunk-FGMPKWT5.js.map} +0 -0
  750. /package/dist/{chunk-D4U5X2QQ.js.map → chunk-FK4MYVW2.js.map} +0 -0
  751. /package/dist/{chunk-3TU6TRLQ.js.map → chunk-FMBJ4SKC.js.map} +0 -0
  752. /package/dist/{chunk-WYZ4COTF.js.map → chunk-FQRLSKJC.js.map} +0 -0
  753. /package/dist/{chunk-C5QOWZK6.js.map → chunk-G6ELKVBG.js.map} +0 -0
  754. /package/dist/{chunk-NBMJ2UMA.js.map → chunk-GO5SIPFE.js.map} +0 -0
  755. /package/dist/{chunk-P4ENJUBN.js.map → chunk-GPOECA3V.js.map} +0 -0
  756. /package/dist/{chunk-TVXESYIR.js.map → chunk-GW7DHJYH.js.map} +0 -0
  757. /package/dist/{chunk-JWX7GYHP.js.map → chunk-H2K5KZP7.js.map} +0 -0
  758. /package/dist/{chunk-22KWZOCN.js.map → chunk-H5XFH3FV.js.map} +0 -0
  759. /package/dist/{chunk-A2Y3GEUH.js.map → chunk-HAMDFQIX.js.map} +0 -0
  760. /package/dist/{chunk-5ZICCKEH.js.map → chunk-HH4QLSTK.js.map} +0 -0
  761. /package/dist/{chunk-LLPFFNLV.js.map → chunk-IBTPGSYI.js.map} +0 -0
  762. /package/dist/{chunk-QXCVG66S.js.map → chunk-IIRU6VK2.js.map} +0 -0
  763. /package/dist/{chunk-PF6MKI4X.js.map → chunk-IP4T477W.js.map} +0 -0
  764. /package/dist/{chunk-6UU7VPDO.js.map → chunk-JHOGX5VE.js.map} +0 -0
  765. /package/dist/{chunk-JDX4E7ZO.js.map → chunk-JOXUBWN3.js.map} +0 -0
  766. /package/dist/{chunk-SEIANPCX.js.map → chunk-K57RR3FD.js.map} +0 -0
  767. /package/dist/{chunk-AHLUW2BN.js.map → chunk-K6JLCMVL.js.map} +0 -0
  768. /package/dist/{chunk-OM326NV3.js.map → chunk-KSFSM46X.js.map} +0 -0
  769. /package/dist/{chunk-BHVDOW3W.js.map → chunk-KVG7FTTK.js.map} +0 -0
  770. /package/dist/{chunk-HLRNIO5K.js.map → chunk-LEDPPLQK.js.map} +0 -0
  771. /package/dist/{chunk-YJ2HC4CP.js.map → chunk-LUTT3MBZ.js.map} +0 -0
  772. /package/dist/{chunk-NTVM4ZPG.js.map → chunk-MPJHDHBA.js.map} +0 -0
  773. /package/dist/{chunk-M464GTNI.js.map → chunk-O4PXELXF.js.map} +0 -0
  774. /package/dist/{chunk-ZZSDYKD5.js.map → chunk-ORPCSG6T.js.map} +0 -0
  775. /package/dist/{chunk-4OEOQX4L.js.map → chunk-OUKDZKSZ.js.map} +0 -0
  776. /package/dist/{chunk-T5KFRIP4.js.map → chunk-P5HLYAHP.js.map} +0 -0
  777. /package/dist/{chunk-SK7YVOQN.js.map → chunk-PIACSJPH.js.map} +0 -0
  778. /package/dist/{chunk-WCTH7CB3.js.map → chunk-PQABAAEZ.js.map} +0 -0
  779. /package/dist/{chunk-HTHH2B6D.js.map → chunk-PSMDCZET.js.map} +0 -0
  780. /package/dist/{chunk-I7X6K4OL.js.map → chunk-RFIVPTMS.js.map} +0 -0
  781. /package/dist/{chunk-PJTQP6RL.js.map → chunk-RSU37SVQ.js.map} +0 -0
  782. /package/dist/{chunk-WGSWVYHY.js.map → chunk-SPAIFVM2.js.map} +0 -0
  783. /package/dist/{chunk-PZ3L3KM6.js.map → chunk-T2HYA2KL.js.map} +0 -0
  784. /package/dist/{chunk-5HCB4HNL.js.map → chunk-TE3DK3A6.js.map} +0 -0
  785. /package/dist/{chunk-3656ZY4T.js.map → chunk-TIQPSXFJ.js.map} +0 -0
  786. /package/dist/{chunk-DV444SFD.js.map → chunk-TN5GSG34.js.map} +0 -0
  787. /package/dist/{chunk-BBIPZ2UF.js.map → chunk-UBGTQMOO.js.map} +0 -0
  788. /package/dist/{chunk-2NQ4TM74.js.map → chunk-UE5ZYM63.js.map} +0 -0
  789. /package/dist/{chunk-DWWAB4YQ.js.map → chunk-UQACPOCM.js.map} +0 -0
  790. /package/dist/{chunk-U3UR3U3F.js.map → chunk-UR3C4SCH.js.map} +0 -0
  791. /package/dist/{chunk-FVWCYGJL.js.map → chunk-UWX7W22M.js.map} +0 -0
  792. /package/dist/{chunk-NI7VSKJI.js.map → chunk-VLTDUJRM.js.map} +0 -0
  793. /package/dist/{chunk-VIYGTRUZ.js.map → chunk-W6UUEAEP.js.map} +0 -0
  794. /package/dist/{chunk-FP5VKE3Z.js.map → chunk-Y3TDC7NU.js.map} +0 -0
  795. /package/dist/{chunk-PEKVBCIH.js.map → chunk-YOTWMCT5.js.map} +0 -0
  796. /package/dist/{chunk-KLFROH3F.js.map → chunk-YUMPQ3CJ.js.map} +0 -0
  797. /package/dist/{condition-S52W57ZO.js.map → condition-VHP2L4GM.js.map} +0 -0
  798. /package/dist/{controls-B4MTTPWO.js.map → controls-N5Q7U7JR.js.map} +0 -0
  799. /package/dist/{controls.config-6KBCTIPN.js.map → controls.config-NJMW4SLR.js.map} +0 -0
  800. /package/dist/{correlation-VSBCBFFP.js.map → correlation-3LDASF5I.js.map} +0 -0
  801. /package/dist/{cuminc-T5ZPAGVB.js.map → cuminc-UWJ23W6C.js.map} +0 -0
  802. /package/dist/{cuminc.integration.spec-2QT3IPHU.js.map → cuminc.integration.spec-OZYYET3W.js.map} +0 -0
  803. /package/dist/{customdata.inputui-5MHQQHJL.js.map → customdata.inputui-2FVCVSE4.js.map} +0 -0
  804. /package/dist/{dataDownload-S4EBNHMW.js.map → dataDownload-4S4PE5HX.js.map} +0 -0
  805. /package/dist/{dataDownload.integration.spec-OVSIWI34.js.map → dataDownload.integration.spec-B57LEKFZ.js.map} +0 -0
  806. /package/dist/{databrowser.ui-EAJS3NXV.js.map → databrowser.ui-N6GHEQ2P.js.map} +0 -0
  807. /package/dist/{dictionary-CQHSMVYF.js.map → dictionary-UP46QRYZ.js.map} +0 -0
  808. /package/dist/{dnaMethylation-G3F2INDH.js.map → dnaMethylation-BOGAUAWA.js.map} +0 -0
  809. /package/dist/{dnaMethylation.integration.spec-FWF4353K.js.map → dnaMethylation.integration.spec-UAHBJSSJ.js.map} +0 -0
  810. /package/dist/{e2pca-SLXGPVHP.js.map → e2pca-L5EBQJNP.js.map} +0 -0
  811. /package/dist/{ep-4HGUSDGJ.js.map → ep-Z67ORKUX.js.map} +0 -0
  812. /package/dist/{expclust.gdc.spec-JJ42ESKE.js.map → expclust.gdc.spec-SP7VOL64.js.map} +0 -0
  813. /package/dist/{facet-6WVTVKDV.js.map → facet-HDB4VDGU.js.map} +0 -0
  814. /package/dist/{geneExpClustering-5LOZPD5X.js.map → geneExpClustering-6ZPOLTDJ.js.map} +0 -0
  815. /package/dist/{geneExpression-BJ46UGXW.js.map → geneExpression-T6YIG4XQ.js.map} +0 -0
  816. /package/dist/{geneExpression-PTSZWKCM.js.map → geneExpression-T7QUHV5S.js.map} +0 -0
  817. /package/dist/{geneExpression.unit.spec-NW5HTO7F.js.map → geneExpression.unit.spec-DO52L5IB.js.map} +0 -0
  818. /package/dist/{geneORA-H65EZ7QO.js.map → geneORA-KOUDUWUO.js.map} +0 -0
  819. /package/dist/{geneVariant-T6GWOVZD.js.map → geneVariant-FVR76F6I.js.map} +0 -0
  820. /package/dist/{geneVariant-WTDFZTXG.js.map → geneVariant-I5QUITKG.js.map} +0 -0
  821. /package/dist/{geneVariant.integration.spec-OPSBRUM3.js.map → geneVariant.integration.spec-D4IRM7B5.js.map} +0 -0
  822. /package/dist/{genefusion.ui-RSBCC37C.js.map → genefusion.ui-35IYSZD7.js.map} +0 -0
  823. /package/dist/{geneset-B67PAZVL.js.map → geneset-7ZHJ5KWK.js.map} +0 -0
  824. /package/dist/{genomeBrowser.spec-AUTULF4C.js.map → genomeBrowser.spec-VXASVLNH.js.map} +0 -0
  825. /package/dist/{grin2-JVCNH3KW.js.map → grin2-7NM56COO.js.map} +0 -0
  826. /package/dist/{grin2-CMBP7XVH.js.map → grin2-IY26UUQI.js.map} +0 -0
  827. /package/dist/{gsea-H774WVPQ.js.map → gsea-TORO46C6.js.map} +0 -0
  828. /package/dist/{hierCluster-IQTXQUMI.js.map → hierCluster-3BKEGW6P.js.map} +0 -0
  829. /package/dist/{hierCluster-ZQJDXYBD.js.map → hierCluster-HM3LOM6V.js.map} +0 -0
  830. /package/dist/{hierCluster.config-ZHJTZK5L.js.map → hierCluster.config-LDO5IGQ5.js.map} +0 -0
  831. /package/dist/{hierCluster.integration.spec-MSJ5GHHK.js.map → hierCluster.integration.spec-XO5R6CQT.js.map} +0 -0
  832. /package/dist/{hierCluster.interactivity-H2GNO6AA.js.map → hierCluster.interactivity-NVQ6262K.js.map} +0 -0
  833. /package/dist/{hierCluster.renderers-2TE6HMK2.js.map → hierCluster.renderers-SWPPNBLU.js.map} +0 -0
  834. /package/dist/{imagePlot-FMNMB7JZ.js.map → imagePlot-V4WLAPV6.js.map} +0 -0
  835. /package/dist/{importPlot-N66G43XX.js.map → importPlot-NZKQEOX4.js.map} +0 -0
  836. /package/dist/{isoformExpression-B64WLO3H.js.map → isoformExpression-TIZBIGNL.js.map} +0 -0
  837. /package/dist/{launch.adhoc-MPRAJ3GN.js.map → launch.adhoc-JYEN42NM.js.map} +0 -0
  838. /package/dist/{leftlabel.sample-4JCKYXED.js.map → leftlabel.sample-43DL3J3H.js.map} +0 -0
  839. /package/dist/{legacyDataset-PBCPC5I7.js.map → legacyDataset-QRSNRVUA.js.map} +0 -0
  840. /package/dist/{lollipop-25ADHT7O.js.map → lollipop-NMWZ4FVF.js.map} +0 -0
  841. /package/dist/{maftimeline-FOQF6O3X.js.map → maftimeline-ZB2753S7.js.map} +0 -0
  842. /package/dist/{matrix-LHLAYDTQ.js.map → matrix-RCGQWQ3C.js.map} +0 -0
  843. /package/dist/{matrix-ZKF7NRAD.js.map → matrix-WTTEK4FT.js.map} +0 -0
  844. /package/dist/{matrix.cells-H4TS74FJ.js.map → matrix.cells-UO5ASQ35.js.map} +0 -0
  845. /package/dist/{matrix.config-HE7QUDER.js.map → matrix.config-3UQAT3QR.js.map} +0 -0
  846. /package/dist/{matrix.controls-VILCLNSC.js.map → matrix.controls-PRZ77K5L.js.map} +0 -0
  847. /package/dist/{matrix.data-2OUWYD35.js.map → matrix.data-4W73RQ3H.js.map} +0 -0
  848. /package/dist/{matrix.groups-5BGJIOOJ.js.map → matrix.groups-5VMPI7SA.js.map} +0 -0
  849. /package/dist/{matrix.integration.spec-DSXZHAEY.js.map → matrix.integration.spec-2F5LDLC2.js.map} +0 -0
  850. /package/dist/{matrix.interactivity-VK3NWX5M.js.map → matrix.interactivity-MIPZ6ELV.js.map} +0 -0
  851. /package/dist/{matrix.layout-PUNMMNCC.js.map → matrix.layout-EO5LVYRO.js.map} +0 -0
  852. /package/dist/{matrix.legend-QMERGVYU.js.map → matrix.legend-QBFBFEUG.js.map} +0 -0
  853. /package/dist/{matrix.renderers-2KQ2NXSQ.js.map → matrix.renderers-ERJXVCQL.js.map} +0 -0
  854. /package/dist/{matrix.serieses-24G3XPJD.js.map → matrix.serieses-E23EPXHA.js.map} +0 -0
  855. /package/dist/{matrix.sort-HTVT4K7C.js.map → matrix.sort-I4UGMEXR.js.map} +0 -0
  856. /package/dist/{matrix.sort.unit.spec-EUVL76NB.js.map → matrix.sort.unit.spec-CRGF6CSE.js.map} +0 -0
  857. /package/dist/{matrix.sorterUi-PJPFXWOJ.js.map → matrix.sorterUi-YLSYTYLE.js.map} +0 -0
  858. /package/dist/{matrix.sorterUi.unit.spec-QWL5Y4DQ.js.map → matrix.sorterUi.unit.spec-ENG3ICOO.js.map} +0 -0
  859. /package/dist/{mavb-UGM5SHEF.js.map → mavb-5WR7OJHI.js.map} +0 -0
  860. /package/dist/{mds.fimo-64US7RTE.js.map → mds.fimo-3ZRH7BBJ.js.map} +0 -0
  861. /package/dist/{mds.samplescatterplot-JMXLXVIE.js.map → mds.samplescatterplot-RPXR2FVK.js.map} +0 -0
  862. /package/dist/{mds.survivalplot-RJ5UD3IU.js.map → mds.survivalplot-WSSMYUZD.js.map} +0 -0
  863. /package/dist/{oncomatrix.spec-4YLKDGFE.js.map → oncomatrix.spec-OEGU4DYK.js.map} +0 -0
  864. /package/dist/{plot.2dvaf-DYSU6BBN.js.map → plot.2dvaf-ZGARLQNK.js.map} +0 -0
  865. /package/dist/{plot.app-NFBVLAXZ.js.map → plot.app-TKUJH3LK.js.map} +0 -0
  866. /package/dist/{plot.barplot-DBGTDK7J.js.map → plot.barplot-FEIPGDZ2.js.map} +0 -0
  867. /package/dist/{plot.boxplot-MCKZUROP.js.map → plot.boxplot-6RASUMZB.js.map} +0 -0
  868. /package/dist/{plot.brainImaging-BBAVUEB4.js.map → plot.brainImaging-ZJPFWX2W.js.map} +0 -0
  869. /package/dist/{plot.disco-VGOEQYRL.js.map → plot.disco-2KTKB3XX.js.map} +0 -0
  870. /package/dist/{plot.dzi-YQIFOTZQ.js.map → plot.dzi-PC34YI6Y.js.map} +0 -0
  871. /package/dist/{plot.ssgq-MU3BRTMC.js.map → plot.ssgq-Z4UNJKWO.js.map} +0 -0
  872. /package/dist/{plot.vaf2cov-KDHZ7JXJ.js.map → plot.vaf2cov-NZ4WULKT.js.map} +0 -0
  873. /package/dist/{plot.wsi-G2TUGQF7.js.map → plot.wsi-YYXFAZWY.js.map} +0 -0
  874. /package/dist/{polar-RCCZXZIU.js.map → polar-X2GPIBLB.js.map} +0 -0
  875. /package/dist/{polar2-COQ3WIGW.js.map → polar2-TZ553QQH.js.map} +0 -0
  876. /package/dist/{profile.spec-A4ZASR2T.js.map → profile.spec-VB6VMFLY.js.map} +0 -0
  877. /package/dist/{profileBarchart-GB4RK5DF.js.map → profileBarchart-SKJSTC7B.js.map} +0 -0
  878. /package/dist/{profileForms-O5KBHRF6.js.map → profileForms-RLOGSMAQ.js.map} +0 -0
  879. /package/dist/{profilePlot-COCLCP5B.js.map → profilePlot-267ZS3RG.js.map} +0 -0
  880. /package/dist/{profileRadar-4EE3YDOH.js.map → profileRadar-KGOBHCSF.js.map} +0 -0
  881. /package/dist/{profileRadarFacility-JYTSGA5H.js.map → profileRadarFacility-MCJKSHUM.js.map} +0 -0
  882. /package/dist/{proteomeAbundance-NQVU4DOW.js.map → proteomeAbundance-JUYAYO5I.js.map} +0 -0
  883. /package/dist/{proteomeAbundance-JBVXUSD6.js.map → proteomeAbundance-PGHZSVAF.js.map} +0 -0
  884. /package/dist/{qualitative-QROOPDSI.js.map → qualitative-3IECKKJM.js.map} +0 -0
  885. /package/dist/{regression-7FQZ22OO.js.map → regression-J6FFRPXN.js.map} +0 -0
  886. /package/dist/{regression.inputs-F62CES3A.js.map → regression.inputs-T7LWBSYZ.js.map} +0 -0
  887. /package/dist/{regression.inputs.term-BCGP7PX4.js.map → regression.inputs.term-TT7PNX6G.js.map} +0 -0
  888. /package/dist/{regression.inputs.values.table-D3ZXZSH7.js.map → regression.inputs.values.table-SHFUNKCS.js.map} +0 -0
  889. /package/dist/{regression.integration.spec-P2BBTT2O.js.map → regression.integration.spec-QKHMJTHA.js.map} +0 -0
  890. /package/dist/{regression.results-JX6RJQQP.js.map → regression.results-D4WX6VIV.js.map} +0 -0
  891. /package/dist/{regression.spec-ROME7T33.js.map → regression.spec-7SW55L7X.js.map} +0 -0
  892. /package/dist/{report-B6MM4T6B.js.map → report-QYOZ4BRF.js.map} +0 -0
  893. /package/dist/{sampleScatter.spec-EPCMC3SR.js.map → sampleScatter.spec-JCHFMGNF.js.map} +0 -0
  894. /package/dist/{sampleView-77EAJ75T.js.map → sampleView-7RPKNAZC.js.map} +0 -0
  895. /package/dist/{samplelst-CX4NQWA7.js.map → samplelst-4WNPHZVG.js.map} +0 -0
  896. /package/dist/{samplematrix-PYQFAH64.js.map → samplematrix-CG52DSXJ.js.map} +0 -0
  897. /package/dist/{sc-X6SI5VVI.js.map → sc-OJSWILSA.js.map} +0 -0
  898. /package/dist/{scatter-ZFFHAI4F.js.map → scatter-LG2RMMEC.js.map} +0 -0
  899. /package/dist/{scatter.integration.spec-NN43OXRN.js.map → scatter.integration.spec-QPANYTKW.js.map} +0 -0
  900. /package/dist/{selectGenomeWithTklst-CZMVTBMD.js.map → selectGenomeWithTklst-QXRVE6N4.js.map} +0 -0
  901. /package/dist/{singleCellCellType-GOBX7JKV.js.map → singleCellCellType-XBSRL33U.js.map} +0 -0
  902. /package/dist/{singleCellCellType.unit.spec-F344QMTQ.js.map → singleCellCellType.unit.spec-YZX4CSXA.js.map} +0 -0
  903. /package/dist/{singleCellGeneExpression-BLMNMEAI.js.map → singleCellGeneExpression-64ECP62X.js.map} +0 -0
  904. /package/dist/{singleCellGeneExpression.unit.spec-6ZEPUFWC.js.map → singleCellGeneExpression.unit.spec-CFHFXMA6.js.map} +0 -0
  905. /package/dist/{singleCellPlot-HLD7PLQH.js.map → singleCellPlot-E5F62JY6.js.map} +0 -0
  906. /package/dist/{singlecell-JQFPINRS.js.map → singlecell-FCY5EOUV.js.map} +0 -0
  907. /package/dist/{singlecell-HL4GLGIA.js.map → singlecell-S7B5V7NK.js.map} +0 -0
  908. /package/dist/{snp-EAUNFDAV.js.map → snp-ACKX4GRX.js.map} +0 -0
  909. /package/dist/{snp.unit.spec-AVLPMAWI.js.map → snp.unit.spec-QBGHKKUD.js.map} +0 -0
  910. /package/dist/{snplocus-2J7OA6OL.js.map → snplocus-7EUOW7J7.js.map} +0 -0
  911. /package/dist/{spliceevent.a53ss.diagram-4DU2U7NW.js.map → spliceevent.a53ss.diagram-ALQZA35Z.js.map} +0 -0
  912. /package/dist/{spliceevent.exonskip.diagram-GG5FGXOK.js.map → spliceevent.exonskip.diagram-UF7WJA5R.js.map} +0 -0
  913. /package/dist/{spliceevent.noeventdiagram-T6RNIMCM.js.map → spliceevent.noeventdiagram-4HPGRNRR.js.map} +0 -0
  914. /package/dist/{ssGSEA-XJWLRVFQ.js.map → ssGSEA-FDRBBBLJ.js.map} +0 -0
  915. /package/dist/{ssGSEA.unit.spec-MQ23ODYO.js.map → ssGSEA.unit.spec-EZEOWJVV.js.map} +0 -0
  916. /package/dist/{summarizeCnvGeneexp-CJPC76RM.js.map → summarizeCnvGeneexp-FTL2MGAJ.js.map} +0 -0
  917. /package/dist/{summarizeGeneexpSurvival-FGCFZTVG.js.map → summarizeGeneexpSurvival-DDIF4UW6.js.map} +0 -0
  918. /package/dist/{summarizeMutationCnv-4E7R2NHQ.js.map → summarizeMutationCnv-L3GL5YDY.js.map} +0 -0
  919. /package/dist/{summarizeMutationDiagnosis-ZVX7AZK7.js.map → summarizeMutationDiagnosis-LALOJTHV.js.map} +0 -0
  920. /package/dist/{summarizeMutationSurvival-EWXD7TCT.js.map → summarizeMutationSurvival-TSNTSOBZ.js.map} +0 -0
  921. /package/dist/{summary-VUYBKQOC.js.map → summary-YRHVS64T.js.map} +0 -0
  922. /package/dist/{summary.integration.spec-EPBV5XCT.js.map → summary.integration.spec-766YQLQA.js.map} +0 -0
  923. /package/dist/{summaryInput-YX5IRGWM.js.map → summaryInput-VQ2X6GSX.js.map} +0 -0
  924. /package/dist/{sunburst-HPDML45I.js.map → sunburst-XFOONS6K.js.map} +0 -0
  925. /package/dist/{survival-E6SRRXBB.js.map → survival-FQXZH2MM.js.map} +0 -0
  926. /package/dist/{survival-XOXDPXZR.js.map → survival-TVA3ZWVP.js.map} +0 -0
  927. /package/dist/{survival.integration.spec-SJBPJZGJ.js.map → survival.integration.spec-WFIOPD6A.js.map} +0 -0
  928. /package/dist/{svgraph-D23WG3UE.js.map → svgraph-4BFBO7EL.js.map} +0 -0
  929. /package/dist/{svmr-UFC4TKWV.js.map → svmr-ML7GAIIA.js.map} +0 -0
  930. /package/dist/{table-US2K6IYZ.js.map → table-SMLMUWPP.js.map} +0 -0
  931. /package/dist/{termCollection-ZMP3VE2G.js.map → termCollection-22CPTISZ.js.map} +0 -0
  932. /package/dist/{termCollection-E7S57CIN.js.map → termCollection-EE6AOIVA.js.map} +0 -0
  933. /package/dist/{termCollection.unit.spec-MDWK6XH3.js.map → termCollection.unit.spec-4DIW3CJ3.js.map} +0 -0
  934. /package/dist/{tk-TLQJK6R4.js.map → tk-ITZCKOQ5.js.map} +0 -0
  935. /package/dist/{tp.ui-NQEAKWUH.js.map → tp.ui-R6HVKCBC.js.map} +0 -0
  936. /package/dist/{tvs.density-HSVPDDGA.js.map → tvs.density-AQ5GD437.js.map} +0 -0
  937. /package/dist/{tvs.dt-U2MINIBH.js.map → tvs.dt-2263TBEJ.js.map} +0 -0
  938. /package/dist/{tvs.dtcnv.categorical-2OOAZJKC.js.map → tvs.dtcnv.categorical-TRRHL33N.js.map} +0 -0
  939. /package/dist/{tvs.dtcnv.continuous-5ETKBJ52.js.map → tvs.dtcnv.continuous-GREYNF52.js.map} +0 -0
  940. /package/dist/{tvs.dtfusion-EB4PPR3Y.js.map → tvs.dtfusion-XOX46L3M.js.map} +0 -0
  941. /package/dist/{tvs.dtsnvindel-IRQPTKQF.js.map → tvs.dtsnvindel-IDMXT53F.js.map} +0 -0
  942. /package/dist/{tvs.dtsv-TOVXZJCR.js.map → tvs.dtsv-ZDWFYH2C.js.map} +0 -0
  943. /package/dist/{tvs.numeric-ICUGA4WY.js.map → tvs.numeric-ZN2R7BH3.js.map} +0 -0
  944. /package/dist/{tvs.samplelst-4SCH543Y.js.map → tvs.samplelst-GAP76HRH.js.map} +0 -0
  945. /package/dist/{tvs.termCollection-GGN5F6HC.js.map → tvs.termCollection-GQ65UKSI.js.map} +0 -0
  946. /package/dist/{violin-7D7DN74I.js.map → violin-JGDL62YA.js.map} +0 -0
  947. /package/dist/{violin.integration.spec-KE76AL54.js.map → violin.integration.spec-W4NN7LBY.js.map} +0 -0
  948. /package/dist/{violin.interactivity-YPJ2H6SQ.js.map → violin.interactivity-H4RP4K5U.js.map} +0 -0
  949. /package/dist/{violin.renderer-UK7WSA2Z.js.map → violin.renderer-QPHLACDC.js.map} +0 -0
  950. /package/dist/{vocabulary-KLWZ6LRP.js.map → vocabulary-7JACY4J2.js.map} +0 -0
@@ -0,0 +1,2327 @@
1
+ import {
2
+ vcf2dstk
3
+ } from "./chunk-YUMPQ3CJ.js";
4
+ import {
5
+ getsjcharts
6
+ } from "./chunk-MKAF2BHB.js";
7
+ import {
8
+ parseheader,
9
+ parseline
10
+ } from "./chunk-RZ5JP44H.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-7FEHI46K.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-TCPU43TU.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-IGEQI6MR.js";
51
+ import {
52
+ category10_default
53
+ } from "./chunk-IH7ILDJS.js";
54
+ import {
55
+ ordinal
56
+ } from "./chunk-OAWQ6LOO.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-R6HVKCBC.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-R6HVKCBC.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-R6HVKCBC.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-RTC4U4PH.js.map