@sjcrh/proteinpaint-client 2.187.0 → 2.188.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (963) hide show
  1. package/dist/2dmaf-6YIEXAIG.js +1372 -0
  2. package/dist/AIProjectAdmin-5K5NIQNT.js +828 -0
  3. package/dist/AppHeader-4SN5M6SZ.js +834 -0
  4. package/dist/BoxPlot-DBJA6TQF.js +1218 -0
  5. package/dist/CorrelationVolcano-MDMTMTT5.js +618 -0
  6. package/dist/DE-S5AFNI4I.js +94 -0
  7. package/dist/DEinput-XVBBA74N.js +300 -0
  8. package/dist/DifferentialAnalysis-TUBGPAB2.js +244 -0
  9. package/dist/DifferentialAnalysis-TUBGPAB2.js.map +7 -0
  10. package/dist/Disco-VV7FQ7WW.js +3236 -0
  11. package/dist/Disco.UI-JDJFJFEY.js +244 -0
  12. package/dist/DmrPlot-XOG67W74.js +641 -0
  13. package/dist/GB-K3AWZQFF.js +1129 -0
  14. package/dist/GeneExpInput-Y7MDS2CA.js +365 -0
  15. package/dist/HicApp-53OTZ3YU.js +2249 -0
  16. package/dist/NumBinaryEditor-SB4YR3JM.js +269 -0
  17. package/dist/NumBinaryEditor.unit.spec-V2W2OZYP.js +285 -0
  18. package/dist/NumContEditor-RZZBM7PR.js +106 -0
  19. package/dist/NumContEditor.unit.spec-GAAW3ZZN.js +168 -0
  20. package/dist/NumCustomBinEditor-GFCGPRPI.js +37 -0
  21. package/dist/NumCustomBinEditor.unit.spec-24MXSO3L.js +283 -0
  22. package/dist/NumDiscreteEditor-HAHIOFNC.js +178 -0
  23. package/dist/NumDiscreteEditor.unit.spec-JYN2CWSI.js +201 -0
  24. package/dist/NumRegularBinEditor-7DOE64RB.js +37 -0
  25. package/dist/NumRegularBinEditor.unit.spec-2WU4GGNT.js +226 -0
  26. package/dist/NumSplineEditor-JLRD5TVX.js +191 -0
  27. package/dist/NumSplineEditor.unit.spec-LOG7CECJ.js +198 -0
  28. package/dist/NumericDensity-IDOP7I34.js +37 -0
  29. package/dist/NumericDensity.unit.spec-HTJQRPVH.js +220 -0
  30. package/dist/NumericHandler-DWVVGLLB.js +38 -0
  31. package/dist/NumericHandler.unit.spec-BDDFTHOF.js +218 -0
  32. package/dist/ProteomeInput-PK4ZM3SZ.js +395 -0
  33. package/dist/ProteomeInput-PK4ZM3SZ.js.map +7 -0
  34. package/dist/RunChart2-PBJ56YX3.js +757 -0
  35. package/dist/SC-UC3HP2MY.js +830 -0
  36. package/dist/SC-UC3HP2MY.js.map +7 -0
  37. package/dist/Volcano-BZJCA53R.js +1314 -0
  38. package/dist/Volcano-BZJCA53R.js.map +7 -0
  39. package/dist/WSIViewer-OHOP2DZT.js +48475 -0
  40. package/dist/WSIViewer-OHOP2DZT.js.map +7 -0
  41. package/dist/WsiSamplesPlot-FOMPMEXK.js +164 -0
  42. package/dist/adSandbox-SRPPCYYR.js +37 -0
  43. package/dist/alphaGenome-IS2WAJCK.js +174 -0
  44. package/dist/app-GTHYSGWI.js +36 -0
  45. package/dist/app-XEKETNLG.js +48 -0
  46. package/dist/app.js +20 -20
  47. package/dist/bam-GQBFL6A7.js +859 -0
  48. package/dist/barchart-AESC4JSX.js +46 -0
  49. package/dist/barchart.data-RE34IC4G.js +22 -0
  50. package/dist/barchart.events-KM4J5ISO.js +46 -0
  51. package/dist/barchart.integration.spec-DFVSBGO3.js +1676 -0
  52. package/dist/barchart2-NNTL4RQZ.js +310 -0
  53. package/dist/block-EHZM3FUX.js +6201 -0
  54. package/dist/block.init-EAEFNNF6.js +37 -0
  55. package/dist/block.mds.expressionrank-ZBHA2CFE.js +358 -0
  56. package/dist/block.mds.geneboxplot-4ZU3QUAK.js +827 -0
  57. package/dist/block.mds.junction-PDH55JXO.js +1544 -0
  58. package/dist/block.mds.svcnv-QWBU54XQ.js +6800 -0
  59. package/dist/block.svg-HUGBYWXU.js +163 -0
  60. package/dist/block.tk.aicheck-SDCWXQZF.js +282 -0
  61. package/dist/block.tk.ase-HMUTHCJS.js +364 -0
  62. package/dist/block.tk.bam-Q7B2YQLI.js +1905 -0
  63. package/dist/block.tk.bedgraphdot-QBGBSVHN.js +383 -0
  64. package/dist/block.tk.bigwig.ui-767A3MUH.js +211 -0
  65. package/dist/block.tk.hicstraw-LEZUZHLF.js +822 -0
  66. package/dist/block.tk.junction-GQHCZOYR.js +2363 -0
  67. package/dist/block.tk.junction.textmatrixui-D5QUO7KQ.js +198 -0
  68. package/dist/block.tk.ld-E3MHZOG5.js +98 -0
  69. package/dist/block.tk.menu-XE7PFYGR.js +1028 -0
  70. package/dist/block.tk.pgv-MPPMPDED.js +943 -0
  71. package/dist/brainImaging-YQ443NOL.js +422 -0
  72. package/dist/chunk-26WXJBSR.js +228 -0
  73. package/dist/chunk-2P6Z7JFC.js +119 -0
  74. package/dist/chunk-2QQO4RRD.js +2681 -0
  75. package/dist/chunk-2T7VYQLY.js +281 -0
  76. package/dist/chunk-2T7VYQLY.js.map +7 -0
  77. package/dist/chunk-2XPDA6NL.js +20652 -0
  78. package/dist/chunk-2XPDA6NL.js.map +7 -0
  79. package/dist/chunk-37ARSZOI.js +2815 -0
  80. package/dist/chunk-42Q53PXE.js +381 -0
  81. package/dist/chunk-46ASPS5Y.js +386 -0
  82. package/dist/chunk-4KPI7PB5.js +142 -0
  83. package/dist/chunk-4MDNMCGZ.js +102 -0
  84. package/dist/chunk-5IG3E4DT.js +272 -0
  85. package/dist/chunk-5MIR7IHI.js +52 -0
  86. package/dist/chunk-5MZVXJVA.js +55 -0
  87. package/dist/chunk-66D5GRS5.js +263 -0
  88. package/dist/chunk-6ATE2TRC.js +534 -0
  89. package/dist/chunk-6BFR6MK3.js +158 -0
  90. package/dist/chunk-6NJMCO4X.js +335 -0
  91. package/dist/chunk-6ON5KAMO.js +54 -0
  92. package/dist/chunk-76GPYMHZ.js +102 -0
  93. package/dist/chunk-7AAFBFOH.js +147 -0
  94. package/dist/chunk-7OOZHEUC.js +302 -0
  95. package/dist/chunk-A4VLWLYF.js +226 -0
  96. package/dist/chunk-A6EFWGWD.js +444 -0
  97. package/dist/chunk-ALW5XXVW.js +170 -0
  98. package/dist/chunk-ANCT2BGO.js +34 -0
  99. package/dist/chunk-AROMXWCY.js +291 -0
  100. package/dist/chunk-AY4UBGLC.js +815 -0
  101. package/dist/chunk-B43MTEYB.js +84 -0
  102. package/dist/chunk-B43MTEYB.js.map +7 -0
  103. package/dist/chunk-BMVLR3TM.js +1210 -0
  104. package/dist/chunk-BR7JA2EO.js +621 -0
  105. package/dist/chunk-C3SYSMNE.js +42 -0
  106. package/dist/chunk-C3SYSMNE.js.map +7 -0
  107. package/dist/chunk-D3HJXMTH.js +17 -0
  108. package/dist/chunk-DKUEZ4XD.js +205 -0
  109. package/dist/chunk-DT3MMC5U.js +31 -0
  110. package/dist/chunk-DYVKN7EE.js +5000 -0
  111. package/dist/chunk-EF37UZY6.js +37 -0
  112. package/dist/chunk-ESXMS7FW.js +229 -0
  113. package/dist/chunk-FDK4UJMN.js +263 -0
  114. package/dist/chunk-FDK4UJMN.js.map +7 -0
  115. package/dist/chunk-FUSVXQ6C.js +368 -0
  116. package/dist/chunk-G7JRRTS5.js +170 -0
  117. package/dist/chunk-G7JRRTS5.js.map +7 -0
  118. package/dist/chunk-GHWHLSUX.js +192 -0
  119. package/dist/chunk-GHWHLSUX.js.map +7 -0
  120. package/dist/chunk-GXKVAPGP.js +2786 -0
  121. package/dist/chunk-H4JIENLQ.js +39 -0
  122. package/dist/chunk-H7YJG4YM.js +470 -0
  123. package/dist/chunk-I24KPIDD.js +148 -0
  124. package/dist/chunk-IENFDUWD.js +203 -0
  125. package/dist/chunk-IKHIY6IZ.js +2327 -0
  126. package/dist/chunk-IKHIY6IZ.js.map +7 -0
  127. package/dist/chunk-J7BISJTL.js +50 -0
  128. package/dist/chunk-J7KYOSEK.js +824 -0
  129. package/dist/chunk-JGPZ5254.js +371 -0
  130. package/dist/chunk-JUIPCWAM.js +194 -0
  131. package/dist/chunk-LO4NMQ7W.js +293 -0
  132. package/dist/chunk-LSSLS5HV.js +95 -0
  133. package/dist/chunk-MDLRB3MR.js +407 -0
  134. package/dist/chunk-MJLKGZ27.js +129 -0
  135. package/dist/chunk-MYWJQRTD.js +1849 -0
  136. package/dist/chunk-MYWJQRTD.js.map +7 -0
  137. package/dist/chunk-NL5T3SBK.js +4209 -0
  138. package/dist/chunk-NMBIT4IK.js +46 -0
  139. package/dist/chunk-NMBIT4IK.js.map +7 -0
  140. package/dist/chunk-ONAYJVN2.js +217 -0
  141. package/dist/chunk-PP7K4R2E.js +141 -0
  142. package/dist/chunk-PP7K4R2E.js.map +7 -0
  143. package/dist/chunk-PSMFOARZ.js +14 -0
  144. package/dist/chunk-QX3GF2IA.js +514 -0
  145. package/dist/chunk-QZ2U4BOS.js +1159 -0
  146. package/dist/chunk-RBZBBNLL.js +1087 -0
  147. package/dist/chunk-RQ2ZJ66W.js +276 -0
  148. package/dist/chunk-RQ2ZJ66W.js.map +7 -0
  149. package/dist/chunk-RZTFQXWV.js +117 -0
  150. package/dist/chunk-SJC2C77V.js +177 -0
  151. package/dist/chunk-THUXB7EE.js +698 -0
  152. package/dist/chunk-THUXB7EE.js.map +7 -0
  153. package/dist/chunk-TVXVP4M6.js +215 -0
  154. package/dist/chunk-UTDPKDIY.js +482 -0
  155. package/dist/chunk-UVIUB7QI.js +280 -0
  156. package/dist/chunk-VAUSRBL5.js +6364 -0
  157. package/dist/chunk-VP3IZVQA.js +54 -0
  158. package/dist/chunk-VP3IZVQA.js.map +7 -0
  159. package/dist/chunk-WP22GYZ2.js +446 -0
  160. package/dist/chunk-WUNX3VST.js +1271 -0
  161. package/dist/chunk-X7GDCYND.js +1561 -0
  162. package/dist/chunk-X7GDCYND.js.map +7 -0
  163. package/dist/chunk-XB3V6S2X.js +1230 -0
  164. package/dist/chunk-XB3V6S2X.js.map +7 -0
  165. package/dist/chunk-XD4TBJK2.js +455 -0
  166. package/dist/chunk-Y6DSXMPB.js +121 -0
  167. package/dist/chunk-YBIZRASR.js +252 -0
  168. package/dist/chunk-YI2YH7ZK.js +158 -0
  169. package/dist/chunk-YLDE3PVC.js +1943 -0
  170. package/dist/chunk-Z736NYXL.js +26 -0
  171. package/dist/chunk-ZEJB7CPC.js +95 -0
  172. package/dist/chunk-ZGWEBKZ4.js +100 -0
  173. package/dist/condition-FSF6ROJV.js +331 -0
  174. package/dist/controls-OPSBFDFZ.js +40 -0
  175. package/dist/controls.config-3QRV5363.js +38 -0
  176. package/dist/correlation-WLOI7Z35.js +97 -0
  177. package/dist/cuminc-G2UGJUUA.js +1148 -0
  178. package/dist/cuminc.integration.spec-X5NEZ6S5.js +677 -0
  179. package/dist/customdata.inputui-RNW3AO3Z.js +288 -0
  180. package/dist/dataDownload-4U3TGDMH.js +329 -0
  181. package/dist/dataDownload.integration.spec-6FUI2SJ4.js +192 -0
  182. package/dist/databrowser.ui-4GVJVJWG.js +432 -0
  183. package/dist/dictionary-NSDS7Z4K.js +110 -0
  184. package/dist/dnaMethylation-OYQB75LD.js +37 -0
  185. package/dist/dnaMethylation.integration.spec-6TTLV34N.js +202 -0
  186. package/dist/dofetch-4TO3QMT6.js +50 -0
  187. package/dist/e2pca-NYBVR6PL.js +349 -0
  188. package/dist/ep-RTDVEA4D.js +1255 -0
  189. package/dist/expclust.gdc.spec-JVIRESTP.js +306 -0
  190. package/dist/facet-OVBF2QMO.js +520 -0
  191. package/dist/forms2-HTLS54CX.js +533 -0
  192. package/dist/gb-Y3546HMZ.js +87 -0
  193. package/dist/geneExpClustering-PH3PWH3K.js +248 -0
  194. package/dist/geneExpression-2Z2EV3XM.js +37 -0
  195. package/dist/geneExpression-6CFXOCGW.js +312 -0
  196. package/dist/geneExpression.unit.spec-WKUTHRHC.js +101 -0
  197. package/dist/geneORA-SHLZESLB.js +277 -0
  198. package/dist/geneVariant-FHZUIFPM.js +38 -0
  199. package/dist/geneVariant-Y7ZUBEOX.js +40 -0
  200. package/dist/geneVariant.integration.spec-N7TZUOY3.js +197 -0
  201. package/dist/genefusion.ui-7PDVZPZ2.js +308 -0
  202. package/dist/geneset-HLVOGYUI.js +202 -0
  203. package/dist/genomeBrowser.spec-7IVIMUR5.js +280 -0
  204. package/dist/grin2-2GNWIYFU.js +845 -0
  205. package/dist/grin2-2GNWIYFU.js.map +7 -0
  206. package/dist/grin2-Z5O7254R.js +1555 -0
  207. package/dist/gsea-TFC3MBRW.js +46 -0
  208. package/dist/hierCluster-ERSE5I4I.js +62 -0
  209. package/dist/hierCluster-QQZQU5ZG.js +58 -0
  210. package/dist/hierCluster.config-WPINWW37.js +39 -0
  211. package/dist/hierCluster.integration.spec-Y6OHSKPW.js +394 -0
  212. package/dist/hierCluster.interactivity-HS3G5QC5.js +53 -0
  213. package/dist/hierCluster.renderers-W63ZKZTT.js +21 -0
  214. package/dist/imagePlot-QFVN25PM.js +162 -0
  215. package/dist/importPlot-MIDM5APH.js +8 -0
  216. package/dist/isoformExpression-L4TRNT4A.js +39 -0
  217. package/dist/isoformExpression.unit.spec-QQG323LA.js +207 -0
  218. package/dist/launch.adhoc-4NQ6GGGL.js +41 -0
  219. package/dist/leftlabel.sample-JU7AIPZL.js +259 -0
  220. package/dist/legacyDataset-TT4CHF23.js +119 -0
  221. package/dist/lollipop-JG74M6PJ.js +170 -0
  222. package/dist/maf-PDL2EGHI.js +451 -0
  223. package/dist/maftimeline-V43NQEEE.js +592 -0
  224. package/dist/matrix-EB2EFP4S.js +57 -0
  225. package/dist/matrix-Q57FU5FE.js +62 -0
  226. package/dist/matrix.cells-NJIMPD32.js +28 -0
  227. package/dist/matrix.config-GLDEQD3H.js +40 -0
  228. package/dist/matrix.data-6SHAKOQU.js +25 -0
  229. package/dist/matrix.groups-MTDEANQA.js +26 -0
  230. package/dist/matrix.integration.spec-JCZ5VQJU.js +3071 -0
  231. package/dist/matrix.interactivity-SVRNWL6V.js +41 -0
  232. package/dist/matrix.layout-2HREO42N.js +43 -0
  233. package/dist/matrix.legend-QHVKT3MP.js +22 -0
  234. package/dist/matrix.renderers-IYR3ZY6V.js +37 -0
  235. package/dist/matrix.serieses-2VMTQXL2.js +21 -0
  236. package/dist/matrix.sort-PWA2RQQR.js +27 -0
  237. package/dist/matrix.sort.unit.spec-3OYIPTFY.js +471 -0
  238. package/dist/matrix.sorterUi-Y5QLO75X.js +18 -0
  239. package/dist/matrix.sorterUi.unit.spec-BNEXQHLP.js +341 -0
  240. package/dist/mavb-IZDDU4KK.js +731 -0
  241. package/dist/mds.fimo-FWBL7JE6.js +517 -0
  242. package/dist/mds.samplescatterplot-T47C7DJB.js +1549 -0
  243. package/dist/mds.survivalplot-MFZJCGS6.js +482 -0
  244. package/dist/numericDictTermCluster-I2W67RGA.js +72 -0
  245. package/dist/oncomatrix-6W7IBAED.js +294 -0
  246. package/dist/oncomatrix.spec-CEFH5IGH.js +447 -0
  247. package/dist/plot.2dvaf-BN6CFLNU.js +376 -0
  248. package/dist/plot.app-7EYWUCZV.js +40 -0
  249. package/dist/plot.barplot-MDIARSQD.js +101 -0
  250. package/dist/plot.boxplot-RUHGXC54.js +151 -0
  251. package/dist/plot.brainImaging-JEE32ZBV.js +51 -0
  252. package/dist/plot.disco-2RPNPX6E.js +101 -0
  253. package/dist/plot.dzi-7VTYYGGW.js +33 -0
  254. package/dist/plot.ssgq-FHE5KU5C.js +138 -0
  255. package/dist/plot.vaf2cov-WDJJM5Q4.js +258 -0
  256. package/dist/plot.wsi-FQZWHNSF.js +36 -0
  257. package/dist/polar-M7EGINN4.js +185 -0
  258. package/dist/polar2-JFYY43K2.js +227 -0
  259. package/dist/profile.spec-SIOHASOX.js +79 -0
  260. package/dist/profileBarchart-6JLEKVJV.js +266 -0
  261. package/dist/profileForms-G6CH73RV.js +440 -0
  262. package/dist/profilePlot-NQYJOBVV.js +53 -0
  263. package/dist/profileRadar-4TNWIXDB.js +262 -0
  264. package/dist/profileRadarFacility-XPH3LCBQ.js +262 -0
  265. package/dist/proteinView-OZLHO45J.js +1222 -0
  266. package/dist/proteinView-OZLHO45J.js.map +7 -0
  267. package/dist/proteomeAbundance-NQ4635NL.js +12 -0
  268. package/dist/proteomeAbundance-OV24UTZN.js +59 -0
  269. package/dist/proteomeAbundance-OV24UTZN.js.map +7 -0
  270. package/dist/qualitative-DL4WJG3O.js +42 -0
  271. package/dist/radar2-YNOQWHBT.js +315 -0
  272. package/dist/radarFacility2-24UPSI7S.js +324 -0
  273. package/dist/regression-URAUTLTD.js +55 -0
  274. package/dist/regression.inputs-UDVOU7FB.js +47 -0
  275. package/dist/regression.inputs.term-BWW6W34R.js +47 -0
  276. package/dist/regression.inputs.values.table-UKGIZTXG.js +44 -0
  277. package/dist/regression.integration.spec-EBHQTNA3.js +783 -0
  278. package/dist/regression.results-XTOSWIP6.js +39 -0
  279. package/dist/regression.spec-KG2I53VR.js +707 -0
  280. package/dist/report-KH7SNPVF.js +221 -0
  281. package/dist/sampleScatter.spec-PIXGS3LG.js +201 -0
  282. package/dist/sampleView-TWS6VT55.js +47 -0
  283. package/dist/samplelst-6AB5Y4WR.js +110 -0
  284. package/dist/samplematrix-AJAF555E.js +2197 -0
  285. package/dist/sc-PMNYZKXA.js +85 -0
  286. package/dist/scatter-Q2GH3ZJD.js +801 -0
  287. package/dist/scatter.integration.spec-SMMYKWH3.js +1195 -0
  288. package/dist/selectGenomeWithTklst-VE4SDYY7.js +133 -0
  289. package/dist/singleCellCellType-S324GCKW.js +37 -0
  290. package/dist/singleCellCellType.unit.spec-NXC2GELH.js +159 -0
  291. package/dist/singleCellGeneExpression-6H4HRKIA.js +37 -0
  292. package/dist/singleCellGeneExpression.unit.spec-HIJXVUWJ.js +152 -0
  293. package/dist/singleCellPlot-H7PCZ2DP.js +52 -0
  294. package/dist/singlecell-4LH3MQVL.js +85 -0
  295. package/dist/singlecell-MOSYT3RI.js +1571 -0
  296. package/dist/snp-IKLGTD4Q.js +37 -0
  297. package/dist/snp.unit.spec-GC74MUVM.js +175 -0
  298. package/dist/snplocus-RIABFSBQ.js +207 -0
  299. package/dist/spliceevent.a53ss.diagram-4E2IYYHL.js +150 -0
  300. package/dist/spliceevent.exonskip.diagram-C56R6XLQ.js +276 -0
  301. package/dist/spliceevent.noeventdiagram-SIPMAKXI.js +459 -0
  302. package/dist/ssGSEA-5QNHLSOI.js +37 -0
  303. package/dist/ssGSEA.unit.spec-KVPN553B.js +87 -0
  304. package/dist/summarizeCnvGeneexp-K4VGJSW6.js +162 -0
  305. package/dist/summarizeGeneexpSurvival-HGHX65FN.js +107 -0
  306. package/dist/summarizeMutationCnv-3K4Z6R2X.js +163 -0
  307. package/dist/summarizeMutationDiagnosis-M2MHUPRT.js +39 -0
  308. package/dist/summarizeMutationSurvival-WVBUP3GA.js +98 -0
  309. package/dist/summary-RZHZXCU5.js +48 -0
  310. package/dist/summary.integration.spec-FGZP7DY7.js +413 -0
  311. package/dist/summaryInput-UGM7MMCR.js +234 -0
  312. package/dist/sunburst-L27U7LV7.js +283 -0
  313. package/dist/survival-5ZMEBV6O.js +57 -0
  314. package/dist/survival-JWRRGTJT.js +45 -0
  315. package/dist/survival.integration.spec-Z5542I4V.js +801 -0
  316. package/dist/svgraph-O6ZVLNNN.js +1386 -0
  317. package/dist/svmr-ULFV7OSH.js +3841 -0
  318. package/dist/table-CHRQH2GH.js +199 -0
  319. package/dist/termCollection-FAO6ZA6F.js +178 -0
  320. package/dist/termCollection-GBXS3GOY.js +37 -0
  321. package/dist/termCollection.unit.spec-4WRTOV6E.js +207 -0
  322. package/dist/tk-KNUBWRNK.js +45 -0
  323. package/dist/tp.ui-2PPYOQYL.js +1458 -0
  324. package/dist/tvs.density-BZ5SKDQS.js +18 -0
  325. package/dist/tvs.dt-TDNSTGQR.js +38 -0
  326. package/dist/tvs.dtcnv.categorical-P2IGIE4I.js +39 -0
  327. package/dist/tvs.dtcnv.continuous-2XUCRBDR.js +71 -0
  328. package/dist/tvs.dtfusion-PRHZVMOG.js +39 -0
  329. package/dist/tvs.dtsnvindel-KGKBW5JS.js +39 -0
  330. package/dist/tvs.dtsv-M3CY5TZF.js +39 -0
  331. package/dist/tvs.numeric-W74JCC5P.js +21 -0
  332. package/dist/tvs.samplelst-BTWFBBAN.js +103 -0
  333. package/dist/tvs.termCollection-Y64QIKOA.js +158 -0
  334. package/dist/violin-3LLHHV3L.js +45 -0
  335. package/dist/violin.integration.spec-6NF5FDLQ.js +1424 -0
  336. package/dist/violin.interactivity-W2AKZ24D.js +37 -0
  337. package/dist/violin.renderer-CRFYYZRI.js +39 -0
  338. package/dist/vocabulary-AUJOAVYS.js +40 -0
  339. package/package.json +4 -3
  340. package/dist/2dmaf-DTWWXOZC.js +0 -1372
  341. package/dist/AIProjectAdmin-BCYIWOXD.js +0 -828
  342. package/dist/AppHeader-H3L2MRWP.js +0 -834
  343. package/dist/BoxPlot-INZ6IN3V.js +0 -1218
  344. package/dist/CorrelationVolcano-AK3XW4ZH.js +0 -618
  345. package/dist/DE-IBSFUKNG.js +0 -94
  346. package/dist/DEinput-H4GMQWDY.js +0 -300
  347. package/dist/DifferentialAnalysis-3DSL5LQC.js +0 -243
  348. package/dist/DifferentialAnalysis-3DSL5LQC.js.map +0 -7
  349. package/dist/Disco-5PXXMGGQ.js +0 -3236
  350. package/dist/Disco.UI-23LOT2U6.js +0 -244
  351. package/dist/DmrPlot-PBCU2XNF.js +0 -641
  352. package/dist/GB-HIEPWNPV.js +0 -1129
  353. package/dist/GeneExpInput-A4JNX7PU.js +0 -365
  354. package/dist/HicApp-IDH2A4BC.js +0 -2249
  355. package/dist/NumBinaryEditor-CZ54X7J3.js +0 -269
  356. package/dist/NumBinaryEditor.unit.spec-QLBRM7MJ.js +0 -285
  357. package/dist/NumContEditor-Z5MGLQ2I.js +0 -106
  358. package/dist/NumContEditor.unit.spec-TR7D7ULV.js +0 -168
  359. package/dist/NumCustomBinEditor-B7JID42Y.js +0 -37
  360. package/dist/NumCustomBinEditor.unit.spec-GZJIVY4K.js +0 -283
  361. package/dist/NumDiscreteEditor-LWHZ36T6.js +0 -178
  362. package/dist/NumDiscreteEditor.unit.spec-QCQCMEWO.js +0 -201
  363. package/dist/NumRegularBinEditor-IATRIUKD.js +0 -37
  364. package/dist/NumRegularBinEditor.unit.spec-J6UTQO76.js +0 -226
  365. package/dist/NumSplineEditor-2KMU6SRO.js +0 -191
  366. package/dist/NumSplineEditor.unit.spec-MX7Y4MTD.js +0 -198
  367. package/dist/NumericDensity-JCH7F5FV.js +0 -37
  368. package/dist/NumericDensity.unit.spec-4TKKRKHF.js +0 -220
  369. package/dist/NumericHandler-7FB3RJM7.js +0 -38
  370. package/dist/NumericHandler.unit.spec-U6DCADZY.js +0 -218
  371. package/dist/RunChart2-VQTIVMKM.js +0 -757
  372. package/dist/SC-XW272KAP.js +0 -827
  373. package/dist/SC-XW272KAP.js.map +0 -7
  374. package/dist/Volcano-Y4U3L6D2.js +0 -1352
  375. package/dist/Volcano-Y4U3L6D2.js.map +0 -7
  376. package/dist/WSIViewer-UFB7TI2D.js +0 -47972
  377. package/dist/WSIViewer-UFB7TI2D.js.map +0 -7
  378. package/dist/WsiSamplesPlot-2OAR57YB.js +0 -164
  379. package/dist/adSandbox-IKKFYRF7.js +0 -37
  380. package/dist/alphaGenome-WJNFQGGK.js +0 -174
  381. package/dist/app-UHGTFH6D.js +0 -48
  382. package/dist/app-YETYAR45.js +0 -36
  383. package/dist/bam-S6U7VNJP.js +0 -859
  384. package/dist/barchart-3NJDGHXU.js +0 -46
  385. package/dist/barchart.data-MVVKPDLE.js +0 -22
  386. package/dist/barchart.events-WQGA4CGB.js +0 -46
  387. package/dist/barchart.integration.spec-E6CJTWRN.js +0 -1676
  388. package/dist/barchart2-UNHFOYKB.js +0 -310
  389. package/dist/block-2XHZLY26.js +0 -6201
  390. package/dist/block.init-CMG4V6RB.js +0 -37
  391. package/dist/block.mds.expressionrank-QX2JOEMV.js +0 -358
  392. package/dist/block.mds.geneboxplot-USVQSDBT.js +0 -827
  393. package/dist/block.mds.junction-R6GJO75N.js +0 -1544
  394. package/dist/block.mds.svcnv-MRISSDAX.js +0 -6800
  395. package/dist/block.svg-Z5KKZTDB.js +0 -163
  396. package/dist/block.tk.aicheck-SOFJYYZX.js +0 -282
  397. package/dist/block.tk.ase-EHX5FV2Y.js +0 -364
  398. package/dist/block.tk.bam-DJS6LODM.js +0 -1905
  399. package/dist/block.tk.bedgraphdot-R2YHPXZA.js +0 -383
  400. package/dist/block.tk.bigwig.ui-VPEEQJLS.js +0 -211
  401. package/dist/block.tk.hicstraw-BDYN573B.js +0 -822
  402. package/dist/block.tk.junction-BONB4BXU.js +0 -2363
  403. package/dist/block.tk.junction.textmatrixui-Y5R6KY4N.js +0 -198
  404. package/dist/block.tk.ld-EGVVSXCB.js +0 -98
  405. package/dist/block.tk.menu-4YBMB5JT.js +0 -1028
  406. package/dist/block.tk.pgv-SBHGL6UH.js +0 -943
  407. package/dist/brainImaging-G3WZDYG6.js +0 -422
  408. package/dist/chunk-2K5DSRBJ.js +0 -84
  409. package/dist/chunk-2K5DSRBJ.js.map +0 -7
  410. package/dist/chunk-2O6JF76T.js +0 -121
  411. package/dist/chunk-2QULGYVE.js +0 -368
  412. package/dist/chunk-2VLGHVOL.js +0 -215
  413. package/dist/chunk-32TTOWY6.js +0 -1210
  414. package/dist/chunk-43PMSEMV.js +0 -50
  415. package/dist/chunk-4KSU6NBP.js +0 -194
  416. package/dist/chunk-4SFX42S7.js +0 -1271
  417. package/dist/chunk-4Y444IRJ.js +0 -272
  418. package/dist/chunk-56AN5PPQ.js +0 -679
  419. package/dist/chunk-56AN5PPQ.js.map +0 -7
  420. package/dist/chunk-5FO3NKA4.js +0 -155
  421. package/dist/chunk-5FO3NKA4.js.map +0 -7
  422. package/dist/chunk-5HOR6JQ2.js +0 -100
  423. package/dist/chunk-5LZKQFLO.js +0 -180
  424. package/dist/chunk-5LZKQFLO.js.map +0 -7
  425. package/dist/chunk-5RE3J6HK.js +0 -293
  426. package/dist/chunk-5SMOOFRW.js +0 -386
  427. package/dist/chunk-64Z22QAH.js +0 -14
  428. package/dist/chunk-6NMH6WPB.js +0 -446
  429. package/dist/chunk-7FKIAQ4K.js +0 -17
  430. package/dist/chunk-7NOKTEHK.js +0 -407
  431. package/dist/chunk-7UHUOC6F.js +0 -119
  432. package/dist/chunk-AMYSEKPF.js +0 -1658
  433. package/dist/chunk-AMYSEKPF.js.map +0 -7
  434. package/dist/chunk-ANGDY7VC.js +0 -170
  435. package/dist/chunk-AQ4OP4GR.js +0 -39
  436. package/dist/chunk-AQVOYTLS.js +0 -177
  437. package/dist/chunk-ARINZFQG.js +0 -276
  438. package/dist/chunk-ARINZFQG.js.map +0 -7
  439. package/dist/chunk-BQJVLXEL.js +0 -55
  440. package/dist/chunk-BRMASRRS.js +0 -455
  441. package/dist/chunk-BT4OOYPT.js +0 -280
  442. package/dist/chunk-BTJFVY3R.js +0 -190
  443. package/dist/chunk-BTJFVY3R.js.map +0 -7
  444. package/dist/chunk-C62CSWMV.js +0 -335
  445. package/dist/chunk-CAWDQURD.js +0 -6364
  446. package/dist/chunk-DMAHNBGN.js +0 -1230
  447. package/dist/chunk-DMAHNBGN.js.map +0 -7
  448. package/dist/chunk-EGWVYY7K.js +0 -264
  449. package/dist/chunk-EGWVYY7K.js.map +0 -7
  450. package/dist/chunk-ENWVV6EU.js +0 -2681
  451. package/dist/chunk-EPOELG75.js +0 -56
  452. package/dist/chunk-EPOELG75.js.map +0 -7
  453. package/dist/chunk-FA44G3GZ.js +0 -470
  454. package/dist/chunk-GD7FKXOA.js +0 -148
  455. package/dist/chunk-GF4OSOYW.js +0 -2815
  456. package/dist/chunk-GQOBT2W7.js +0 -203
  457. package/dist/chunk-GTBL7UHX.js +0 -2786
  458. package/dist/chunk-HE7CD7BD.js +0 -482
  459. package/dist/chunk-I7JDV4ZC.js +0 -226
  460. package/dist/chunk-IABWKPRK.js +0 -534
  461. package/dist/chunk-IPDH4FHY.js +0 -54
  462. package/dist/chunk-JNOOLCYB.js +0 -1159
  463. package/dist/chunk-JPKYHLNI.js +0 -158
  464. package/dist/chunk-KMQ6GQ3I.js +0 -1943
  465. package/dist/chunk-KTCW3JA6.js +0 -4209
  466. package/dist/chunk-L4QG7XZE.js +0 -46
  467. package/dist/chunk-L4QG7XZE.js.map +0 -7
  468. package/dist/chunk-LGUE54VX.js +0 -302
  469. package/dist/chunk-LJ4AUJXC.js +0 -95
  470. package/dist/chunk-LN3QYBGI.js +0 -20495
  471. package/dist/chunk-LN3QYBGI.js.map +0 -7
  472. package/dist/chunk-LQQSRNR5.js +0 -228
  473. package/dist/chunk-LSV4Z473.js +0 -31
  474. package/dist/chunk-LTSR7SLO.js +0 -514
  475. package/dist/chunk-LY7GD74F.js +0 -381
  476. package/dist/chunk-MHCTLVGE.js +0 -26
  477. package/dist/chunk-MSAMGAQF.js +0 -2370
  478. package/dist/chunk-MSAMGAQF.js.map +0 -7
  479. package/dist/chunk-NYX4B5CO.js +0 -291
  480. package/dist/chunk-OPPNZXYG.js +0 -129
  481. package/dist/chunk-P6TPXUMP.js +0 -117
  482. package/dist/chunk-PL2CM7RY.js +0 -621
  483. package/dist/chunk-PSGQWZN4.js +0 -147
  484. package/dist/chunk-PZLYNNST.js +0 -371
  485. package/dist/chunk-RA4RQYXQ.js +0 -142
  486. package/dist/chunk-RAJZYWFN.js +0 -95
  487. package/dist/chunk-ROLVOPVR.js +0 -252
  488. package/dist/chunk-RQZJIBIH.js +0 -34
  489. package/dist/chunk-RSE2FOKW.js +0 -217
  490. package/dist/chunk-SDLRTORS.js +0 -263
  491. package/dist/chunk-TF4EDNQO.js +0 -158
  492. package/dist/chunk-TV74I3Y5.js +0 -43
  493. package/dist/chunk-TV74I3Y5.js.map +0 -7
  494. package/dist/chunk-UPPBAFUK.js +0 -5000
  495. package/dist/chunk-UVPAZM3G.js +0 -52
  496. package/dist/chunk-UWYCEYML.js +0 -815
  497. package/dist/chunk-VB3SRNBK.js +0 -37
  498. package/dist/chunk-W6XQR5UL.js +0 -444
  499. package/dist/chunk-XBBUQW52.js +0 -824
  500. package/dist/chunk-XSA3VIEQ.js +0 -205
  501. package/dist/chunk-XZ6MGJQ3.js +0 -102
  502. package/dist/chunk-YC6ZJ7RP.js +0 -1842
  503. package/dist/chunk-YC6ZJ7RP.js.map +0 -7
  504. package/dist/chunk-YEMIL6QU.js +0 -1087
  505. package/dist/chunk-ZD47FENE.js +0 -229
  506. package/dist/chunk-ZYBM24FU.js +0 -102
  507. package/dist/chunk-ZYY54HBU.js +0 -330
  508. package/dist/chunk-ZYY54HBU.js.map +0 -7
  509. package/dist/condition-ARCN26MF.js +0 -331
  510. package/dist/controls-PKWN2JGN.js +0 -40
  511. package/dist/controls.config-NFRPXFUJ.js +0 -38
  512. package/dist/correlation-DPT6XL2U.js +0 -97
  513. package/dist/cuminc-M4U7LQD5.js +0 -1148
  514. package/dist/cuminc.integration.spec-MH4OFYDJ.js +0 -677
  515. package/dist/customdata.inputui-6TAHAMSV.js +0 -288
  516. package/dist/dataDownload-7GZEYSUT.js +0 -329
  517. package/dist/dataDownload.integration.spec-NAIJRFTV.js +0 -192
  518. package/dist/databrowser.ui-LLXHZ5O6.js +0 -432
  519. package/dist/dictionary-MUAURMYE.js +0 -110
  520. package/dist/dnaMethylation-AU5D3U3E.js +0 -37
  521. package/dist/dnaMethylation.integration.spec-JIDBRA6P.js +0 -202
  522. package/dist/dofetch-WSYK5OTB.js +0 -50
  523. package/dist/e2pca-ICG35YR5.js +0 -349
  524. package/dist/ep-CSSSQOUP.js +0 -1255
  525. package/dist/expclust.gdc.spec-4WPQUXH4.js +0 -306
  526. package/dist/facet-JAGILNY6.js +0 -520
  527. package/dist/forms2-IMVDB6AT.js +0 -533
  528. package/dist/gb-36LTYICV.js +0 -87
  529. package/dist/geneExpClustering-CGMENTHI.js +0 -248
  530. package/dist/geneExpression-AD2L46J4.js +0 -37
  531. package/dist/geneExpression-G2FHBDUQ.js +0 -312
  532. package/dist/geneExpression.unit.spec-XWCB7K5L.js +0 -101
  533. package/dist/geneORA-GVHQF7DF.js +0 -277
  534. package/dist/geneVariant-HE22CH76.js +0 -40
  535. package/dist/geneVariant-SQD5QUFH.js +0 -38
  536. package/dist/geneVariant.integration.spec-66XFLDNN.js +0 -197
  537. package/dist/genefusion.ui-TD32NWD4.js +0 -308
  538. package/dist/geneset-NSYPDXS3.js +0 -202
  539. package/dist/genomeBrowser.spec-CYFONLNQ.js +0 -280
  540. package/dist/grin2-3QB57OPH.js +0 -1555
  541. package/dist/grin2-FLQNWPMZ.js +0 -851
  542. package/dist/grin2-FLQNWPMZ.js.map +0 -7
  543. package/dist/gsea-RMTU5I3U.js +0 -46
  544. package/dist/hierCluster-LSQL6PGC.js +0 -58
  545. package/dist/hierCluster-XTEBDEVO.js +0 -62
  546. package/dist/hierCluster.config-SHXFSPOH.js +0 -39
  547. package/dist/hierCluster.integration.spec-KNMIYWV3.js +0 -394
  548. package/dist/hierCluster.interactivity-6NAKTUR5.js +0 -53
  549. package/dist/hierCluster.renderers-FWOV4Q47.js +0 -21
  550. package/dist/imagePlot-3IVG4SFN.js +0 -162
  551. package/dist/importPlot-HEMDRIVF.js +0 -8
  552. package/dist/isoformExpression-FJ3GEU6D.js +0 -39
  553. package/dist/isoformExpression.unit.spec-L7D22UDB.js +0 -207
  554. package/dist/launch.adhoc-PDGQF2UP.js +0 -41
  555. package/dist/leftlabel.sample-ZBI4NHCV.js +0 -259
  556. package/dist/legacyDataset-PBCPC5I7.js +0 -119
  557. package/dist/lollipop-K7S6ASFE.js +0 -170
  558. package/dist/maf-JEW6PPJB.js +0 -451
  559. package/dist/maftimeline-7URL27MC.js +0 -592
  560. package/dist/matrix-6EK5WGIG.js +0 -57
  561. package/dist/matrix-DKBD5RIL.js +0 -62
  562. package/dist/matrix.cells-KEIOXJQ7.js +0 -28
  563. package/dist/matrix.config-FGJB4VVM.js +0 -40
  564. package/dist/matrix.data-QGCGFLD7.js +0 -25
  565. package/dist/matrix.groups-HBPLZ2QX.js +0 -26
  566. package/dist/matrix.integration.spec-R4PF67KF.js +0 -3071
  567. package/dist/matrix.interactivity-M3SY33ET.js +0 -41
  568. package/dist/matrix.layout-H6WQ3ZMW.js +0 -43
  569. package/dist/matrix.legend-UCL7HM26.js +0 -22
  570. package/dist/matrix.renderers-3PPFSS7Z.js +0 -37
  571. package/dist/matrix.serieses-S2TJ3E6P.js +0 -21
  572. package/dist/matrix.sort-CFA4UWBJ.js +0 -27
  573. package/dist/matrix.sort.unit.spec-562VIWDS.js +0 -471
  574. package/dist/matrix.sorterUi-FT7K5664.js +0 -18
  575. package/dist/matrix.sorterUi.unit.spec-GAHHUN3K.js +0 -341
  576. package/dist/mavb-HPW5X55U.js +0 -731
  577. package/dist/mds.fimo-HSBKLIOX.js +0 -517
  578. package/dist/mds.samplescatterplot-DE27OMJE.js +0 -1549
  579. package/dist/mds.survivalplot-IW22UGCE.js +0 -482
  580. package/dist/numericDictTermCluster-DOD66G3A.js +0 -72
  581. package/dist/oncomatrix-BZCVCPR4.js +0 -294
  582. package/dist/oncomatrix.spec-IHYCIAP4.js +0 -447
  583. package/dist/plot.2dvaf-QLOZ54VC.js +0 -376
  584. package/dist/plot.app-XDVDR23J.js +0 -40
  585. package/dist/plot.barplot-XOESF7OQ.js +0 -101
  586. package/dist/plot.boxplot-VNOC2CHT.js +0 -151
  587. package/dist/plot.brainImaging-7ZEOY4UR.js +0 -51
  588. package/dist/plot.disco-6GVDYK7A.js +0 -101
  589. package/dist/plot.dzi-TEFPPPL6.js +0 -33
  590. package/dist/plot.ssgq-OG4TODLO.js +0 -138
  591. package/dist/plot.vaf2cov-VMZRJULA.js +0 -258
  592. package/dist/plot.wsi-2CHZZ7AC.js +0 -36
  593. package/dist/polar-QUYQRQOQ.js +0 -185
  594. package/dist/polar2-OXXLAXJC.js +0 -227
  595. package/dist/profile.spec-TI6PRHNJ.js +0 -79
  596. package/dist/profileBarchart-GEK77XEB.js +0 -266
  597. package/dist/profileForms-NR3VNHKM.js +0 -440
  598. package/dist/profilePlot-GGKO3IW5.js +0 -53
  599. package/dist/profileRadar-MN3LX5ER.js +0 -262
  600. package/dist/profileRadarFacility-3G2HWB2L.js +0 -262
  601. package/dist/proteinView-TZ5BGOTA.js +0 -1188
  602. package/dist/proteinView-TZ5BGOTA.js.map +0 -7
  603. package/dist/proteomeAbundance-JXNECXF7.js +0 -68
  604. package/dist/proteomeAbundance-JXNECXF7.js.map +0 -7
  605. package/dist/proteomeAbundance-O4BB55O3.js +0 -21
  606. package/dist/qualitative-Q3TT73O7.js +0 -42
  607. package/dist/radar2-LSD3VPZT.js +0 -315
  608. package/dist/radarFacility2-LZGIXY7A.js +0 -324
  609. package/dist/regression-J3XDAPAZ.js +0 -55
  610. package/dist/regression.inputs-BBZYI5OI.js +0 -47
  611. package/dist/regression.inputs.term-7BW6XGLG.js +0 -47
  612. package/dist/regression.inputs.values.table-DYX2YU4H.js +0 -44
  613. package/dist/regression.integration.spec-WLXZYKWW.js +0 -783
  614. package/dist/regression.results-K5Q2N2KW.js +0 -39
  615. package/dist/regression.spec-VT7T6KBY.js +0 -707
  616. package/dist/report-3D3L573D.js +0 -221
  617. package/dist/sampleScatter.spec-6IPJQLM2.js +0 -201
  618. package/dist/sampleView-5JMFI4HF.js +0 -47
  619. package/dist/samplelst-SUCB5WOZ.js +0 -110
  620. package/dist/samplematrix-A5SZBKO6.js +0 -2197
  621. package/dist/sc-NAA6ESO6.js +0 -85
  622. package/dist/scatter-EQCN2HYE.js +0 -801
  623. package/dist/scatter.integration.spec-7NXIYS67.js +0 -1195
  624. package/dist/selectGenomeWithTklst-KXODNCY6.js +0 -133
  625. package/dist/singleCellCellType-HMIW76YB.js +0 -37
  626. package/dist/singleCellCellType.unit.spec-ZCZET56X.js +0 -159
  627. package/dist/singleCellGeneExpression-IUCUHF6R.js +0 -37
  628. package/dist/singleCellGeneExpression.unit.spec-J4D6F2N3.js +0 -152
  629. package/dist/singleCellPlot-L6W3MDGG.js +0 -52
  630. package/dist/singlecell-A6ECAAPI.js +0 -85
  631. package/dist/singlecell-KBABNXC5.js +0 -1571
  632. package/dist/snp-RO7ATG6E.js +0 -37
  633. package/dist/snp.unit.spec-ZJLRGJD4.js +0 -175
  634. package/dist/snplocus-N3CU6NRP.js +0 -207
  635. package/dist/spliceevent.a53ss.diagram-7PHT4COB.js +0 -150
  636. package/dist/spliceevent.exonskip.diagram-3CZTY6QD.js +0 -276
  637. package/dist/spliceevent.noeventdiagram-GQE256DT.js +0 -459
  638. package/dist/ssGSEA-4I3L5MX2.js +0 -37
  639. package/dist/ssGSEA.unit.spec-PZCC5YU7.js +0 -87
  640. package/dist/summarizeCnvGeneexp-ASXUQW56.js +0 -162
  641. package/dist/summarizeGeneexpSurvival-ULGUOW5V.js +0 -107
  642. package/dist/summarizeMutationCnv-VDUCIUGM.js +0 -163
  643. package/dist/summarizeMutationDiagnosis-FMAAMCZC.js +0 -39
  644. package/dist/summarizeMutationSurvival-GZ4NGDJT.js +0 -98
  645. package/dist/summary-2WNZ6JSB.js +0 -48
  646. package/dist/summary.integration.spec-XPMYB6GM.js +0 -413
  647. package/dist/summaryInput-2UGXEA5C.js +0 -234
  648. package/dist/sunburst-76WCQLTT.js +0 -283
  649. package/dist/survival-23IZM4ML.js +0 -45
  650. package/dist/survival-3EAMPHSX.js +0 -57
  651. package/dist/survival.integration.spec-YNVAKBV3.js +0 -801
  652. package/dist/svgraph-G2M5LXEP.js +0 -1386
  653. package/dist/svmr-BUDBVU34.js +0 -3841
  654. package/dist/table-QJSZ6YFK.js +0 -199
  655. package/dist/termCollection-2YAY3RLZ.js +0 -178
  656. package/dist/termCollection-MAMDMEDD.js +0 -37
  657. package/dist/termCollection.unit.spec-UY7G2BHG.js +0 -207
  658. package/dist/tk-GFGP3F76.js +0 -45
  659. package/dist/tp.ui-OQ757UIE.js +0 -1458
  660. package/dist/tvs.density-BJK23JYJ.js +0 -18
  661. package/dist/tvs.dt-TOYEFKNT.js +0 -38
  662. package/dist/tvs.dtcnv.categorical-EO2VLFL2.js +0 -39
  663. package/dist/tvs.dtcnv.continuous-ZAHTKZ4Y.js +0 -71
  664. package/dist/tvs.dtfusion-BY3AHBL3.js +0 -39
  665. package/dist/tvs.dtsnvindel-UM5LQ4FR.js +0 -39
  666. package/dist/tvs.dtsv-H7ZVHLS5.js +0 -39
  667. package/dist/tvs.numeric-66FP6RRH.js +0 -21
  668. package/dist/tvs.samplelst-Q5ECTZOY.js +0 -103
  669. package/dist/tvs.termCollection-FYNMKZTR.js +0 -158
  670. package/dist/violin-EGWLAJVM.js +0 -45
  671. package/dist/violin.integration.spec-3P4TYHBR.js +0 -1424
  672. package/dist/violin.interactivity-VWDR4LYB.js +0 -37
  673. package/dist/violin.renderer-WWTU6J7X.js +0 -39
  674. package/dist/vocabulary-JG4ZITOH.js +0 -40
  675. /package/dist/{2dmaf-DTWWXOZC.js.map → 2dmaf-6YIEXAIG.js.map} +0 -0
  676. /package/dist/{AIProjectAdmin-BCYIWOXD.js.map → AIProjectAdmin-5K5NIQNT.js.map} +0 -0
  677. /package/dist/{AppHeader-H3L2MRWP.js.map → AppHeader-4SN5M6SZ.js.map} +0 -0
  678. /package/dist/{BoxPlot-INZ6IN3V.js.map → BoxPlot-DBJA6TQF.js.map} +0 -0
  679. /package/dist/{CorrelationVolcano-AK3XW4ZH.js.map → CorrelationVolcano-MDMTMTT5.js.map} +0 -0
  680. /package/dist/{DE-IBSFUKNG.js.map → DE-S5AFNI4I.js.map} +0 -0
  681. /package/dist/{DEinput-H4GMQWDY.js.map → DEinput-XVBBA74N.js.map} +0 -0
  682. /package/dist/{Disco-5PXXMGGQ.js.map → Disco-VV7FQ7WW.js.map} +0 -0
  683. /package/dist/{Disco.UI-23LOT2U6.js.map → Disco.UI-JDJFJFEY.js.map} +0 -0
  684. /package/dist/{DmrPlot-PBCU2XNF.js.map → DmrPlot-XOG67W74.js.map} +0 -0
  685. /package/dist/{GB-HIEPWNPV.js.map → GB-K3AWZQFF.js.map} +0 -0
  686. /package/dist/{GeneExpInput-A4JNX7PU.js.map → GeneExpInput-Y7MDS2CA.js.map} +0 -0
  687. /package/dist/{HicApp-IDH2A4BC.js.map → HicApp-53OTZ3YU.js.map} +0 -0
  688. /package/dist/{NumBinaryEditor-CZ54X7J3.js.map → NumBinaryEditor-SB4YR3JM.js.map} +0 -0
  689. /package/dist/{NumBinaryEditor.unit.spec-QLBRM7MJ.js.map → NumBinaryEditor.unit.spec-V2W2OZYP.js.map} +0 -0
  690. /package/dist/{NumContEditor-Z5MGLQ2I.js.map → NumContEditor-RZZBM7PR.js.map} +0 -0
  691. /package/dist/{NumContEditor.unit.spec-TR7D7ULV.js.map → NumContEditor.unit.spec-GAAW3ZZN.js.map} +0 -0
  692. /package/dist/{NumCustomBinEditor-B7JID42Y.js.map → NumCustomBinEditor-GFCGPRPI.js.map} +0 -0
  693. /package/dist/{NumCustomBinEditor.unit.spec-GZJIVY4K.js.map → NumCustomBinEditor.unit.spec-24MXSO3L.js.map} +0 -0
  694. /package/dist/{NumDiscreteEditor-LWHZ36T6.js.map → NumDiscreteEditor-HAHIOFNC.js.map} +0 -0
  695. /package/dist/{NumDiscreteEditor.unit.spec-QCQCMEWO.js.map → NumDiscreteEditor.unit.spec-JYN2CWSI.js.map} +0 -0
  696. /package/dist/{NumRegularBinEditor-IATRIUKD.js.map → NumRegularBinEditor-7DOE64RB.js.map} +0 -0
  697. /package/dist/{NumRegularBinEditor.unit.spec-J6UTQO76.js.map → NumRegularBinEditor.unit.spec-2WU4GGNT.js.map} +0 -0
  698. /package/dist/{NumSplineEditor-2KMU6SRO.js.map → NumSplineEditor-JLRD5TVX.js.map} +0 -0
  699. /package/dist/{NumSplineEditor.unit.spec-MX7Y4MTD.js.map → NumSplineEditor.unit.spec-LOG7CECJ.js.map} +0 -0
  700. /package/dist/{NumericDensity-JCH7F5FV.js.map → NumericDensity-IDOP7I34.js.map} +0 -0
  701. /package/dist/{NumericDensity.unit.spec-4TKKRKHF.js.map → NumericDensity.unit.spec-HTJQRPVH.js.map} +0 -0
  702. /package/dist/{NumericHandler-7FB3RJM7.js.map → NumericHandler-DWVVGLLB.js.map} +0 -0
  703. /package/dist/{NumericHandler.unit.spec-U6DCADZY.js.map → NumericHandler.unit.spec-BDDFTHOF.js.map} +0 -0
  704. /package/dist/{RunChart2-VQTIVMKM.js.map → RunChart2-PBJ56YX3.js.map} +0 -0
  705. /package/dist/{WsiSamplesPlot-2OAR57YB.js.map → WsiSamplesPlot-FOMPMEXK.js.map} +0 -0
  706. /package/dist/{adSandbox-IKKFYRF7.js.map → adSandbox-SRPPCYYR.js.map} +0 -0
  707. /package/dist/{alphaGenome-WJNFQGGK.js.map → alphaGenome-IS2WAJCK.js.map} +0 -0
  708. /package/dist/{app-UHGTFH6D.js.map → app-GTHYSGWI.js.map} +0 -0
  709. /package/dist/{app-YETYAR45.js.map → app-XEKETNLG.js.map} +0 -0
  710. /package/dist/{bam-S6U7VNJP.js.map → bam-GQBFL6A7.js.map} +0 -0
  711. /package/dist/{barchart-3NJDGHXU.js.map → barchart-AESC4JSX.js.map} +0 -0
  712. /package/dist/{barchart.data-MVVKPDLE.js.map → barchart.data-RE34IC4G.js.map} +0 -0
  713. /package/dist/{barchart.events-WQGA4CGB.js.map → barchart.events-KM4J5ISO.js.map} +0 -0
  714. /package/dist/{barchart.integration.spec-E6CJTWRN.js.map → barchart.integration.spec-DFVSBGO3.js.map} +0 -0
  715. /package/dist/{barchart2-UNHFOYKB.js.map → barchart2-NNTL4RQZ.js.map} +0 -0
  716. /package/dist/{block-2XHZLY26.js.map → block-EHZM3FUX.js.map} +0 -0
  717. /package/dist/{block.init-CMG4V6RB.js.map → block.init-EAEFNNF6.js.map} +0 -0
  718. /package/dist/{block.mds.expressionrank-QX2JOEMV.js.map → block.mds.expressionrank-ZBHA2CFE.js.map} +0 -0
  719. /package/dist/{block.mds.geneboxplot-USVQSDBT.js.map → block.mds.geneboxplot-4ZU3QUAK.js.map} +0 -0
  720. /package/dist/{block.mds.junction-R6GJO75N.js.map → block.mds.junction-PDH55JXO.js.map} +0 -0
  721. /package/dist/{block.mds.svcnv-MRISSDAX.js.map → block.mds.svcnv-QWBU54XQ.js.map} +0 -0
  722. /package/dist/{block.svg-Z5KKZTDB.js.map → block.svg-HUGBYWXU.js.map} +0 -0
  723. /package/dist/{block.tk.aicheck-SOFJYYZX.js.map → block.tk.aicheck-SDCWXQZF.js.map} +0 -0
  724. /package/dist/{block.tk.ase-EHX5FV2Y.js.map → block.tk.ase-HMUTHCJS.js.map} +0 -0
  725. /package/dist/{block.tk.bam-DJS6LODM.js.map → block.tk.bam-Q7B2YQLI.js.map} +0 -0
  726. /package/dist/{block.tk.bedgraphdot-R2YHPXZA.js.map → block.tk.bedgraphdot-QBGBSVHN.js.map} +0 -0
  727. /package/dist/{block.tk.bigwig.ui-VPEEQJLS.js.map → block.tk.bigwig.ui-767A3MUH.js.map} +0 -0
  728. /package/dist/{block.tk.hicstraw-BDYN573B.js.map → block.tk.hicstraw-LEZUZHLF.js.map} +0 -0
  729. /package/dist/{block.tk.junction-BONB4BXU.js.map → block.tk.junction-GQHCZOYR.js.map} +0 -0
  730. /package/dist/{block.tk.junction.textmatrixui-Y5R6KY4N.js.map → block.tk.junction.textmatrixui-D5QUO7KQ.js.map} +0 -0
  731. /package/dist/{block.tk.ld-EGVVSXCB.js.map → block.tk.ld-E3MHZOG5.js.map} +0 -0
  732. /package/dist/{block.tk.menu-4YBMB5JT.js.map → block.tk.menu-XE7PFYGR.js.map} +0 -0
  733. /package/dist/{block.tk.pgv-SBHGL6UH.js.map → block.tk.pgv-MPPMPDED.js.map} +0 -0
  734. /package/dist/{brainImaging-G3WZDYG6.js.map → brainImaging-YQ443NOL.js.map} +0 -0
  735. /package/dist/{chunk-LQQSRNR5.js.map → chunk-26WXJBSR.js.map} +0 -0
  736. /package/dist/{chunk-7UHUOC6F.js.map → chunk-2P6Z7JFC.js.map} +0 -0
  737. /package/dist/{chunk-ENWVV6EU.js.map → chunk-2QQO4RRD.js.map} +0 -0
  738. /package/dist/{chunk-GF4OSOYW.js.map → chunk-37ARSZOI.js.map} +0 -0
  739. /package/dist/{chunk-LY7GD74F.js.map → chunk-42Q53PXE.js.map} +0 -0
  740. /package/dist/{chunk-5SMOOFRW.js.map → chunk-46ASPS5Y.js.map} +0 -0
  741. /package/dist/{chunk-RA4RQYXQ.js.map → chunk-4KPI7PB5.js.map} +0 -0
  742. /package/dist/{chunk-XZ6MGJQ3.js.map → chunk-4MDNMCGZ.js.map} +0 -0
  743. /package/dist/{chunk-4Y444IRJ.js.map → chunk-5IG3E4DT.js.map} +0 -0
  744. /package/dist/{chunk-UVPAZM3G.js.map → chunk-5MIR7IHI.js.map} +0 -0
  745. /package/dist/{chunk-BQJVLXEL.js.map → chunk-5MZVXJVA.js.map} +0 -0
  746. /package/dist/{chunk-SDLRTORS.js.map → chunk-66D5GRS5.js.map} +0 -0
  747. /package/dist/{chunk-IABWKPRK.js.map → chunk-6ATE2TRC.js.map} +0 -0
  748. /package/dist/{chunk-JPKYHLNI.js.map → chunk-6BFR6MK3.js.map} +0 -0
  749. /package/dist/{chunk-C62CSWMV.js.map → chunk-6NJMCO4X.js.map} +0 -0
  750. /package/dist/{chunk-IPDH4FHY.js.map → chunk-6ON5KAMO.js.map} +0 -0
  751. /package/dist/{chunk-ZYBM24FU.js.map → chunk-76GPYMHZ.js.map} +0 -0
  752. /package/dist/{chunk-PSGQWZN4.js.map → chunk-7AAFBFOH.js.map} +0 -0
  753. /package/dist/{chunk-LGUE54VX.js.map → chunk-7OOZHEUC.js.map} +0 -0
  754. /package/dist/{chunk-I7JDV4ZC.js.map → chunk-A4VLWLYF.js.map} +0 -0
  755. /package/dist/{chunk-W6XQR5UL.js.map → chunk-A6EFWGWD.js.map} +0 -0
  756. /package/dist/{chunk-ANGDY7VC.js.map → chunk-ALW5XXVW.js.map} +0 -0
  757. /package/dist/{chunk-RQZJIBIH.js.map → chunk-ANCT2BGO.js.map} +0 -0
  758. /package/dist/{chunk-NYX4B5CO.js.map → chunk-AROMXWCY.js.map} +0 -0
  759. /package/dist/{chunk-UWYCEYML.js.map → chunk-AY4UBGLC.js.map} +0 -0
  760. /package/dist/{chunk-32TTOWY6.js.map → chunk-BMVLR3TM.js.map} +0 -0
  761. /package/dist/{chunk-PL2CM7RY.js.map → chunk-BR7JA2EO.js.map} +0 -0
  762. /package/dist/{chunk-7FKIAQ4K.js.map → chunk-D3HJXMTH.js.map} +0 -0
  763. /package/dist/{chunk-XSA3VIEQ.js.map → chunk-DKUEZ4XD.js.map} +0 -0
  764. /package/dist/{chunk-LSV4Z473.js.map → chunk-DT3MMC5U.js.map} +0 -0
  765. /package/dist/{chunk-UPPBAFUK.js.map → chunk-DYVKN7EE.js.map} +0 -0
  766. /package/dist/{chunk-VB3SRNBK.js.map → chunk-EF37UZY6.js.map} +0 -0
  767. /package/dist/{chunk-ZD47FENE.js.map → chunk-ESXMS7FW.js.map} +0 -0
  768. /package/dist/{chunk-2QULGYVE.js.map → chunk-FUSVXQ6C.js.map} +0 -0
  769. /package/dist/{chunk-GTBL7UHX.js.map → chunk-GXKVAPGP.js.map} +0 -0
  770. /package/dist/{chunk-AQ4OP4GR.js.map → chunk-H4JIENLQ.js.map} +0 -0
  771. /package/dist/{chunk-FA44G3GZ.js.map → chunk-H7YJG4YM.js.map} +0 -0
  772. /package/dist/{chunk-GD7FKXOA.js.map → chunk-I24KPIDD.js.map} +0 -0
  773. /package/dist/{chunk-GQOBT2W7.js.map → chunk-IENFDUWD.js.map} +0 -0
  774. /package/dist/{chunk-43PMSEMV.js.map → chunk-J7BISJTL.js.map} +0 -0
  775. /package/dist/{chunk-XBBUQW52.js.map → chunk-J7KYOSEK.js.map} +0 -0
  776. /package/dist/{chunk-PZLYNNST.js.map → chunk-JGPZ5254.js.map} +0 -0
  777. /package/dist/{chunk-4KSU6NBP.js.map → chunk-JUIPCWAM.js.map} +0 -0
  778. /package/dist/{chunk-5RE3J6HK.js.map → chunk-LO4NMQ7W.js.map} +0 -0
  779. /package/dist/{chunk-RAJZYWFN.js.map → chunk-LSSLS5HV.js.map} +0 -0
  780. /package/dist/{chunk-7NOKTEHK.js.map → chunk-MDLRB3MR.js.map} +0 -0
  781. /package/dist/{chunk-OPPNZXYG.js.map → chunk-MJLKGZ27.js.map} +0 -0
  782. /package/dist/{chunk-KTCW3JA6.js.map → chunk-NL5T3SBK.js.map} +0 -0
  783. /package/dist/{chunk-RSE2FOKW.js.map → chunk-ONAYJVN2.js.map} +0 -0
  784. /package/dist/{chunk-64Z22QAH.js.map → chunk-PSMFOARZ.js.map} +0 -0
  785. /package/dist/{chunk-LTSR7SLO.js.map → chunk-QX3GF2IA.js.map} +0 -0
  786. /package/dist/{chunk-JNOOLCYB.js.map → chunk-QZ2U4BOS.js.map} +0 -0
  787. /package/dist/{chunk-YEMIL6QU.js.map → chunk-RBZBBNLL.js.map} +0 -0
  788. /package/dist/{chunk-P6TPXUMP.js.map → chunk-RZTFQXWV.js.map} +0 -0
  789. /package/dist/{chunk-AQVOYTLS.js.map → chunk-SJC2C77V.js.map} +0 -0
  790. /package/dist/{chunk-2VLGHVOL.js.map → chunk-TVXVP4M6.js.map} +0 -0
  791. /package/dist/{chunk-HE7CD7BD.js.map → chunk-UTDPKDIY.js.map} +0 -0
  792. /package/dist/{chunk-BT4OOYPT.js.map → chunk-UVIUB7QI.js.map} +0 -0
  793. /package/dist/{chunk-CAWDQURD.js.map → chunk-VAUSRBL5.js.map} +0 -0
  794. /package/dist/{chunk-6NMH6WPB.js.map → chunk-WP22GYZ2.js.map} +0 -0
  795. /package/dist/{chunk-4SFX42S7.js.map → chunk-WUNX3VST.js.map} +0 -0
  796. /package/dist/{chunk-BRMASRRS.js.map → chunk-XD4TBJK2.js.map} +0 -0
  797. /package/dist/{chunk-2O6JF76T.js.map → chunk-Y6DSXMPB.js.map} +0 -0
  798. /package/dist/{chunk-ROLVOPVR.js.map → chunk-YBIZRASR.js.map} +0 -0
  799. /package/dist/{chunk-TF4EDNQO.js.map → chunk-YI2YH7ZK.js.map} +0 -0
  800. /package/dist/{chunk-KMQ6GQ3I.js.map → chunk-YLDE3PVC.js.map} +0 -0
  801. /package/dist/{chunk-MHCTLVGE.js.map → chunk-Z736NYXL.js.map} +0 -0
  802. /package/dist/{chunk-LJ4AUJXC.js.map → chunk-ZEJB7CPC.js.map} +0 -0
  803. /package/dist/{chunk-5HOR6JQ2.js.map → chunk-ZGWEBKZ4.js.map} +0 -0
  804. /package/dist/{condition-ARCN26MF.js.map → condition-FSF6ROJV.js.map} +0 -0
  805. /package/dist/{controls-PKWN2JGN.js.map → controls-OPSBFDFZ.js.map} +0 -0
  806. /package/dist/{controls.config-NFRPXFUJ.js.map → controls.config-3QRV5363.js.map} +0 -0
  807. /package/dist/{correlation-DPT6XL2U.js.map → correlation-WLOI7Z35.js.map} +0 -0
  808. /package/dist/{cuminc-M4U7LQD5.js.map → cuminc-G2UGJUUA.js.map} +0 -0
  809. /package/dist/{cuminc.integration.spec-MH4OFYDJ.js.map → cuminc.integration.spec-X5NEZ6S5.js.map} +0 -0
  810. /package/dist/{customdata.inputui-6TAHAMSV.js.map → customdata.inputui-RNW3AO3Z.js.map} +0 -0
  811. /package/dist/{dataDownload-7GZEYSUT.js.map → dataDownload-4U3TGDMH.js.map} +0 -0
  812. /package/dist/{dataDownload.integration.spec-NAIJRFTV.js.map → dataDownload.integration.spec-6FUI2SJ4.js.map} +0 -0
  813. /package/dist/{databrowser.ui-LLXHZ5O6.js.map → databrowser.ui-4GVJVJWG.js.map} +0 -0
  814. /package/dist/{dictionary-MUAURMYE.js.map → dictionary-NSDS7Z4K.js.map} +0 -0
  815. /package/dist/{dnaMethylation-AU5D3U3E.js.map → dnaMethylation-OYQB75LD.js.map} +0 -0
  816. /package/dist/{dnaMethylation.integration.spec-JIDBRA6P.js.map → dnaMethylation.integration.spec-6TTLV34N.js.map} +0 -0
  817. /package/dist/{dofetch-WSYK5OTB.js.map → dofetch-4TO3QMT6.js.map} +0 -0
  818. /package/dist/{e2pca-ICG35YR5.js.map → e2pca-NYBVR6PL.js.map} +0 -0
  819. /package/dist/{ep-CSSSQOUP.js.map → ep-RTDVEA4D.js.map} +0 -0
  820. /package/dist/{expclust.gdc.spec-4WPQUXH4.js.map → expclust.gdc.spec-JVIRESTP.js.map} +0 -0
  821. /package/dist/{facet-JAGILNY6.js.map → facet-OVBF2QMO.js.map} +0 -0
  822. /package/dist/{forms2-IMVDB6AT.js.map → forms2-HTLS54CX.js.map} +0 -0
  823. /package/dist/{gb-36LTYICV.js.map → gb-Y3546HMZ.js.map} +0 -0
  824. /package/dist/{geneExpClustering-CGMENTHI.js.map → geneExpClustering-PH3PWH3K.js.map} +0 -0
  825. /package/dist/{geneExpression-AD2L46J4.js.map → geneExpression-2Z2EV3XM.js.map} +0 -0
  826. /package/dist/{geneExpression-G2FHBDUQ.js.map → geneExpression-6CFXOCGW.js.map} +0 -0
  827. /package/dist/{geneExpression.unit.spec-XWCB7K5L.js.map → geneExpression.unit.spec-WKUTHRHC.js.map} +0 -0
  828. /package/dist/{geneORA-GVHQF7DF.js.map → geneORA-SHLZESLB.js.map} +0 -0
  829. /package/dist/{geneVariant-HE22CH76.js.map → geneVariant-FHZUIFPM.js.map} +0 -0
  830. /package/dist/{geneVariant-SQD5QUFH.js.map → geneVariant-Y7ZUBEOX.js.map} +0 -0
  831. /package/dist/{geneVariant.integration.spec-66XFLDNN.js.map → geneVariant.integration.spec-N7TZUOY3.js.map} +0 -0
  832. /package/dist/{genefusion.ui-TD32NWD4.js.map → genefusion.ui-7PDVZPZ2.js.map} +0 -0
  833. /package/dist/{geneset-NSYPDXS3.js.map → geneset-HLVOGYUI.js.map} +0 -0
  834. /package/dist/{genomeBrowser.spec-CYFONLNQ.js.map → genomeBrowser.spec-7IVIMUR5.js.map} +0 -0
  835. /package/dist/{grin2-3QB57OPH.js.map → grin2-Z5O7254R.js.map} +0 -0
  836. /package/dist/{gsea-RMTU5I3U.js.map → gsea-TFC3MBRW.js.map} +0 -0
  837. /package/dist/{hierCluster-LSQL6PGC.js.map → hierCluster-ERSE5I4I.js.map} +0 -0
  838. /package/dist/{hierCluster-XTEBDEVO.js.map → hierCluster-QQZQU5ZG.js.map} +0 -0
  839. /package/dist/{hierCluster.config-SHXFSPOH.js.map → hierCluster.config-WPINWW37.js.map} +0 -0
  840. /package/dist/{hierCluster.integration.spec-KNMIYWV3.js.map → hierCluster.integration.spec-Y6OHSKPW.js.map} +0 -0
  841. /package/dist/{hierCluster.interactivity-6NAKTUR5.js.map → hierCluster.interactivity-HS3G5QC5.js.map} +0 -0
  842. /package/dist/{hierCluster.renderers-FWOV4Q47.js.map → hierCluster.renderers-W63ZKZTT.js.map} +0 -0
  843. /package/dist/{imagePlot-3IVG4SFN.js.map → imagePlot-QFVN25PM.js.map} +0 -0
  844. /package/dist/{importPlot-HEMDRIVF.js.map → importPlot-MIDM5APH.js.map} +0 -0
  845. /package/dist/{isoformExpression-FJ3GEU6D.js.map → isoformExpression-L4TRNT4A.js.map} +0 -0
  846. /package/dist/{isoformExpression.unit.spec-L7D22UDB.js.map → isoformExpression.unit.spec-QQG323LA.js.map} +0 -0
  847. /package/dist/{launch.adhoc-PDGQF2UP.js.map → launch.adhoc-4NQ6GGGL.js.map} +0 -0
  848. /package/dist/{leftlabel.sample-ZBI4NHCV.js.map → leftlabel.sample-JU7AIPZL.js.map} +0 -0
  849. /package/dist/{legacyDataset-PBCPC5I7.js.map → legacyDataset-TT4CHF23.js.map} +0 -0
  850. /package/dist/{lollipop-K7S6ASFE.js.map → lollipop-JG74M6PJ.js.map} +0 -0
  851. /package/dist/{maf-JEW6PPJB.js.map → maf-PDL2EGHI.js.map} +0 -0
  852. /package/dist/{maftimeline-7URL27MC.js.map → maftimeline-V43NQEEE.js.map} +0 -0
  853. /package/dist/{matrix-6EK5WGIG.js.map → matrix-EB2EFP4S.js.map} +0 -0
  854. /package/dist/{matrix-DKBD5RIL.js.map → matrix-Q57FU5FE.js.map} +0 -0
  855. /package/dist/{matrix.cells-KEIOXJQ7.js.map → matrix.cells-NJIMPD32.js.map} +0 -0
  856. /package/dist/{matrix.config-FGJB4VVM.js.map → matrix.config-GLDEQD3H.js.map} +0 -0
  857. /package/dist/{matrix.data-QGCGFLD7.js.map → matrix.data-6SHAKOQU.js.map} +0 -0
  858. /package/dist/{matrix.groups-HBPLZ2QX.js.map → matrix.groups-MTDEANQA.js.map} +0 -0
  859. /package/dist/{matrix.integration.spec-R4PF67KF.js.map → matrix.integration.spec-JCZ5VQJU.js.map} +0 -0
  860. /package/dist/{matrix.interactivity-M3SY33ET.js.map → matrix.interactivity-SVRNWL6V.js.map} +0 -0
  861. /package/dist/{matrix.layout-H6WQ3ZMW.js.map → matrix.layout-2HREO42N.js.map} +0 -0
  862. /package/dist/{matrix.legend-UCL7HM26.js.map → matrix.legend-QHVKT3MP.js.map} +0 -0
  863. /package/dist/{matrix.renderers-3PPFSS7Z.js.map → matrix.renderers-IYR3ZY6V.js.map} +0 -0
  864. /package/dist/{matrix.serieses-S2TJ3E6P.js.map → matrix.serieses-2VMTQXL2.js.map} +0 -0
  865. /package/dist/{matrix.sort-CFA4UWBJ.js.map → matrix.sort-PWA2RQQR.js.map} +0 -0
  866. /package/dist/{matrix.sort.unit.spec-562VIWDS.js.map → matrix.sort.unit.spec-3OYIPTFY.js.map} +0 -0
  867. /package/dist/{matrix.sorterUi-FT7K5664.js.map → matrix.sorterUi-Y5QLO75X.js.map} +0 -0
  868. /package/dist/{matrix.sorterUi.unit.spec-GAHHUN3K.js.map → matrix.sorterUi.unit.spec-BNEXQHLP.js.map} +0 -0
  869. /package/dist/{mavb-HPW5X55U.js.map → mavb-IZDDU4KK.js.map} +0 -0
  870. /package/dist/{mds.fimo-HSBKLIOX.js.map → mds.fimo-FWBL7JE6.js.map} +0 -0
  871. /package/dist/{mds.samplescatterplot-DE27OMJE.js.map → mds.samplescatterplot-T47C7DJB.js.map} +0 -0
  872. /package/dist/{mds.survivalplot-IW22UGCE.js.map → mds.survivalplot-MFZJCGS6.js.map} +0 -0
  873. /package/dist/{numericDictTermCluster-DOD66G3A.js.map → numericDictTermCluster-I2W67RGA.js.map} +0 -0
  874. /package/dist/{oncomatrix-BZCVCPR4.js.map → oncomatrix-6W7IBAED.js.map} +0 -0
  875. /package/dist/{oncomatrix.spec-IHYCIAP4.js.map → oncomatrix.spec-CEFH5IGH.js.map} +0 -0
  876. /package/dist/{plot.2dvaf-QLOZ54VC.js.map → plot.2dvaf-BN6CFLNU.js.map} +0 -0
  877. /package/dist/{plot.app-XDVDR23J.js.map → plot.app-7EYWUCZV.js.map} +0 -0
  878. /package/dist/{plot.barplot-XOESF7OQ.js.map → plot.barplot-MDIARSQD.js.map} +0 -0
  879. /package/dist/{plot.boxplot-VNOC2CHT.js.map → plot.boxplot-RUHGXC54.js.map} +0 -0
  880. /package/dist/{plot.brainImaging-7ZEOY4UR.js.map → plot.brainImaging-JEE32ZBV.js.map} +0 -0
  881. /package/dist/{plot.disco-6GVDYK7A.js.map → plot.disco-2RPNPX6E.js.map} +0 -0
  882. /package/dist/{plot.dzi-TEFPPPL6.js.map → plot.dzi-7VTYYGGW.js.map} +0 -0
  883. /package/dist/{plot.ssgq-OG4TODLO.js.map → plot.ssgq-FHE5KU5C.js.map} +0 -0
  884. /package/dist/{plot.vaf2cov-VMZRJULA.js.map → plot.vaf2cov-WDJJM5Q4.js.map} +0 -0
  885. /package/dist/{plot.wsi-2CHZZ7AC.js.map → plot.wsi-FQZWHNSF.js.map} +0 -0
  886. /package/dist/{polar-QUYQRQOQ.js.map → polar-M7EGINN4.js.map} +0 -0
  887. /package/dist/{polar2-OXXLAXJC.js.map → polar2-JFYY43K2.js.map} +0 -0
  888. /package/dist/{profile.spec-TI6PRHNJ.js.map → profile.spec-SIOHASOX.js.map} +0 -0
  889. /package/dist/{profileBarchart-GEK77XEB.js.map → profileBarchart-6JLEKVJV.js.map} +0 -0
  890. /package/dist/{profileForms-NR3VNHKM.js.map → profileForms-G6CH73RV.js.map} +0 -0
  891. /package/dist/{profilePlot-GGKO3IW5.js.map → profilePlot-NQYJOBVV.js.map} +0 -0
  892. /package/dist/{profileRadar-MN3LX5ER.js.map → profileRadar-4TNWIXDB.js.map} +0 -0
  893. /package/dist/{profileRadarFacility-3G2HWB2L.js.map → profileRadarFacility-XPH3LCBQ.js.map} +0 -0
  894. /package/dist/{proteomeAbundance-O4BB55O3.js.map → proteomeAbundance-NQ4635NL.js.map} +0 -0
  895. /package/dist/{qualitative-Q3TT73O7.js.map → qualitative-DL4WJG3O.js.map} +0 -0
  896. /package/dist/{radar2-LSD3VPZT.js.map → radar2-YNOQWHBT.js.map} +0 -0
  897. /package/dist/{radarFacility2-LZGIXY7A.js.map → radarFacility2-24UPSI7S.js.map} +0 -0
  898. /package/dist/{regression-J3XDAPAZ.js.map → regression-URAUTLTD.js.map} +0 -0
  899. /package/dist/{regression.inputs-BBZYI5OI.js.map → regression.inputs-UDVOU7FB.js.map} +0 -0
  900. /package/dist/{regression.inputs.term-7BW6XGLG.js.map → regression.inputs.term-BWW6W34R.js.map} +0 -0
  901. /package/dist/{regression.inputs.values.table-DYX2YU4H.js.map → regression.inputs.values.table-UKGIZTXG.js.map} +0 -0
  902. /package/dist/{regression.integration.spec-WLXZYKWW.js.map → regression.integration.spec-EBHQTNA3.js.map} +0 -0
  903. /package/dist/{regression.results-K5Q2N2KW.js.map → regression.results-XTOSWIP6.js.map} +0 -0
  904. /package/dist/{regression.spec-VT7T6KBY.js.map → regression.spec-KG2I53VR.js.map} +0 -0
  905. /package/dist/{report-3D3L573D.js.map → report-KH7SNPVF.js.map} +0 -0
  906. /package/dist/{sampleScatter.spec-6IPJQLM2.js.map → sampleScatter.spec-PIXGS3LG.js.map} +0 -0
  907. /package/dist/{sampleView-5JMFI4HF.js.map → sampleView-TWS6VT55.js.map} +0 -0
  908. /package/dist/{samplelst-SUCB5WOZ.js.map → samplelst-6AB5Y4WR.js.map} +0 -0
  909. /package/dist/{samplematrix-A5SZBKO6.js.map → samplematrix-AJAF555E.js.map} +0 -0
  910. /package/dist/{sc-NAA6ESO6.js.map → sc-PMNYZKXA.js.map} +0 -0
  911. /package/dist/{scatter-EQCN2HYE.js.map → scatter-Q2GH3ZJD.js.map} +0 -0
  912. /package/dist/{scatter.integration.spec-7NXIYS67.js.map → scatter.integration.spec-SMMYKWH3.js.map} +0 -0
  913. /package/dist/{selectGenomeWithTklst-KXODNCY6.js.map → selectGenomeWithTklst-VE4SDYY7.js.map} +0 -0
  914. /package/dist/{singleCellCellType-HMIW76YB.js.map → singleCellCellType-S324GCKW.js.map} +0 -0
  915. /package/dist/{singleCellCellType.unit.spec-ZCZET56X.js.map → singleCellCellType.unit.spec-NXC2GELH.js.map} +0 -0
  916. /package/dist/{singleCellGeneExpression-IUCUHF6R.js.map → singleCellGeneExpression-6H4HRKIA.js.map} +0 -0
  917. /package/dist/{singleCellGeneExpression.unit.spec-J4D6F2N3.js.map → singleCellGeneExpression.unit.spec-HIJXVUWJ.js.map} +0 -0
  918. /package/dist/{singleCellPlot-L6W3MDGG.js.map → singleCellPlot-H7PCZ2DP.js.map} +0 -0
  919. /package/dist/{singlecell-A6ECAAPI.js.map → singlecell-4LH3MQVL.js.map} +0 -0
  920. /package/dist/{singlecell-KBABNXC5.js.map → singlecell-MOSYT3RI.js.map} +0 -0
  921. /package/dist/{snp-RO7ATG6E.js.map → snp-IKLGTD4Q.js.map} +0 -0
  922. /package/dist/{snp.unit.spec-ZJLRGJD4.js.map → snp.unit.spec-GC74MUVM.js.map} +0 -0
  923. /package/dist/{snplocus-N3CU6NRP.js.map → snplocus-RIABFSBQ.js.map} +0 -0
  924. /package/dist/{spliceevent.a53ss.diagram-7PHT4COB.js.map → spliceevent.a53ss.diagram-4E2IYYHL.js.map} +0 -0
  925. /package/dist/{spliceevent.exonskip.diagram-3CZTY6QD.js.map → spliceevent.exonskip.diagram-C56R6XLQ.js.map} +0 -0
  926. /package/dist/{spliceevent.noeventdiagram-GQE256DT.js.map → spliceevent.noeventdiagram-SIPMAKXI.js.map} +0 -0
  927. /package/dist/{ssGSEA-4I3L5MX2.js.map → ssGSEA-5QNHLSOI.js.map} +0 -0
  928. /package/dist/{ssGSEA.unit.spec-PZCC5YU7.js.map → ssGSEA.unit.spec-KVPN553B.js.map} +0 -0
  929. /package/dist/{summarizeCnvGeneexp-ASXUQW56.js.map → summarizeCnvGeneexp-K4VGJSW6.js.map} +0 -0
  930. /package/dist/{summarizeGeneexpSurvival-ULGUOW5V.js.map → summarizeGeneexpSurvival-HGHX65FN.js.map} +0 -0
  931. /package/dist/{summarizeMutationCnv-VDUCIUGM.js.map → summarizeMutationCnv-3K4Z6R2X.js.map} +0 -0
  932. /package/dist/{summarizeMutationDiagnosis-FMAAMCZC.js.map → summarizeMutationDiagnosis-M2MHUPRT.js.map} +0 -0
  933. /package/dist/{summarizeMutationSurvival-GZ4NGDJT.js.map → summarizeMutationSurvival-WVBUP3GA.js.map} +0 -0
  934. /package/dist/{summary-2WNZ6JSB.js.map → summary-RZHZXCU5.js.map} +0 -0
  935. /package/dist/{summary.integration.spec-XPMYB6GM.js.map → summary.integration.spec-FGZP7DY7.js.map} +0 -0
  936. /package/dist/{summaryInput-2UGXEA5C.js.map → summaryInput-UGM7MMCR.js.map} +0 -0
  937. /package/dist/{sunburst-76WCQLTT.js.map → sunburst-L27U7LV7.js.map} +0 -0
  938. /package/dist/{survival-3EAMPHSX.js.map → survival-5ZMEBV6O.js.map} +0 -0
  939. /package/dist/{survival-23IZM4ML.js.map → survival-JWRRGTJT.js.map} +0 -0
  940. /package/dist/{survival.integration.spec-YNVAKBV3.js.map → survival.integration.spec-Z5542I4V.js.map} +0 -0
  941. /package/dist/{svgraph-G2M5LXEP.js.map → svgraph-O6ZVLNNN.js.map} +0 -0
  942. /package/dist/{svmr-BUDBVU34.js.map → svmr-ULFV7OSH.js.map} +0 -0
  943. /package/dist/{table-QJSZ6YFK.js.map → table-CHRQH2GH.js.map} +0 -0
  944. /package/dist/{termCollection-2YAY3RLZ.js.map → termCollection-FAO6ZA6F.js.map} +0 -0
  945. /package/dist/{termCollection-MAMDMEDD.js.map → termCollection-GBXS3GOY.js.map} +0 -0
  946. /package/dist/{termCollection.unit.spec-UY7G2BHG.js.map → termCollection.unit.spec-4WRTOV6E.js.map} +0 -0
  947. /package/dist/{tk-GFGP3F76.js.map → tk-KNUBWRNK.js.map} +0 -0
  948. /package/dist/{tp.ui-OQ757UIE.js.map → tp.ui-2PPYOQYL.js.map} +0 -0
  949. /package/dist/{tvs.density-BJK23JYJ.js.map → tvs.density-BZ5SKDQS.js.map} +0 -0
  950. /package/dist/{tvs.dt-TOYEFKNT.js.map → tvs.dt-TDNSTGQR.js.map} +0 -0
  951. /package/dist/{tvs.dtcnv.categorical-EO2VLFL2.js.map → tvs.dtcnv.categorical-P2IGIE4I.js.map} +0 -0
  952. /package/dist/{tvs.dtcnv.continuous-ZAHTKZ4Y.js.map → tvs.dtcnv.continuous-2XUCRBDR.js.map} +0 -0
  953. /package/dist/{tvs.dtfusion-BY3AHBL3.js.map → tvs.dtfusion-PRHZVMOG.js.map} +0 -0
  954. /package/dist/{tvs.dtsnvindel-UM5LQ4FR.js.map → tvs.dtsnvindel-KGKBW5JS.js.map} +0 -0
  955. /package/dist/{tvs.dtsv-H7ZVHLS5.js.map → tvs.dtsv-M3CY5TZF.js.map} +0 -0
  956. /package/dist/{tvs.numeric-66FP6RRH.js.map → tvs.numeric-W74JCC5P.js.map} +0 -0
  957. /package/dist/{tvs.samplelst-Q5ECTZOY.js.map → tvs.samplelst-BTWFBBAN.js.map} +0 -0
  958. /package/dist/{tvs.termCollection-FYNMKZTR.js.map → tvs.termCollection-Y64QIKOA.js.map} +0 -0
  959. /package/dist/{violin-EGWLAJVM.js.map → violin-3LLHHV3L.js.map} +0 -0
  960. /package/dist/{violin.integration.spec-3P4TYHBR.js.map → violin.integration.spec-6NF5FDLQ.js.map} +0 -0
  961. /package/dist/{violin.interactivity-VWDR4LYB.js.map → violin.interactivity-W2AKZ24D.js.map} +0 -0
  962. /package/dist/{violin.renderer-WWTU6J7X.js.map → violin.renderer-CRFYYZRI.js.map} +0 -0
  963. /package/dist/{vocabulary-JG4ZITOH.js.map → vocabulary-AUJOAVYS.js.map} +0 -0
@@ -0,0 +1,2327 @@
1
+ import {
2
+ vcf2dstk
3
+ } from "./chunk-IENFDUWD.js";
4
+ import {
5
+ getsjcharts
6
+ } from "./chunk-MKAF2BHB.js";
7
+ import {
8
+ parseheader,
9
+ parseline
10
+ } from "./chunk-RQ2ZJ66W.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-2XPDA6NL.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-MYWJQRTD.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-X7GDCYND.js";
51
+ import {
52
+ category10_default
53
+ } from "./chunk-KSGA62R2.js";
54
+ import {
55
+ ordinal
56
+ } from "./chunk-OAWQ6LOO.js";
57
+ import {
58
+ select_default
59
+ } from "./chunk-I6Y4O3RR.js";
60
+
61
+ // ../shared/utils/dist/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/dist/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/dist/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/dist/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/dist/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/dist/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-2PPYOQYL.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-2PPYOQYL.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-2PPYOQYL.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-IKHIY6IZ.js.map