@sjcrh/proteinpaint-client 2.185.0 → 2.186.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (848) hide show
  1. package/dist/2dmaf-F5QNP7AQ.js +1371 -0
  2. package/dist/AIProjectAdmin-ROSQHK6Q.js +827 -0
  3. package/dist/AIProjectAdmin-ROSQHK6Q.js.map +7 -0
  4. package/dist/AppHeader-STVCDLET.js +833 -0
  5. package/dist/BoxPlot-CU7MEBH7.js +1217 -0
  6. package/dist/CorrelationVolcano-OE4R2GS3.js +617 -0
  7. package/dist/DE-SR7PJPKI.js +93 -0
  8. package/dist/DEinput-PRIAIBFH.js +299 -0
  9. package/dist/DEinput-PRIAIBFH.js.map +7 -0
  10. package/dist/DifferentialAnalysis-UWTYK7NU.js +241 -0
  11. package/dist/Disco-IL6REGSA.js +3235 -0
  12. package/dist/Disco.UI-JHHLS5BA.js +242 -0
  13. package/dist/DmrPlot-DDP53T3F.js +640 -0
  14. package/dist/GB-F4LMYMHF.js +1127 -0
  15. package/dist/GB-F4LMYMHF.js.map +7 -0
  16. package/dist/GeneExpInput-ZWBC226P.js +363 -0
  17. package/dist/GeneExpInput-ZWBC226P.js.map +7 -0
  18. package/dist/HicApp-RVFHTYED.js +2248 -0
  19. package/dist/NumBinaryEditor-B3FXQAOH.js +268 -0
  20. package/dist/NumBinaryEditor.unit.spec-75YQJ2U6.js +284 -0
  21. package/dist/NumContEditor-5PYW3OLY.js +105 -0
  22. package/dist/NumContEditor.unit.spec-F7ZRDGBN.js +167 -0
  23. package/dist/NumCustomBinEditor-TBT6GLYQ.js +36 -0
  24. package/dist/NumCustomBinEditor.unit.spec-6YHU45XV.js +282 -0
  25. package/dist/NumDiscreteEditor-N6OJYSJA.js +177 -0
  26. package/dist/NumDiscreteEditor.unit.spec-HQS5RZ6R.js +200 -0
  27. package/dist/NumRegularBinEditor-HSDDKVNG.js +36 -0
  28. package/dist/NumRegularBinEditor.unit.spec-33KN2MVM.js +225 -0
  29. package/dist/NumSplineEditor-XERKOACS.js +190 -0
  30. package/dist/NumSplineEditor.unit.spec-MPVM6KSC.js +197 -0
  31. package/dist/NumericDensity-35EKYW3V.js +36 -0
  32. package/dist/NumericDensity.unit.spec-OR24PPRJ.js +219 -0
  33. package/dist/NumericHandler-D6ZNGRE3.js +37 -0
  34. package/dist/NumericHandler.unit.spec-EKPGVSXI.js +217 -0
  35. package/dist/RunChart2-7DOXOFXV.js +756 -0
  36. package/dist/SC-APZRV4H6.js +826 -0
  37. package/dist/SC-APZRV4H6.js.map +7 -0
  38. package/dist/Volcano-X4ZWK644.js +1344 -0
  39. package/dist/Volcano-X4ZWK644.js.map +7 -0
  40. package/dist/WSIViewer-E247ELKN.js +47971 -0
  41. package/dist/WsiSamplesPlot-3522VRB5.js +163 -0
  42. package/dist/adSandbox-IDFY5P2P.js +36 -0
  43. package/dist/alphaGenome-F3W7GJQ5.js +173 -0
  44. package/dist/app-2HDSFMRM.js +47 -0
  45. package/dist/app-LIWPFL7C.js +35 -0
  46. package/dist/app.js +10 -10
  47. package/dist/bam-TBHHSATL.js +857 -0
  48. package/dist/barchart-HHFCBOZE.js +45 -0
  49. package/dist/barchart.events-UQUSSRXB.js +45 -0
  50. package/dist/barchart.integration.spec-OF3MWFQ5.js +1675 -0
  51. package/dist/barchart2-XRMPCBBU.js +309 -0
  52. package/dist/block-5UEORHFB.js +6200 -0
  53. package/dist/block.init-QSSFUVIT.js +36 -0
  54. package/dist/block.mds.expressionrank-VBIIJHQF.js +357 -0
  55. package/dist/block.mds.geneboxplot-KSBHXBNX.js +826 -0
  56. package/dist/block.mds.junction-FWZWMZJ2.js +1543 -0
  57. package/dist/block.mds.svcnv-UXORVLH2.js +6799 -0
  58. package/dist/block.svg-6KIGW4QH.js +162 -0
  59. package/dist/block.tk.aicheck-DK566Q4C.js +281 -0
  60. package/dist/block.tk.ase-2GB2VJJ6.js +363 -0
  61. package/dist/block.tk.bam-RQNOLY52.js +1904 -0
  62. package/dist/block.tk.bedgraphdot-N4YMZFO4.js +382 -0
  63. package/dist/block.tk.bigwig.ui-4S7L7D7D.js +209 -0
  64. package/dist/block.tk.hicstraw-AHFNQKCS.js +821 -0
  65. package/dist/block.tk.junction-7E6SNQMQ.js +2362 -0
  66. package/dist/block.tk.junction.textmatrixui-3C5JVYX5.js +197 -0
  67. package/dist/block.tk.ld-TOUCLT3W.js +97 -0
  68. package/dist/block.tk.menu-JCV5ORD6.js +1027 -0
  69. package/dist/block.tk.pgv-CUU22U6M.js +942 -0
  70. package/dist/brainImaging-MTQTXNNL.js +421 -0
  71. package/dist/chunk-2UYBBUXK.js +293 -0
  72. package/dist/chunk-2VPEFXEJ.js +4207 -0
  73. package/dist/chunk-2YC6ZVE4.js +20377 -0
  74. package/dist/chunk-2YC6ZVE4.js.map +7 -0
  75. package/dist/chunk-37MD3Y5G.js +1230 -0
  76. package/dist/chunk-37MD3Y5G.js.map +7 -0
  77. package/dist/chunk-3QHIL3V3.js +55 -0
  78. package/dist/chunk-44VXWKYJ.js +129 -0
  79. package/dist/chunk-52D6EGUS.js +95 -0
  80. package/dist/chunk-5FHM3L4I.js +102 -0
  81. package/dist/chunk-62TF2MCH.js +142 -0
  82. package/dist/chunk-67QM2NUK.js +6364 -0
  83. package/dist/chunk-6AAPHEWK.js +676 -0
  84. package/dist/chunk-6KPGMUHS.js +153 -0
  85. package/dist/chunk-6WBIZXNI.js +455 -0
  86. package/dist/chunk-7AAJVXEG.js +302 -0
  87. package/dist/chunk-AFJRAR4N.js +1271 -0
  88. package/dist/chunk-BBNO6JLO.js +200 -0
  89. package/dist/chunk-BBNO6JLO.js.map +7 -0
  90. package/dist/chunk-CVRYZMDE.js +148 -0
  91. package/dist/chunk-DGUTCYH2.js +276 -0
  92. package/dist/chunk-DHNXATHC.js +158 -0
  93. package/dist/chunk-DXHATYHE.js +180 -0
  94. package/dist/chunk-DXHATYHE.js.map +7 -0
  95. package/dist/chunk-E3BI23UK.js +229 -0
  96. package/dist/chunk-E4JDHA3C.js +621 -0
  97. package/dist/chunk-FOJWYEGV.js +228 -0
  98. package/dist/chunk-FTN7Y34O.js +158 -0
  99. package/dist/chunk-GAOUV4ID.js +1943 -0
  100. package/dist/chunk-GAOUV4ID.js.map +7 -0
  101. package/dist/chunk-GRG5MMPN.js +2815 -0
  102. package/dist/chunk-GSU4PZN3.js +482 -0
  103. package/dist/chunk-I55NLUCQ.js +1823 -0
  104. package/dist/chunk-I55NLUCQ.js.map +7 -0
  105. package/dist/chunk-IIRU2JLK.js +217 -0
  106. package/dist/chunk-JCB74ZSK.js +272 -0
  107. package/dist/chunk-JUDWPYMA.js +824 -0
  108. package/dist/chunk-KT6VZBC7.js +1087 -0
  109. package/dist/chunk-L2HBHFTK.js +2370 -0
  110. package/dist/chunk-LKADRF3Q.js +368 -0
  111. package/dist/chunk-MAXFRUGM.js +407 -0
  112. package/dist/chunk-MQN7RYCK.js +37 -0
  113. package/dist/chunk-OEUI4CYZ.js +470 -0
  114. package/dist/chunk-OM36XUQL.js +34 -0
  115. package/dist/chunk-P5LNIH5X.js +54 -0
  116. package/dist/chunk-PG62PRMF.js +102 -0
  117. package/dist/chunk-Q3J3F2NU.js +205 -0
  118. package/dist/chunk-RYCOJY7M.js +188 -0
  119. package/dist/chunk-RYCOJY7M.js.map +7 -0
  120. package/dist/chunk-RZBV6474.js +117 -0
  121. package/dist/chunk-T5V4OC27.js +442 -0
  122. package/dist/chunk-TXJG4N6S.js +4992 -0
  123. package/dist/chunk-TXJG4N6S.js.map +7 -0
  124. package/dist/chunk-UCKSUNSJ.js +335 -0
  125. package/dist/chunk-W4TLYHZO.js +514 -0
  126. package/dist/chunk-WPZUXKIB.js +56 -0
  127. package/dist/chunk-XM47XD6G.js +215 -0
  128. package/dist/chunk-XVA3UOWD.js +263 -0
  129. package/dist/chunk-XVA3UOWD.js.map +7 -0
  130. package/dist/chunk-YIMRBXQK.js +1210 -0
  131. package/dist/chunk-YIMRBXQK.js.map +7 -0
  132. package/dist/chunk-YL7VT4QT.js +1159 -0
  133. package/dist/chunk-YL7VT4QT.js.map +7 -0
  134. package/dist/chunk-YWBUK4B7.js +291 -0
  135. package/dist/chunk-YWBUK4B7.js.map +7 -0
  136. package/dist/chunk-YZHGLSKQ.js +50 -0
  137. package/dist/chunk-ZGOOZK3I.js +203 -0
  138. package/dist/chunk-ZH2VP6Q6.js +95 -0
  139. package/dist/chunk-ZLOQXO5K.js +14 -0
  140. package/dist/chunk-ZMNDBPJU.js +100 -0
  141. package/dist/chunk-ZRTW6X3F.js +2784 -0
  142. package/dist/chunk-ZTT52MBP.js +2681 -0
  143. package/dist/condition-VUACUQYF.js +330 -0
  144. package/dist/controls-N4MPSNO4.js +39 -0
  145. package/dist/controls.config-PRXVODCM.js +37 -0
  146. package/dist/correlation-QJZUYDFH.js +96 -0
  147. package/dist/cuminc-JJHXW55V.js +1147 -0
  148. package/dist/cuminc.integration.spec-IXS2UO2O.js +676 -0
  149. package/dist/customdata.inputui-DUHO6M6I.js +287 -0
  150. package/dist/dataDownload-OFB7TYDB.js +328 -0
  151. package/dist/dataDownload.integration.spec-4HWDQO4C.js +191 -0
  152. package/dist/databrowser.ui-FGZ5SWG3.js +430 -0
  153. package/dist/databrowser.ui-FGZ5SWG3.js.map +7 -0
  154. package/dist/dictionary-BSKN37CP.js +109 -0
  155. package/dist/dnaMethylation-5QNEEGC6.js +36 -0
  156. package/dist/dnaMethylation.integration.spec-YIX3JSA7.js +201 -0
  157. package/dist/dofetch-KFMGQY7G.js +50 -0
  158. package/dist/e2pca-VX42HDYZ.js +348 -0
  159. package/dist/ep-B6ZNETLI.js +1254 -0
  160. package/dist/expclust.gdc.spec-SGECIILQ.js +305 -0
  161. package/dist/facet-2W5SBPGP.js +519 -0
  162. package/dist/gb-67KTSE2W.js +86 -0
  163. package/dist/gb-67KTSE2W.js.map +7 -0
  164. package/dist/geneExpClustering-6A7364T5.js +247 -0
  165. package/dist/geneExpression-NAM2UEYN.js +36 -0
  166. package/dist/geneExpression-WF56ODMZ.js +312 -0
  167. package/dist/geneExpression.unit.spec-DNE2T3WI.js +100 -0
  168. package/dist/geneORA-33FK2YOS.js +276 -0
  169. package/dist/geneVariant-C7PCNBOQ.js +37 -0
  170. package/dist/geneVariant-REELFRRA.js +39 -0
  171. package/dist/geneVariant.integration.spec-GNXUGDKL.js +196 -0
  172. package/dist/genefusion.ui-WO5EPJDS.js +306 -0
  173. package/dist/geneset-4C6ZLVMN.js +201 -0
  174. package/dist/geneset-4C6ZLVMN.js.map +7 -0
  175. package/dist/genomeBrowser.spec-VPAKTUJF.js +279 -0
  176. package/dist/grin2-AJFEBD43.js +852 -0
  177. package/dist/grin2-AJFEBD43.js.map +7 -0
  178. package/dist/grin2-GYHUYNEF.js +1554 -0
  179. package/dist/gsea-PE5WZ5ZI.js +45 -0
  180. package/dist/hierCluster-FH6YJHRT.js +61 -0
  181. package/dist/hierCluster-IFM5I5QN.js +57 -0
  182. package/dist/hierCluster.config-M57ZIWMB.js +38 -0
  183. package/dist/hierCluster.integration.spec-Z64RL7MC.js +393 -0
  184. package/dist/hierCluster.interactivity-CDBAJXOY.js +52 -0
  185. package/dist/imagePlot-NFEE6IGV.js +161 -0
  186. package/dist/imagePlot-NFEE6IGV.js.map +7 -0
  187. package/dist/importPlot-OWKXSK77.js +8 -0
  188. package/dist/isoformExpression-66XLJG73.js +38 -0
  189. package/dist/isoformExpression.unit.spec-QJX2IRHL.js +206 -0
  190. package/dist/launch.adhoc-JCWID253.js +40 -0
  191. package/dist/leftlabel.sample-5NZ6VQDN.js +257 -0
  192. package/dist/lollipop-BPFDEM2R.js +169 -0
  193. package/dist/lollipop-BPFDEM2R.js.map +7 -0
  194. package/dist/maf-HIS2FQXK.js +450 -0
  195. package/dist/maftimeline-UPJJQE23.js +591 -0
  196. package/dist/matrix-62CN2KXR.js +56 -0
  197. package/dist/matrix-SPEDEB3J.js +61 -0
  198. package/dist/matrix.config-XB6WFXUY.js +39 -0
  199. package/dist/matrix.integration.spec-NN7OR5XM.js +3070 -0
  200. package/dist/matrix.interactivity-OWMHUJCX.js +40 -0
  201. package/dist/matrix.layout-27QB6MWK.js +42 -0
  202. package/dist/matrix.renderers-EPXES5E4.js +36 -0
  203. package/dist/matrix.sort.unit.spec-NBT5FSZ6.js +470 -0
  204. package/dist/matrix.sorterUi.unit.spec-QKGUE4RR.js +340 -0
  205. package/dist/mavb-M7Y74OWQ.js +730 -0
  206. package/dist/mds.fimo-WCDFA7HG.js +516 -0
  207. package/dist/mds.samplescatterplot-ZDHQ3MKJ.js +1548 -0
  208. package/dist/mds.survivalplot-R74DL2RA.js +481 -0
  209. package/dist/oncomatrix-MOITJBII.js +293 -0
  210. package/dist/oncomatrix.spec-NALJBPYS.js +446 -0
  211. package/dist/plot.2dvaf-IE2EZEFA.js +375 -0
  212. package/dist/plot.app-HTW6TZEH.js +39 -0
  213. package/dist/plot.barplot-NCQEPEOY.js +100 -0
  214. package/dist/plot.boxplot-WNKVBVJJ.js +150 -0
  215. package/dist/plot.brainImaging-2Z3TOO6J.js +51 -0
  216. package/dist/plot.disco-4JAEIAYK.js +101 -0
  217. package/dist/plot.dzi-ZGLOVJJN.js +33 -0
  218. package/dist/plot.ssgq-IHUILM43.js +137 -0
  219. package/dist/plot.vaf2cov-ZYCQMD27.js +257 -0
  220. package/dist/plot.wsi-3GISVBDH.js +36 -0
  221. package/dist/polar-4AUAZHBV.js +184 -0
  222. package/dist/polar2-SRD4WWXU.js +226 -0
  223. package/dist/profile.spec-TOITKBBZ.js +78 -0
  224. package/dist/profileBarchart-Z4SYIYBE.js +265 -0
  225. package/dist/profileForms-RA7XQ2QT.js +438 -0
  226. package/dist/profilePlot-4BM3XZVK.js +52 -0
  227. package/dist/profileRadar-EYBESEPI.js +261 -0
  228. package/dist/profileRadarFacility-FZYTFM26.js +261 -0
  229. package/dist/proteinView-F6XKT2A5.js +1122 -0
  230. package/dist/proteinView-F6XKT2A5.js.map +7 -0
  231. package/dist/proteomeAbundance-3RJMRXYI.js +68 -0
  232. package/dist/proteomeAbundance-3RJMRXYI.js.map +7 -0
  233. package/dist/proteomeAbundance-65R6M4YQ.js +21 -0
  234. package/dist/qualitative-E7WL6DN4.js +41 -0
  235. package/dist/radar2-I6FN5SUX.js +314 -0
  236. package/dist/radarFacility2-GVK7PT3V.js +323 -0
  237. package/dist/regression-TIR5D354.js +54 -0
  238. package/dist/regression.inputs-2AMJCJ3L.js +46 -0
  239. package/dist/regression.inputs.term-D6D2QEUB.js +46 -0
  240. package/dist/regression.inputs.values.table-M3IPLGDJ.js +43 -0
  241. package/dist/regression.integration.spec-ROUSXLMH.js +782 -0
  242. package/dist/regression.results-YD5S74YS.js +38 -0
  243. package/dist/regression.spec-4OXBBTNO.js +706 -0
  244. package/dist/report-ETNALKTY.js +220 -0
  245. package/dist/sampleScatter.spec-LECMFMI2.js +200 -0
  246. package/dist/sampleView-B5TM7JOW.js +46 -0
  247. package/dist/samplelst-GFQCG4SS.js +109 -0
  248. package/dist/samplematrix-OMTNWCJK.js +2196 -0
  249. package/dist/sc-MIEEZBWG.js +84 -0
  250. package/dist/scatter-ETOZ722F.js +800 -0
  251. package/dist/scatter.integration.spec-TS4PNRLX.js +1194 -0
  252. package/dist/selectGenomeWithTklst-Y5QIM2JB.js +132 -0
  253. package/dist/singleCellCellType-HOJHZF5W.js +36 -0
  254. package/dist/singleCellCellType.unit.spec-MH5V3RPX.js +158 -0
  255. package/dist/singleCellGeneExpression-YVQ5TIKN.js +36 -0
  256. package/dist/singleCellGeneExpression.unit.spec-BMFFT5HO.js +151 -0
  257. package/dist/singleCellPlot-3YFUYA2Y.js +51 -0
  258. package/dist/singlecell-FK5JETW5.js +1570 -0
  259. package/dist/singlecell-RL7V7DIC.js +84 -0
  260. package/dist/snp-FT7HB3XN.js +36 -0
  261. package/dist/snp.unit.spec-CLYVYPPG.js +174 -0
  262. package/dist/snplocus-M5SEQGAC.js +206 -0
  263. package/dist/spliceevent.a53ss.diagram-EJ5CTRCZ.js +149 -0
  264. package/dist/spliceevent.exonskip.diagram-ETXMOHZ3.js +275 -0
  265. package/dist/spliceevent.noeventdiagram-S2O4ZM2Z.js +458 -0
  266. package/dist/ssGSEA-6PMDQDTJ.js +36 -0
  267. package/dist/ssGSEA.unit.spec-JD5T4R2N.js +86 -0
  268. package/dist/summarizeCnvGeneexp-GCHNKTIU.js +161 -0
  269. package/dist/summarizeGeneexpSurvival-R2RYQZ3M.js +106 -0
  270. package/dist/summarizeMutationCnv-LB2BIYRL.js +162 -0
  271. package/dist/summarizeMutationDiagnosis-3JUY75LM.js +38 -0
  272. package/dist/summarizeMutationSurvival-VYLRWTCF.js +97 -0
  273. package/dist/summary-2QQ72IEQ.js +47 -0
  274. package/dist/summary.integration.spec-XXU362UQ.js +412 -0
  275. package/dist/summaryInput-OZHZG3PV.js +233 -0
  276. package/dist/sunburst-CMCJCANX.js +282 -0
  277. package/dist/survival-EBD4DHO7.js +44 -0
  278. package/dist/survival-ISLRRPKU.js +56 -0
  279. package/dist/survival.integration.spec-FS7V4OXK.js +800 -0
  280. package/dist/svgraph-KGLNUM7W.js +1385 -0
  281. package/dist/svmr-NXZ5VLKH.js +3840 -0
  282. package/dist/table-ISOQOI6C.js +198 -0
  283. package/dist/termCollection-7ZSU3I45.js +36 -0
  284. package/dist/termCollection-V2A5BDQB.js +177 -0
  285. package/dist/termCollection.unit.spec-6VLCJGOU.js +206 -0
  286. package/dist/tk-6AB6XYIE.js +44 -0
  287. package/dist/tp.ui-2O4UW5N7.js +1457 -0
  288. package/dist/tvs.dt-CY6TOQVB.js +37 -0
  289. package/dist/tvs.dtcnv.categorical-AYQ432TW.js +38 -0
  290. package/dist/tvs.dtcnv.continuous-XVDL6SG3.js +70 -0
  291. package/dist/tvs.dtfusion-V3AV7A6Q.js +38 -0
  292. package/dist/tvs.dtsnvindel-XM3NXIT7.js +38 -0
  293. package/dist/tvs.dtsv-Z2GYRINW.js +38 -0
  294. package/dist/tvs.samplelst-C4FB63G7.js +102 -0
  295. package/dist/tvs.termCollection-VHTSC2ST.js +157 -0
  296. package/dist/violin-KGGTUQFF.js +44 -0
  297. package/dist/violin.integration.spec-5EW6PLJX.js +1423 -0
  298. package/dist/violin.interactivity-RI4RURGO.js +36 -0
  299. package/dist/violin.renderer-EWU2IFZE.js +38 -0
  300. package/dist/vocabulary-VLIGC7OP.js +39 -0
  301. package/package.json +3 -3
  302. package/src/databrowser/dictionary.parse.js +14 -2
  303. package/dist/2dmaf-X7LATQT7.js +0 -1371
  304. package/dist/AIProjectAdmin-GUBKURGO.js +0 -830
  305. package/dist/AIProjectAdmin-GUBKURGO.js.map +0 -7
  306. package/dist/AppHeader-RDOFP322.js +0 -833
  307. package/dist/BoxPlot-AZF2EMGQ.js +0 -1217
  308. package/dist/CorrelationVolcano-VXW35SXU.js +0 -617
  309. package/dist/DE-NLGMZ44O.js +0 -93
  310. package/dist/DEinput-OJ7P4UMP.js +0 -297
  311. package/dist/DEinput-OJ7P4UMP.js.map +0 -7
  312. package/dist/DifferentialAnalysis-G75VUHDI.js +0 -241
  313. package/dist/Disco-DX4S44SI.js +0 -3235
  314. package/dist/Disco.UI-5FYIACCU.js +0 -242
  315. package/dist/DmrPlot-HWYITHK2.js +0 -640
  316. package/dist/GB-DBTMRVYH.js +0 -1125
  317. package/dist/GB-DBTMRVYH.js.map +0 -7
  318. package/dist/GeneExpInput-DWB7OYT2.js +0 -335
  319. package/dist/GeneExpInput-DWB7OYT2.js.map +0 -7
  320. package/dist/HicApp-XPZVZXB7.js +0 -2248
  321. package/dist/NumBinaryEditor-M6MJYIHK.js +0 -268
  322. package/dist/NumBinaryEditor.unit.spec-W6MMYDAW.js +0 -284
  323. package/dist/NumContEditor-YRVENTS5.js +0 -105
  324. package/dist/NumContEditor.unit.spec-A6OH4TI7.js +0 -167
  325. package/dist/NumCustomBinEditor-BLBOYSCQ.js +0 -36
  326. package/dist/NumCustomBinEditor.unit.spec-55V5CKLB.js +0 -282
  327. package/dist/NumDiscreteEditor-DTRM6VL2.js +0 -177
  328. package/dist/NumDiscreteEditor.unit.spec-YMB6QRER.js +0 -200
  329. package/dist/NumRegularBinEditor-XW4SVA7S.js +0 -36
  330. package/dist/NumRegularBinEditor.unit.spec-VAHC3VOD.js +0 -225
  331. package/dist/NumSplineEditor-H22HTRFR.js +0 -190
  332. package/dist/NumSplineEditor.unit.spec-4JUADXZR.js +0 -197
  333. package/dist/NumericDensity-ECSZCQRX.js +0 -36
  334. package/dist/NumericDensity.unit.spec-SXXCXM4X.js +0 -219
  335. package/dist/NumericHandler-CMBN3FZX.js +0 -37
  336. package/dist/NumericHandler.unit.spec-UYTJG2Z2.js +0 -217
  337. package/dist/RunChart2-MVFWLXZX.js +0 -756
  338. package/dist/SC-BRC3J2O4.js +0 -797
  339. package/dist/SC-BRC3J2O4.js.map +0 -7
  340. package/dist/Volcano-WMNFZSX2.js +0 -1234
  341. package/dist/Volcano-WMNFZSX2.js.map +0 -7
  342. package/dist/WSIViewer-2Z636FMA.js +0 -47971
  343. package/dist/WsiSamplesPlot-LN75PND3.js +0 -163
  344. package/dist/adSandbox-AJ7QUDOI.js +0 -36
  345. package/dist/alphaGenome-PVCRXAQK.js +0 -173
  346. package/dist/app-DWYCAFRP.js +0 -47
  347. package/dist/app-RENXV7VR.js +0 -35
  348. package/dist/bam-5G6IT6OX.js +0 -857
  349. package/dist/barchart-MLCCU6SU.js +0 -45
  350. package/dist/barchart.events-B6HQTLK2.js +0 -45
  351. package/dist/barchart.integration.spec-S43A7C7N.js +0 -1675
  352. package/dist/barchart2-QMKEN6MN.js +0 -309
  353. package/dist/block-IGBB4BJH.js +0 -6200
  354. package/dist/block.init-NLCYAKV4.js +0 -36
  355. package/dist/block.mds.expressionrank-TZWGRDY7.js +0 -357
  356. package/dist/block.mds.geneboxplot-OAFROYDL.js +0 -826
  357. package/dist/block.mds.junction-NSLXTW3D.js +0 -1543
  358. package/dist/block.mds.svcnv-ICPG4BW6.js +0 -6799
  359. package/dist/block.svg-DTFVIAAC.js +0 -162
  360. package/dist/block.tk.aicheck-ZIMIBWHA.js +0 -281
  361. package/dist/block.tk.ase-I7UNK5BK.js +0 -363
  362. package/dist/block.tk.bam-W7JG46RS.js +0 -1904
  363. package/dist/block.tk.bedgraphdot-XAQJPKGJ.js +0 -382
  364. package/dist/block.tk.bigwig.ui-YQOJPJSG.js +0 -209
  365. package/dist/block.tk.hicstraw-OWWGGCHU.js +0 -821
  366. package/dist/block.tk.junction-V63ZQQX6.js +0 -2362
  367. package/dist/block.tk.junction.textmatrixui-B7KXX7WN.js +0 -197
  368. package/dist/block.tk.ld-2J6CT74S.js +0 -97
  369. package/dist/block.tk.menu-6AQLG7PW.js +0 -1027
  370. package/dist/block.tk.pgv-4V6PKVCQ.js +0 -942
  371. package/dist/brainImaging-WRBGYLHK.js +0 -421
  372. package/dist/chat-X2BCTEDF.js +0 -148
  373. package/dist/chat-X2BCTEDF.js.map +0 -7
  374. package/dist/chunk-23VG37CB.js +0 -1939
  375. package/dist/chunk-23VG37CB.js.map +0 -7
  376. package/dist/chunk-2VOHINOC.js +0 -262
  377. package/dist/chunk-2VOHINOC.js.map +0 -7
  378. package/dist/chunk-3AK6GP4M.js +0 -215
  379. package/dist/chunk-3B7EWIVB.js +0 -153
  380. package/dist/chunk-3JAC5CHL.js +0 -407
  381. package/dist/chunk-3QBZ2Y77.js +0 -188
  382. package/dist/chunk-3QBZ2Y77.js.map +0 -7
  383. package/dist/chunk-3T2PCWII.js +0 -442
  384. package/dist/chunk-4BTAI6HQ.js +0 -100
  385. package/dist/chunk-4JVNATQR.js +0 -621
  386. package/dist/chunk-4ZCR6CPK.js +0 -4964
  387. package/dist/chunk-4ZCR6CPK.js.map +0 -7
  388. package/dist/chunk-5MW5VMWD.js +0 -2784
  389. package/dist/chunk-5ZBEDKBD.js +0 -158
  390. package/dist/chunk-65YTZS3R.js +0 -203
  391. package/dist/chunk-6ZCHECOT.js +0 -1816
  392. package/dist/chunk-6ZCHECOT.js.map +0 -7
  393. package/dist/chunk-73ZT6NAT.js +0 -34
  394. package/dist/chunk-7HJ6H7AZ.js +0 -2681
  395. package/dist/chunk-AFXYPMFZ.js +0 -117
  396. package/dist/chunk-BL4ALBZ7.js +0 -37
  397. package/dist/chunk-BRCDZJBQ.js +0 -824
  398. package/dist/chunk-EBGX226R.js +0 -205
  399. package/dist/chunk-EHXI36HJ.js +0 -2815
  400. package/dist/chunk-ENP4FLOX.js +0 -293
  401. package/dist/chunk-FDOSJKDA.js +0 -1209
  402. package/dist/chunk-FDOSJKDA.js.map +0 -7
  403. package/dist/chunk-HP2BASCY.js +0 -1159
  404. package/dist/chunk-HP2BASCY.js.map +0 -7
  405. package/dist/chunk-HROKXT4K.js +0 -14
  406. package/dist/chunk-HTMXVOTH.js +0 -482
  407. package/dist/chunk-IA7S4UL5.js +0 -302
  408. package/dist/chunk-JFIOYO3M.js +0 -272
  409. package/dist/chunk-JMJW3ERE.js +0 -470
  410. package/dist/chunk-K7XWZSQA.js +0 -148
  411. package/dist/chunk-KSN3EVKI.js +0 -102
  412. package/dist/chunk-L5SOHZ5V.js +0 -229
  413. package/dist/chunk-LMGE54CQ.js +0 -54
  414. package/dist/chunk-LOMVTHAM.js +0 -95
  415. package/dist/chunk-MSW7OS2O.js +0 -276
  416. package/dist/chunk-MVCGSYS2.js +0 -50
  417. package/dist/chunk-N2HBIQKU.js +0 -102
  418. package/dist/chunk-NL3DVEVX.js +0 -158
  419. package/dist/chunk-O4WJSZC3.js +0 -1087
  420. package/dist/chunk-OLUDD6EC.js +0 -2370
  421. package/dist/chunk-OVPVPPRG.js +0 -55
  422. package/dist/chunk-OYEISJSJ.js +0 -289
  423. package/dist/chunk-OYEISJSJ.js.map +0 -7
  424. package/dist/chunk-P2JDCMXW.js +0 -4207
  425. package/dist/chunk-PMDXCESS.js +0 -514
  426. package/dist/chunk-PXYYICV7.js +0 -1271
  427. package/dist/chunk-PZ3KIUWJ.js +0 -56
  428. package/dist/chunk-QEWMCAJW.js +0 -335
  429. package/dist/chunk-QLWDUZ5K.js +0 -129
  430. package/dist/chunk-QRSIID3T.js +0 -95
  431. package/dist/chunk-ST644IDH.js +0 -217
  432. package/dist/chunk-UOOMFM7K.js +0 -6364
  433. package/dist/chunk-VGHSLILD.js +0 -368
  434. package/dist/chunk-W35IOI74.js +0 -228
  435. package/dist/chunk-XKF4KMCB.js +0 -146
  436. package/dist/chunk-XKF4KMCB.js.map +0 -7
  437. package/dist/chunk-XVDWYTJ6.js +0 -676
  438. package/dist/chunk-YQVEBFGT.js +0 -455
  439. package/dist/chunk-YWUVCXFS.js +0 -20271
  440. package/dist/chunk-YWUVCXFS.js.map +0 -7
  441. package/dist/chunk-ZT3PB4XX.js +0 -1150
  442. package/dist/chunk-ZT3PB4XX.js.map +0 -7
  443. package/dist/chunk-ZVSXHCGP.js +0 -142
  444. package/dist/condition-CZX2GSN4.js +0 -330
  445. package/dist/controls-BQR3WY5W.js +0 -39
  446. package/dist/controls.config-TAVZDHFZ.js +0 -37
  447. package/dist/correlation-BIWVZNC6.js +0 -96
  448. package/dist/cuminc-EDXOOI5R.js +0 -1147
  449. package/dist/cuminc.integration.spec-UZA7BDTB.js +0 -676
  450. package/dist/customdata.inputui-PEB4CE7J.js +0 -287
  451. package/dist/dataDownload-KANEHJXJ.js +0 -328
  452. package/dist/dataDownload.integration.spec-23WLHSWJ.js +0 -191
  453. package/dist/databrowser.ui-B2TNECC4.js +0 -419
  454. package/dist/databrowser.ui-B2TNECC4.js.map +0 -7
  455. package/dist/dictionary-YOTUFVES.js +0 -109
  456. package/dist/dnaMethylation-TRFAZWRJ.js +0 -36
  457. package/dist/dnaMethylation.integration.spec-SPFZO76D.js +0 -201
  458. package/dist/dofetch-MH4MRMGY.js +0 -50
  459. package/dist/e2pca-AFVAFUJ2.js +0 -348
  460. package/dist/ep-4FXTLWB4.js +0 -1254
  461. package/dist/expclust.gdc.spec-SFOCKBLR.js +0 -305
  462. package/dist/facet-SY6PYSTN.js +0 -519
  463. package/dist/gb-JUV63QCN.js +0 -93
  464. package/dist/gb-JUV63QCN.js.map +0 -7
  465. package/dist/geneExpClustering-FOY77R7P.js +0 -247
  466. package/dist/geneExpression-AHKX57BT.js +0 -312
  467. package/dist/geneExpression-D2F2KVGY.js +0 -36
  468. package/dist/geneExpression.unit.spec-SR2BGZQL.js +0 -100
  469. package/dist/geneORA-VJMYI4BT.js +0 -276
  470. package/dist/geneVariant-LFM5SO2P.js +0 -37
  471. package/dist/geneVariant-OIKEV4JM.js +0 -39
  472. package/dist/geneVariant.integration.spec-T6BINPIN.js +0 -196
  473. package/dist/genefusion.ui-NLMW5XMI.js +0 -306
  474. package/dist/geneset-HKXFHM5K.js +0 -197
  475. package/dist/geneset-HKXFHM5K.js.map +0 -7
  476. package/dist/genomeBrowser.spec-DRYIFJLY.js +0 -279
  477. package/dist/grin2-GJKLNT4J.js +0 -1031
  478. package/dist/grin2-GJKLNT4J.js.map +0 -7
  479. package/dist/grin2-LGI535FF.js +0 -1554
  480. package/dist/gsea-Z7DSDFOA.js +0 -45
  481. package/dist/hierCluster-HC2B5XRR.js +0 -61
  482. package/dist/hierCluster-PLHVN5S3.js +0 -57
  483. package/dist/hierCluster.config-E3DIJWL5.js +0 -38
  484. package/dist/hierCluster.integration.spec-OQLPUQG4.js +0 -393
  485. package/dist/hierCluster.interactivity-LRNPDTEH.js +0 -52
  486. package/dist/imagePlot-GUXRGYQA.js +0 -139
  487. package/dist/imagePlot-GUXRGYQA.js.map +0 -7
  488. package/dist/importPlot-M5HGLHRO.js +0 -8
  489. package/dist/isoformExpression-PADLHHR5.js +0 -38
  490. package/dist/isoformExpression.unit.spec-5BPAL4OS.js +0 -206
  491. package/dist/launch.adhoc-JH6ZZFDB.js +0 -40
  492. package/dist/leftlabel.sample-NS2TBANH.js +0 -257
  493. package/dist/lollipop-W6NOHHCP.js +0 -166
  494. package/dist/lollipop-W6NOHHCP.js.map +0 -7
  495. package/dist/maf-NOHIKTUP.js +0 -450
  496. package/dist/maftimeline-WGWE52EF.js +0 -591
  497. package/dist/matrix-B6NPQFFF.js +0 -61
  498. package/dist/matrix-UAKRJL5A.js +0 -56
  499. package/dist/matrix.config-KJNJXPJJ.js +0 -39
  500. package/dist/matrix.integration.spec-VAXIR3E6.js +0 -3070
  501. package/dist/matrix.interactivity-H4MCMJXU.js +0 -40
  502. package/dist/matrix.layout-RFKQJM5D.js +0 -42
  503. package/dist/matrix.renderers-7JJIC6VC.js +0 -36
  504. package/dist/matrix.sort.unit.spec-MQQVWWNT.js +0 -470
  505. package/dist/matrix.sorterUi.unit.spec-LG4TI7VF.js +0 -340
  506. package/dist/mavb-EIZHS6F4.js +0 -730
  507. package/dist/mds.fimo-XVC6MI7W.js +0 -516
  508. package/dist/mds.samplescatterplot-PRR4TKYI.js +0 -1548
  509. package/dist/mds.survivalplot-3OG4Y2B6.js +0 -481
  510. package/dist/oncomatrix-SO6S6IIB.js +0 -293
  511. package/dist/oncomatrix.spec-VXTF44K5.js +0 -446
  512. package/dist/plot.2dvaf-JW5OJJXV.js +0 -375
  513. package/dist/plot.app-T3GVCFQ3.js +0 -39
  514. package/dist/plot.barplot-2TYP6DPI.js +0 -100
  515. package/dist/plot.boxplot-HOQHM7JF.js +0 -150
  516. package/dist/plot.brainImaging-5AI7BSD4.js +0 -51
  517. package/dist/plot.disco-HNNZHK5Z.js +0 -101
  518. package/dist/plot.dzi-4OQSO7SY.js +0 -33
  519. package/dist/plot.ssgq-VZTTGECT.js +0 -137
  520. package/dist/plot.vaf2cov-ASEELRDV.js +0 -257
  521. package/dist/plot.wsi-MDWYLU4R.js +0 -36
  522. package/dist/polar-QSY6JG4P.js +0 -184
  523. package/dist/polar2-FD6656VD.js +0 -226
  524. package/dist/profile.spec-V7EQBXT2.js +0 -78
  525. package/dist/profileBarchart-EIKHZAPD.js +0 -265
  526. package/dist/profileForms-NGFRXPFF.js +0 -438
  527. package/dist/profilePlot-2UFKJ2OC.js +0 -52
  528. package/dist/profileRadar-B2R7OV5F.js +0 -261
  529. package/dist/profileRadarFacility-ILC7POCI.js +0 -261
  530. package/dist/proteinView-AS6ZV2JT.js +0 -758
  531. package/dist/proteinView-AS6ZV2JT.js.map +0 -7
  532. package/dist/proteomeAbundance-6J5YF4V2.js +0 -63
  533. package/dist/proteomeAbundance-6J5YF4V2.js.map +0 -7
  534. package/dist/proteomeAbundance-OF27N347.js +0 -21
  535. package/dist/qualitative-CSUO2WG5.js +0 -41
  536. package/dist/radar2-L2HGCUYR.js +0 -314
  537. package/dist/radarFacility2-HXUUTRYO.js +0 -323
  538. package/dist/regression-Y4NYGZSA.js +0 -54
  539. package/dist/regression.inputs-RWFIJLNF.js +0 -46
  540. package/dist/regression.inputs.term-QIU5SHTN.js +0 -46
  541. package/dist/regression.inputs.values.table-FM6QTSEV.js +0 -43
  542. package/dist/regression.integration.spec-YRKKU7HL.js +0 -782
  543. package/dist/regression.results-YUDCHUZJ.js +0 -38
  544. package/dist/regression.spec-G4GIIV32.js +0 -706
  545. package/dist/report-2N4FBR4Q.js +0 -220
  546. package/dist/sampleScatter.spec-UIUYO4WR.js +0 -200
  547. package/dist/sampleView-TOK5Y5KU.js +0 -46
  548. package/dist/samplelst-YW5ZS3GJ.js +0 -109
  549. package/dist/samplematrix-447BHSO7.js +0 -2196
  550. package/dist/sc-O2PL3FL2.js +0 -84
  551. package/dist/scatter-4DXHOWVY.js +0 -800
  552. package/dist/scatter.integration.spec-ZPTM3AGQ.js +0 -1194
  553. package/dist/selectGenomeWithTklst-3RLZFW62.js +0 -132
  554. package/dist/singleCellCellType-3LQJXS7H.js +0 -36
  555. package/dist/singleCellCellType.unit.spec-UJM72SP4.js +0 -158
  556. package/dist/singleCellGeneExpression-JOWJWPIQ.js +0 -36
  557. package/dist/singleCellGeneExpression.unit.spec-VY5CGRZH.js +0 -151
  558. package/dist/singleCellPlot-IVLVKOO6.js +0 -51
  559. package/dist/singlecell-VJJZJZF7.js +0 -1570
  560. package/dist/singlecell-VQJ2252L.js +0 -84
  561. package/dist/snp-ALMKZKL2.js +0 -36
  562. package/dist/snp.unit.spec-GJQBAHGQ.js +0 -174
  563. package/dist/snplocus-WCNCMFWZ.js +0 -206
  564. package/dist/spliceevent.a53ss.diagram-4Q4JF4RX.js +0 -149
  565. package/dist/spliceevent.exonskip.diagram-IOYOKELT.js +0 -275
  566. package/dist/spliceevent.noeventdiagram-77ZCOHSF.js +0 -458
  567. package/dist/ssGSEA-QTXXIN4K.js +0 -36
  568. package/dist/ssGSEA.unit.spec-LQESATT3.js +0 -86
  569. package/dist/summarizeCnvGeneexp-YKUQGDQF.js +0 -161
  570. package/dist/summarizeGeneexpSurvival-ARGG5VDC.js +0 -106
  571. package/dist/summarizeMutationCnv-FMZYT3EC.js +0 -162
  572. package/dist/summarizeMutationDiagnosis-ZX7I46SC.js +0 -38
  573. package/dist/summarizeMutationSurvival-RCFMTT43.js +0 -97
  574. package/dist/summary-QLL5YVI2.js +0 -47
  575. package/dist/summary.integration.spec-DHY6XCEJ.js +0 -412
  576. package/dist/summaryInput-ANCUQGIB.js +0 -233
  577. package/dist/sunburst-RDNFBOCK.js +0 -282
  578. package/dist/survival-BG7QV52L.js +0 -44
  579. package/dist/survival-WSN36OQE.js +0 -56
  580. package/dist/survival.integration.spec-37KAJ5IK.js +0 -800
  581. package/dist/svgraph-A5WGHW4S.js +0 -1385
  582. package/dist/svmr-CYRHHWZF.js +0 -3840
  583. package/dist/table-VHO7E5PI.js +0 -198
  584. package/dist/termCollection-E4Q6GLXN.js +0 -177
  585. package/dist/termCollection-HSVSH7TJ.js +0 -36
  586. package/dist/termCollection.unit.spec-ZCE3TUMS.js +0 -206
  587. package/dist/tk-GPRHDN4K.js +0 -44
  588. package/dist/tp.ui-LTUA3FSL.js +0 -1457
  589. package/dist/tvs.dt-G43PAAKD.js +0 -37
  590. package/dist/tvs.dtcnv.categorical-UHDS2TGZ.js +0 -38
  591. package/dist/tvs.dtcnv.continuous-ZNGYQKTD.js +0 -70
  592. package/dist/tvs.dtfusion-JBEEUDUS.js +0 -38
  593. package/dist/tvs.dtsnvindel-XXN5Q7RN.js +0 -38
  594. package/dist/tvs.dtsv-MO6L7HHV.js +0 -38
  595. package/dist/tvs.samplelst-HKY6UUJM.js +0 -102
  596. package/dist/tvs.termCollection-TY6FPL25.js +0 -157
  597. package/dist/violin-YHE3WSGR.js +0 -44
  598. package/dist/violin.integration.spec-F2UD7BHC.js +0 -1423
  599. package/dist/violin.interactivity-LVDTDEPQ.js +0 -36
  600. package/dist/violin.renderer-IIEIUGRI.js +0 -38
  601. package/dist/vocabulary-WQRYXBRO.js +0 -39
  602. /package/dist/{2dmaf-X7LATQT7.js.map → 2dmaf-F5QNP7AQ.js.map} +0 -0
  603. /package/dist/{AppHeader-RDOFP322.js.map → AppHeader-STVCDLET.js.map} +0 -0
  604. /package/dist/{BoxPlot-AZF2EMGQ.js.map → BoxPlot-CU7MEBH7.js.map} +0 -0
  605. /package/dist/{CorrelationVolcano-VXW35SXU.js.map → CorrelationVolcano-OE4R2GS3.js.map} +0 -0
  606. /package/dist/{DE-NLGMZ44O.js.map → DE-SR7PJPKI.js.map} +0 -0
  607. /package/dist/{DifferentialAnalysis-G75VUHDI.js.map → DifferentialAnalysis-UWTYK7NU.js.map} +0 -0
  608. /package/dist/{Disco-DX4S44SI.js.map → Disco-IL6REGSA.js.map} +0 -0
  609. /package/dist/{Disco.UI-5FYIACCU.js.map → Disco.UI-JHHLS5BA.js.map} +0 -0
  610. /package/dist/{DmrPlot-HWYITHK2.js.map → DmrPlot-DDP53T3F.js.map} +0 -0
  611. /package/dist/{HicApp-XPZVZXB7.js.map → HicApp-RVFHTYED.js.map} +0 -0
  612. /package/dist/{NumBinaryEditor-M6MJYIHK.js.map → NumBinaryEditor-B3FXQAOH.js.map} +0 -0
  613. /package/dist/{NumBinaryEditor.unit.spec-W6MMYDAW.js.map → NumBinaryEditor.unit.spec-75YQJ2U6.js.map} +0 -0
  614. /package/dist/{NumContEditor-YRVENTS5.js.map → NumContEditor-5PYW3OLY.js.map} +0 -0
  615. /package/dist/{NumContEditor.unit.spec-A6OH4TI7.js.map → NumContEditor.unit.spec-F7ZRDGBN.js.map} +0 -0
  616. /package/dist/{NumCustomBinEditor-BLBOYSCQ.js.map → NumCustomBinEditor-TBT6GLYQ.js.map} +0 -0
  617. /package/dist/{NumCustomBinEditor.unit.spec-55V5CKLB.js.map → NumCustomBinEditor.unit.spec-6YHU45XV.js.map} +0 -0
  618. /package/dist/{NumDiscreteEditor-DTRM6VL2.js.map → NumDiscreteEditor-N6OJYSJA.js.map} +0 -0
  619. /package/dist/{NumDiscreteEditor.unit.spec-YMB6QRER.js.map → NumDiscreteEditor.unit.spec-HQS5RZ6R.js.map} +0 -0
  620. /package/dist/{NumRegularBinEditor-XW4SVA7S.js.map → NumRegularBinEditor-HSDDKVNG.js.map} +0 -0
  621. /package/dist/{NumRegularBinEditor.unit.spec-VAHC3VOD.js.map → NumRegularBinEditor.unit.spec-33KN2MVM.js.map} +0 -0
  622. /package/dist/{NumSplineEditor-H22HTRFR.js.map → NumSplineEditor-XERKOACS.js.map} +0 -0
  623. /package/dist/{NumSplineEditor.unit.spec-4JUADXZR.js.map → NumSplineEditor.unit.spec-MPVM6KSC.js.map} +0 -0
  624. /package/dist/{NumericDensity-ECSZCQRX.js.map → NumericDensity-35EKYW3V.js.map} +0 -0
  625. /package/dist/{NumericDensity.unit.spec-SXXCXM4X.js.map → NumericDensity.unit.spec-OR24PPRJ.js.map} +0 -0
  626. /package/dist/{NumericHandler-CMBN3FZX.js.map → NumericHandler-D6ZNGRE3.js.map} +0 -0
  627. /package/dist/{NumericHandler.unit.spec-UYTJG2Z2.js.map → NumericHandler.unit.spec-EKPGVSXI.js.map} +0 -0
  628. /package/dist/{RunChart2-MVFWLXZX.js.map → RunChart2-7DOXOFXV.js.map} +0 -0
  629. /package/dist/{WSIViewer-2Z636FMA.js.map → WSIViewer-E247ELKN.js.map} +0 -0
  630. /package/dist/{WsiSamplesPlot-LN75PND3.js.map → WsiSamplesPlot-3522VRB5.js.map} +0 -0
  631. /package/dist/{adSandbox-AJ7QUDOI.js.map → adSandbox-IDFY5P2P.js.map} +0 -0
  632. /package/dist/{alphaGenome-PVCRXAQK.js.map → alphaGenome-F3W7GJQ5.js.map} +0 -0
  633. /package/dist/{app-DWYCAFRP.js.map → app-2HDSFMRM.js.map} +0 -0
  634. /package/dist/{app-RENXV7VR.js.map → app-LIWPFL7C.js.map} +0 -0
  635. /package/dist/{bam-5G6IT6OX.js.map → bam-TBHHSATL.js.map} +0 -0
  636. /package/dist/{barchart-MLCCU6SU.js.map → barchart-HHFCBOZE.js.map} +0 -0
  637. /package/dist/{barchart.events-B6HQTLK2.js.map → barchart.events-UQUSSRXB.js.map} +0 -0
  638. /package/dist/{barchart.integration.spec-S43A7C7N.js.map → barchart.integration.spec-OF3MWFQ5.js.map} +0 -0
  639. /package/dist/{barchart2-QMKEN6MN.js.map → barchart2-XRMPCBBU.js.map} +0 -0
  640. /package/dist/{block-IGBB4BJH.js.map → block-5UEORHFB.js.map} +0 -0
  641. /package/dist/{block.init-NLCYAKV4.js.map → block.init-QSSFUVIT.js.map} +0 -0
  642. /package/dist/{block.mds.expressionrank-TZWGRDY7.js.map → block.mds.expressionrank-VBIIJHQF.js.map} +0 -0
  643. /package/dist/{block.mds.geneboxplot-OAFROYDL.js.map → block.mds.geneboxplot-KSBHXBNX.js.map} +0 -0
  644. /package/dist/{block.mds.junction-NSLXTW3D.js.map → block.mds.junction-FWZWMZJ2.js.map} +0 -0
  645. /package/dist/{block.mds.svcnv-ICPG4BW6.js.map → block.mds.svcnv-UXORVLH2.js.map} +0 -0
  646. /package/dist/{block.svg-DTFVIAAC.js.map → block.svg-6KIGW4QH.js.map} +0 -0
  647. /package/dist/{block.tk.aicheck-ZIMIBWHA.js.map → block.tk.aicheck-DK566Q4C.js.map} +0 -0
  648. /package/dist/{block.tk.ase-I7UNK5BK.js.map → block.tk.ase-2GB2VJJ6.js.map} +0 -0
  649. /package/dist/{block.tk.bam-W7JG46RS.js.map → block.tk.bam-RQNOLY52.js.map} +0 -0
  650. /package/dist/{block.tk.bedgraphdot-XAQJPKGJ.js.map → block.tk.bedgraphdot-N4YMZFO4.js.map} +0 -0
  651. /package/dist/{block.tk.bigwig.ui-YQOJPJSG.js.map → block.tk.bigwig.ui-4S7L7D7D.js.map} +0 -0
  652. /package/dist/{block.tk.hicstraw-OWWGGCHU.js.map → block.tk.hicstraw-AHFNQKCS.js.map} +0 -0
  653. /package/dist/{block.tk.junction-V63ZQQX6.js.map → block.tk.junction-7E6SNQMQ.js.map} +0 -0
  654. /package/dist/{block.tk.junction.textmatrixui-B7KXX7WN.js.map → block.tk.junction.textmatrixui-3C5JVYX5.js.map} +0 -0
  655. /package/dist/{block.tk.ld-2J6CT74S.js.map → block.tk.ld-TOUCLT3W.js.map} +0 -0
  656. /package/dist/{block.tk.menu-6AQLG7PW.js.map → block.tk.menu-JCV5ORD6.js.map} +0 -0
  657. /package/dist/{block.tk.pgv-4V6PKVCQ.js.map → block.tk.pgv-CUU22U6M.js.map} +0 -0
  658. /package/dist/{brainImaging-WRBGYLHK.js.map → brainImaging-MTQTXNNL.js.map} +0 -0
  659. /package/dist/{chunk-ENP4FLOX.js.map → chunk-2UYBBUXK.js.map} +0 -0
  660. /package/dist/{chunk-P2JDCMXW.js.map → chunk-2VPEFXEJ.js.map} +0 -0
  661. /package/dist/{chunk-OVPVPPRG.js.map → chunk-3QHIL3V3.js.map} +0 -0
  662. /package/dist/{chunk-QLWDUZ5K.js.map → chunk-44VXWKYJ.js.map} +0 -0
  663. /package/dist/{chunk-QRSIID3T.js.map → chunk-52D6EGUS.js.map} +0 -0
  664. /package/dist/{chunk-N2HBIQKU.js.map → chunk-5FHM3L4I.js.map} +0 -0
  665. /package/dist/{chunk-ZVSXHCGP.js.map → chunk-62TF2MCH.js.map} +0 -0
  666. /package/dist/{chunk-UOOMFM7K.js.map → chunk-67QM2NUK.js.map} +0 -0
  667. /package/dist/{chunk-XVDWYTJ6.js.map → chunk-6AAPHEWK.js.map} +0 -0
  668. /package/dist/{chunk-3B7EWIVB.js.map → chunk-6KPGMUHS.js.map} +0 -0
  669. /package/dist/{chunk-YQVEBFGT.js.map → chunk-6WBIZXNI.js.map} +0 -0
  670. /package/dist/{chunk-IA7S4UL5.js.map → chunk-7AAJVXEG.js.map} +0 -0
  671. /package/dist/{chunk-PXYYICV7.js.map → chunk-AFJRAR4N.js.map} +0 -0
  672. /package/dist/{chunk-K7XWZSQA.js.map → chunk-CVRYZMDE.js.map} +0 -0
  673. /package/dist/{chunk-MSW7OS2O.js.map → chunk-DGUTCYH2.js.map} +0 -0
  674. /package/dist/{chunk-5ZBEDKBD.js.map → chunk-DHNXATHC.js.map} +0 -0
  675. /package/dist/{chunk-L5SOHZ5V.js.map → chunk-E3BI23UK.js.map} +0 -0
  676. /package/dist/{chunk-4JVNATQR.js.map → chunk-E4JDHA3C.js.map} +0 -0
  677. /package/dist/{chunk-W35IOI74.js.map → chunk-FOJWYEGV.js.map} +0 -0
  678. /package/dist/{chunk-NL3DVEVX.js.map → chunk-FTN7Y34O.js.map} +0 -0
  679. /package/dist/{chunk-EHXI36HJ.js.map → chunk-GRG5MMPN.js.map} +0 -0
  680. /package/dist/{chunk-HTMXVOTH.js.map → chunk-GSU4PZN3.js.map} +0 -0
  681. /package/dist/{chunk-ST644IDH.js.map → chunk-IIRU2JLK.js.map} +0 -0
  682. /package/dist/{chunk-JFIOYO3M.js.map → chunk-JCB74ZSK.js.map} +0 -0
  683. /package/dist/{chunk-BRCDZJBQ.js.map → chunk-JUDWPYMA.js.map} +0 -0
  684. /package/dist/{chunk-O4WJSZC3.js.map → chunk-KT6VZBC7.js.map} +0 -0
  685. /package/dist/{chunk-OLUDD6EC.js.map → chunk-L2HBHFTK.js.map} +0 -0
  686. /package/dist/{chunk-VGHSLILD.js.map → chunk-LKADRF3Q.js.map} +0 -0
  687. /package/dist/{chunk-3JAC5CHL.js.map → chunk-MAXFRUGM.js.map} +0 -0
  688. /package/dist/{chunk-BL4ALBZ7.js.map → chunk-MQN7RYCK.js.map} +0 -0
  689. /package/dist/{chunk-JMJW3ERE.js.map → chunk-OEUI4CYZ.js.map} +0 -0
  690. /package/dist/{chunk-73ZT6NAT.js.map → chunk-OM36XUQL.js.map} +0 -0
  691. /package/dist/{chunk-LMGE54CQ.js.map → chunk-P5LNIH5X.js.map} +0 -0
  692. /package/dist/{chunk-KSN3EVKI.js.map → chunk-PG62PRMF.js.map} +0 -0
  693. /package/dist/{chunk-EBGX226R.js.map → chunk-Q3J3F2NU.js.map} +0 -0
  694. /package/dist/{chunk-AFXYPMFZ.js.map → chunk-RZBV6474.js.map} +0 -0
  695. /package/dist/{chunk-3T2PCWII.js.map → chunk-T5V4OC27.js.map} +0 -0
  696. /package/dist/{chunk-QEWMCAJW.js.map → chunk-UCKSUNSJ.js.map} +0 -0
  697. /package/dist/{chunk-PMDXCESS.js.map → chunk-W4TLYHZO.js.map} +0 -0
  698. /package/dist/{chunk-PZ3KIUWJ.js.map → chunk-WPZUXKIB.js.map} +0 -0
  699. /package/dist/{chunk-3AK6GP4M.js.map → chunk-XM47XD6G.js.map} +0 -0
  700. /package/dist/{chunk-MVCGSYS2.js.map → chunk-YZHGLSKQ.js.map} +0 -0
  701. /package/dist/{chunk-65YTZS3R.js.map → chunk-ZGOOZK3I.js.map} +0 -0
  702. /package/dist/{chunk-LOMVTHAM.js.map → chunk-ZH2VP6Q6.js.map} +0 -0
  703. /package/dist/{chunk-HROKXT4K.js.map → chunk-ZLOQXO5K.js.map} +0 -0
  704. /package/dist/{chunk-4BTAI6HQ.js.map → chunk-ZMNDBPJU.js.map} +0 -0
  705. /package/dist/{chunk-5MW5VMWD.js.map → chunk-ZRTW6X3F.js.map} +0 -0
  706. /package/dist/{chunk-7HJ6H7AZ.js.map → chunk-ZTT52MBP.js.map} +0 -0
  707. /package/dist/{condition-CZX2GSN4.js.map → condition-VUACUQYF.js.map} +0 -0
  708. /package/dist/{controls-BQR3WY5W.js.map → controls-N4MPSNO4.js.map} +0 -0
  709. /package/dist/{controls.config-TAVZDHFZ.js.map → controls.config-PRXVODCM.js.map} +0 -0
  710. /package/dist/{correlation-BIWVZNC6.js.map → correlation-QJZUYDFH.js.map} +0 -0
  711. /package/dist/{cuminc-EDXOOI5R.js.map → cuminc-JJHXW55V.js.map} +0 -0
  712. /package/dist/{cuminc.integration.spec-UZA7BDTB.js.map → cuminc.integration.spec-IXS2UO2O.js.map} +0 -0
  713. /package/dist/{customdata.inputui-PEB4CE7J.js.map → customdata.inputui-DUHO6M6I.js.map} +0 -0
  714. /package/dist/{dataDownload-KANEHJXJ.js.map → dataDownload-OFB7TYDB.js.map} +0 -0
  715. /package/dist/{dataDownload.integration.spec-23WLHSWJ.js.map → dataDownload.integration.spec-4HWDQO4C.js.map} +0 -0
  716. /package/dist/{dictionary-YOTUFVES.js.map → dictionary-BSKN37CP.js.map} +0 -0
  717. /package/dist/{dnaMethylation-TRFAZWRJ.js.map → dnaMethylation-5QNEEGC6.js.map} +0 -0
  718. /package/dist/{dnaMethylation.integration.spec-SPFZO76D.js.map → dnaMethylation.integration.spec-YIX3JSA7.js.map} +0 -0
  719. /package/dist/{dofetch-MH4MRMGY.js.map → dofetch-KFMGQY7G.js.map} +0 -0
  720. /package/dist/{e2pca-AFVAFUJ2.js.map → e2pca-VX42HDYZ.js.map} +0 -0
  721. /package/dist/{ep-4FXTLWB4.js.map → ep-B6ZNETLI.js.map} +0 -0
  722. /package/dist/{expclust.gdc.spec-SFOCKBLR.js.map → expclust.gdc.spec-SGECIILQ.js.map} +0 -0
  723. /package/dist/{facet-SY6PYSTN.js.map → facet-2W5SBPGP.js.map} +0 -0
  724. /package/dist/{geneExpClustering-FOY77R7P.js.map → geneExpClustering-6A7364T5.js.map} +0 -0
  725. /package/dist/{geneExpression-D2F2KVGY.js.map → geneExpression-NAM2UEYN.js.map} +0 -0
  726. /package/dist/{geneExpression-AHKX57BT.js.map → geneExpression-WF56ODMZ.js.map} +0 -0
  727. /package/dist/{geneExpression.unit.spec-SR2BGZQL.js.map → geneExpression.unit.spec-DNE2T3WI.js.map} +0 -0
  728. /package/dist/{geneORA-VJMYI4BT.js.map → geneORA-33FK2YOS.js.map} +0 -0
  729. /package/dist/{geneVariant-LFM5SO2P.js.map → geneVariant-C7PCNBOQ.js.map} +0 -0
  730. /package/dist/{geneVariant-OIKEV4JM.js.map → geneVariant-REELFRRA.js.map} +0 -0
  731. /package/dist/{geneVariant.integration.spec-T6BINPIN.js.map → geneVariant.integration.spec-GNXUGDKL.js.map} +0 -0
  732. /package/dist/{genefusion.ui-NLMW5XMI.js.map → genefusion.ui-WO5EPJDS.js.map} +0 -0
  733. /package/dist/{genomeBrowser.spec-DRYIFJLY.js.map → genomeBrowser.spec-VPAKTUJF.js.map} +0 -0
  734. /package/dist/{grin2-LGI535FF.js.map → grin2-GYHUYNEF.js.map} +0 -0
  735. /package/dist/{gsea-Z7DSDFOA.js.map → gsea-PE5WZ5ZI.js.map} +0 -0
  736. /package/dist/{hierCluster-HC2B5XRR.js.map → hierCluster-FH6YJHRT.js.map} +0 -0
  737. /package/dist/{hierCluster-PLHVN5S3.js.map → hierCluster-IFM5I5QN.js.map} +0 -0
  738. /package/dist/{hierCluster.config-E3DIJWL5.js.map → hierCluster.config-M57ZIWMB.js.map} +0 -0
  739. /package/dist/{hierCluster.integration.spec-OQLPUQG4.js.map → hierCluster.integration.spec-Z64RL7MC.js.map} +0 -0
  740. /package/dist/{hierCluster.interactivity-LRNPDTEH.js.map → hierCluster.interactivity-CDBAJXOY.js.map} +0 -0
  741. /package/dist/{importPlot-M5HGLHRO.js.map → importPlot-OWKXSK77.js.map} +0 -0
  742. /package/dist/{isoformExpression-PADLHHR5.js.map → isoformExpression-66XLJG73.js.map} +0 -0
  743. /package/dist/{isoformExpression.unit.spec-5BPAL4OS.js.map → isoformExpression.unit.spec-QJX2IRHL.js.map} +0 -0
  744. /package/dist/{launch.adhoc-JH6ZZFDB.js.map → launch.adhoc-JCWID253.js.map} +0 -0
  745. /package/dist/{leftlabel.sample-NS2TBANH.js.map → leftlabel.sample-5NZ6VQDN.js.map} +0 -0
  746. /package/dist/{maf-NOHIKTUP.js.map → maf-HIS2FQXK.js.map} +0 -0
  747. /package/dist/{maftimeline-WGWE52EF.js.map → maftimeline-UPJJQE23.js.map} +0 -0
  748. /package/dist/{matrix-B6NPQFFF.js.map → matrix-62CN2KXR.js.map} +0 -0
  749. /package/dist/{matrix-UAKRJL5A.js.map → matrix-SPEDEB3J.js.map} +0 -0
  750. /package/dist/{matrix.config-KJNJXPJJ.js.map → matrix.config-XB6WFXUY.js.map} +0 -0
  751. /package/dist/{matrix.integration.spec-VAXIR3E6.js.map → matrix.integration.spec-NN7OR5XM.js.map} +0 -0
  752. /package/dist/{matrix.interactivity-H4MCMJXU.js.map → matrix.interactivity-OWMHUJCX.js.map} +0 -0
  753. /package/dist/{matrix.layout-RFKQJM5D.js.map → matrix.layout-27QB6MWK.js.map} +0 -0
  754. /package/dist/{matrix.renderers-7JJIC6VC.js.map → matrix.renderers-EPXES5E4.js.map} +0 -0
  755. /package/dist/{matrix.sort.unit.spec-MQQVWWNT.js.map → matrix.sort.unit.spec-NBT5FSZ6.js.map} +0 -0
  756. /package/dist/{matrix.sorterUi.unit.spec-LG4TI7VF.js.map → matrix.sorterUi.unit.spec-QKGUE4RR.js.map} +0 -0
  757. /package/dist/{mavb-EIZHS6F4.js.map → mavb-M7Y74OWQ.js.map} +0 -0
  758. /package/dist/{mds.fimo-XVC6MI7W.js.map → mds.fimo-WCDFA7HG.js.map} +0 -0
  759. /package/dist/{mds.samplescatterplot-PRR4TKYI.js.map → mds.samplescatterplot-ZDHQ3MKJ.js.map} +0 -0
  760. /package/dist/{mds.survivalplot-3OG4Y2B6.js.map → mds.survivalplot-R74DL2RA.js.map} +0 -0
  761. /package/dist/{oncomatrix-SO6S6IIB.js.map → oncomatrix-MOITJBII.js.map} +0 -0
  762. /package/dist/{oncomatrix.spec-VXTF44K5.js.map → oncomatrix.spec-NALJBPYS.js.map} +0 -0
  763. /package/dist/{plot.2dvaf-JW5OJJXV.js.map → plot.2dvaf-IE2EZEFA.js.map} +0 -0
  764. /package/dist/{plot.app-T3GVCFQ3.js.map → plot.app-HTW6TZEH.js.map} +0 -0
  765. /package/dist/{plot.barplot-2TYP6DPI.js.map → plot.barplot-NCQEPEOY.js.map} +0 -0
  766. /package/dist/{plot.boxplot-HOQHM7JF.js.map → plot.boxplot-WNKVBVJJ.js.map} +0 -0
  767. /package/dist/{plot.brainImaging-5AI7BSD4.js.map → plot.brainImaging-2Z3TOO6J.js.map} +0 -0
  768. /package/dist/{plot.disco-HNNZHK5Z.js.map → plot.disco-4JAEIAYK.js.map} +0 -0
  769. /package/dist/{plot.dzi-4OQSO7SY.js.map → plot.dzi-ZGLOVJJN.js.map} +0 -0
  770. /package/dist/{plot.ssgq-VZTTGECT.js.map → plot.ssgq-IHUILM43.js.map} +0 -0
  771. /package/dist/{plot.vaf2cov-ASEELRDV.js.map → plot.vaf2cov-ZYCQMD27.js.map} +0 -0
  772. /package/dist/{plot.wsi-MDWYLU4R.js.map → plot.wsi-3GISVBDH.js.map} +0 -0
  773. /package/dist/{polar-QSY6JG4P.js.map → polar-4AUAZHBV.js.map} +0 -0
  774. /package/dist/{polar2-FD6656VD.js.map → polar2-SRD4WWXU.js.map} +0 -0
  775. /package/dist/{profile.spec-V7EQBXT2.js.map → profile.spec-TOITKBBZ.js.map} +0 -0
  776. /package/dist/{profileBarchart-EIKHZAPD.js.map → profileBarchart-Z4SYIYBE.js.map} +0 -0
  777. /package/dist/{profileForms-NGFRXPFF.js.map → profileForms-RA7XQ2QT.js.map} +0 -0
  778. /package/dist/{profilePlot-2UFKJ2OC.js.map → profilePlot-4BM3XZVK.js.map} +0 -0
  779. /package/dist/{profileRadar-B2R7OV5F.js.map → profileRadar-EYBESEPI.js.map} +0 -0
  780. /package/dist/{profileRadarFacility-ILC7POCI.js.map → profileRadarFacility-FZYTFM26.js.map} +0 -0
  781. /package/dist/{proteomeAbundance-OF27N347.js.map → proteomeAbundance-65R6M4YQ.js.map} +0 -0
  782. /package/dist/{qualitative-CSUO2WG5.js.map → qualitative-E7WL6DN4.js.map} +0 -0
  783. /package/dist/{radar2-L2HGCUYR.js.map → radar2-I6FN5SUX.js.map} +0 -0
  784. /package/dist/{radarFacility2-HXUUTRYO.js.map → radarFacility2-GVK7PT3V.js.map} +0 -0
  785. /package/dist/{regression-Y4NYGZSA.js.map → regression-TIR5D354.js.map} +0 -0
  786. /package/dist/{regression.inputs-RWFIJLNF.js.map → regression.inputs-2AMJCJ3L.js.map} +0 -0
  787. /package/dist/{regression.inputs.term-QIU5SHTN.js.map → regression.inputs.term-D6D2QEUB.js.map} +0 -0
  788. /package/dist/{regression.inputs.values.table-FM6QTSEV.js.map → regression.inputs.values.table-M3IPLGDJ.js.map} +0 -0
  789. /package/dist/{regression.integration.spec-YRKKU7HL.js.map → regression.integration.spec-ROUSXLMH.js.map} +0 -0
  790. /package/dist/{regression.results-YUDCHUZJ.js.map → regression.results-YD5S74YS.js.map} +0 -0
  791. /package/dist/{regression.spec-G4GIIV32.js.map → regression.spec-4OXBBTNO.js.map} +0 -0
  792. /package/dist/{report-2N4FBR4Q.js.map → report-ETNALKTY.js.map} +0 -0
  793. /package/dist/{sampleScatter.spec-UIUYO4WR.js.map → sampleScatter.spec-LECMFMI2.js.map} +0 -0
  794. /package/dist/{sampleView-TOK5Y5KU.js.map → sampleView-B5TM7JOW.js.map} +0 -0
  795. /package/dist/{samplelst-YW5ZS3GJ.js.map → samplelst-GFQCG4SS.js.map} +0 -0
  796. /package/dist/{samplematrix-447BHSO7.js.map → samplematrix-OMTNWCJK.js.map} +0 -0
  797. /package/dist/{sc-O2PL3FL2.js.map → sc-MIEEZBWG.js.map} +0 -0
  798. /package/dist/{scatter-4DXHOWVY.js.map → scatter-ETOZ722F.js.map} +0 -0
  799. /package/dist/{scatter.integration.spec-ZPTM3AGQ.js.map → scatter.integration.spec-TS4PNRLX.js.map} +0 -0
  800. /package/dist/{selectGenomeWithTklst-3RLZFW62.js.map → selectGenomeWithTklst-Y5QIM2JB.js.map} +0 -0
  801. /package/dist/{singleCellCellType-3LQJXS7H.js.map → singleCellCellType-HOJHZF5W.js.map} +0 -0
  802. /package/dist/{singleCellCellType.unit.spec-UJM72SP4.js.map → singleCellCellType.unit.spec-MH5V3RPX.js.map} +0 -0
  803. /package/dist/{singleCellGeneExpression-JOWJWPIQ.js.map → singleCellGeneExpression-YVQ5TIKN.js.map} +0 -0
  804. /package/dist/{singleCellGeneExpression.unit.spec-VY5CGRZH.js.map → singleCellGeneExpression.unit.spec-BMFFT5HO.js.map} +0 -0
  805. /package/dist/{singleCellPlot-IVLVKOO6.js.map → singleCellPlot-3YFUYA2Y.js.map} +0 -0
  806. /package/dist/{singlecell-VJJZJZF7.js.map → singlecell-FK5JETW5.js.map} +0 -0
  807. /package/dist/{singlecell-VQJ2252L.js.map → singlecell-RL7V7DIC.js.map} +0 -0
  808. /package/dist/{snp-ALMKZKL2.js.map → snp-FT7HB3XN.js.map} +0 -0
  809. /package/dist/{snp.unit.spec-GJQBAHGQ.js.map → snp.unit.spec-CLYVYPPG.js.map} +0 -0
  810. /package/dist/{snplocus-WCNCMFWZ.js.map → snplocus-M5SEQGAC.js.map} +0 -0
  811. /package/dist/{spliceevent.a53ss.diagram-4Q4JF4RX.js.map → spliceevent.a53ss.diagram-EJ5CTRCZ.js.map} +0 -0
  812. /package/dist/{spliceevent.exonskip.diagram-IOYOKELT.js.map → spliceevent.exonskip.diagram-ETXMOHZ3.js.map} +0 -0
  813. /package/dist/{spliceevent.noeventdiagram-77ZCOHSF.js.map → spliceevent.noeventdiagram-S2O4ZM2Z.js.map} +0 -0
  814. /package/dist/{ssGSEA-QTXXIN4K.js.map → ssGSEA-6PMDQDTJ.js.map} +0 -0
  815. /package/dist/{ssGSEA.unit.spec-LQESATT3.js.map → ssGSEA.unit.spec-JD5T4R2N.js.map} +0 -0
  816. /package/dist/{summarizeCnvGeneexp-YKUQGDQF.js.map → summarizeCnvGeneexp-GCHNKTIU.js.map} +0 -0
  817. /package/dist/{summarizeGeneexpSurvival-ARGG5VDC.js.map → summarizeGeneexpSurvival-R2RYQZ3M.js.map} +0 -0
  818. /package/dist/{summarizeMutationCnv-FMZYT3EC.js.map → summarizeMutationCnv-LB2BIYRL.js.map} +0 -0
  819. /package/dist/{summarizeMutationDiagnosis-ZX7I46SC.js.map → summarizeMutationDiagnosis-3JUY75LM.js.map} +0 -0
  820. /package/dist/{summarizeMutationSurvival-RCFMTT43.js.map → summarizeMutationSurvival-VYLRWTCF.js.map} +0 -0
  821. /package/dist/{summary-QLL5YVI2.js.map → summary-2QQ72IEQ.js.map} +0 -0
  822. /package/dist/{summary.integration.spec-DHY6XCEJ.js.map → summary.integration.spec-XXU362UQ.js.map} +0 -0
  823. /package/dist/{summaryInput-ANCUQGIB.js.map → summaryInput-OZHZG3PV.js.map} +0 -0
  824. /package/dist/{sunburst-RDNFBOCK.js.map → sunburst-CMCJCANX.js.map} +0 -0
  825. /package/dist/{survival-BG7QV52L.js.map → survival-EBD4DHO7.js.map} +0 -0
  826. /package/dist/{survival-WSN36OQE.js.map → survival-ISLRRPKU.js.map} +0 -0
  827. /package/dist/{survival.integration.spec-37KAJ5IK.js.map → survival.integration.spec-FS7V4OXK.js.map} +0 -0
  828. /package/dist/{svgraph-A5WGHW4S.js.map → svgraph-KGLNUM7W.js.map} +0 -0
  829. /package/dist/{svmr-CYRHHWZF.js.map → svmr-NXZ5VLKH.js.map} +0 -0
  830. /package/dist/{table-VHO7E5PI.js.map → table-ISOQOI6C.js.map} +0 -0
  831. /package/dist/{termCollection-HSVSH7TJ.js.map → termCollection-7ZSU3I45.js.map} +0 -0
  832. /package/dist/{termCollection-E4Q6GLXN.js.map → termCollection-V2A5BDQB.js.map} +0 -0
  833. /package/dist/{termCollection.unit.spec-ZCE3TUMS.js.map → termCollection.unit.spec-6VLCJGOU.js.map} +0 -0
  834. /package/dist/{tk-GPRHDN4K.js.map → tk-6AB6XYIE.js.map} +0 -0
  835. /package/dist/{tp.ui-LTUA3FSL.js.map → tp.ui-2O4UW5N7.js.map} +0 -0
  836. /package/dist/{tvs.dt-G43PAAKD.js.map → tvs.dt-CY6TOQVB.js.map} +0 -0
  837. /package/dist/{tvs.dtcnv.categorical-UHDS2TGZ.js.map → tvs.dtcnv.categorical-AYQ432TW.js.map} +0 -0
  838. /package/dist/{tvs.dtcnv.continuous-ZNGYQKTD.js.map → tvs.dtcnv.continuous-XVDL6SG3.js.map} +0 -0
  839. /package/dist/{tvs.dtfusion-JBEEUDUS.js.map → tvs.dtfusion-V3AV7A6Q.js.map} +0 -0
  840. /package/dist/{tvs.dtsnvindel-XXN5Q7RN.js.map → tvs.dtsnvindel-XM3NXIT7.js.map} +0 -0
  841. /package/dist/{tvs.dtsv-MO6L7HHV.js.map → tvs.dtsv-Z2GYRINW.js.map} +0 -0
  842. /package/dist/{tvs.samplelst-HKY6UUJM.js.map → tvs.samplelst-C4FB63G7.js.map} +0 -0
  843. /package/dist/{tvs.termCollection-TY6FPL25.js.map → tvs.termCollection-VHTSC2ST.js.map} +0 -0
  844. /package/dist/{violin-YHE3WSGR.js.map → violin-KGGTUQFF.js.map} +0 -0
  845. /package/dist/{violin.integration.spec-F2UD7BHC.js.map → violin.integration.spec-5EW6PLJX.js.map} +0 -0
  846. /package/dist/{violin.interactivity-LVDTDEPQ.js.map → violin.interactivity-RI4RURGO.js.map} +0 -0
  847. /package/dist/{violin.renderer-IIEIUGRI.js.map → violin.renderer-EWU2IFZE.js.map} +0 -0
  848. /package/dist/{vocabulary-WQRYXBRO.js.map → vocabulary-VLIGC7OP.js.map} +0 -0
@@ -0,0 +1,2370 @@
1
+ import {
2
+ vcf2dstk
3
+ } from "./chunk-ZGOOZK3I.js";
4
+ import {
5
+ getsjcharts
6
+ } from "./chunk-MKAF2BHB.js";
7
+ import {
8
+ parseheader,
9
+ parseline
10
+ } from "./chunk-DGUTCYH2.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-2YC6ZVE4.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-I55NLUCQ.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-AMYSEKPF.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/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(
73
+ "annovar_gene",
74
+ "annovar_sj_gene",
75
+ "gene",
76
+ "genename",
77
+ "gene_symbol",
78
+ "hugo_symbol"
79
+ );
80
+ if (i == -1) return "gene missing from header";
81
+ header[i] = "gene";
82
+ i = htry(
83
+ "annovar_aachange",
84
+ "amino_acid_change",
85
+ "annovar_sj_aachange",
86
+ "aachange",
87
+ "protein_change",
88
+ "variant"
89
+ );
90
+ if (i == -1) return "amino_acid_change missing from header";
91
+ header[i] = "mname";
92
+ i = htry(
93
+ "annovar_class",
94
+ "class",
95
+ "mclass",
96
+ "variant_class",
97
+ "variant_classification",
98
+ "annovar_sj_class"
99
+ );
100
+ if (i == -1) return "variant_class missing from header";
101
+ header[i] = "class";
102
+ i = htry("chromosome", "chr");
103
+ if (i == -1) return "chromosome missing from header";
104
+ header[i] = "chr";
105
+ i = htry("wu_hg19_pos", "start", "start_position", "chr_position", "position");
106
+ if (i == -1) return "start missing from header";
107
+ header[i] = "pos";
108
+ i = htry(
109
+ "annovar_isoform",
110
+ "mrna_accession",
111
+ "mrna accession",
112
+ "refseq_mrna_id",
113
+ "annovar_sj_filter_isoform",
114
+ "refseq",
115
+ "isoform"
116
+ );
117
+ if (i == -1) return "isoform missing from header";
118
+ header[i] = "isoform";
119
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
120
+ if (i != -1) header[i] = "sample";
121
+ i = htry("patient", "donor", "target_case_id");
122
+ if (i != -1) header[i] = "patient";
123
+ i = htry("quantitative_measurements");
124
+ if (i != -1) header[i] = "qmset";
125
+ i = htry("mutant_reads_in_case", "mutant_in_tumor", "tumor_readcount_alt");
126
+ if (i != -1) header[i] = "maf_tumor_v1";
127
+ i = htry("total_reads_in_case", "total_in_tumor", "tumor_readcount_total");
128
+ if (i != -1) header[i] = "maf_tumor_v2";
129
+ i = htry(
130
+ "mutant_reads_in_control",
131
+ "mutant_in_normal",
132
+ "normal_readcount_alt"
133
+ );
134
+ if (i != -1) header[i] = "maf_normal_v1";
135
+ i = htry(
136
+ "total_reads_in_control",
137
+ "total_in_normal",
138
+ "normal_readcount_total"
139
+ );
140
+ if (i != -1) header[i] = "maf_normal_v2";
141
+ i = htry("cdna_change");
142
+ if (i != -1) header[i] = "cdna_change";
143
+ i = htry("sampletype", "sample type", "sample_type");
144
+ if (i != -1) header[i] = "sampletype";
145
+ i = htry("origin");
146
+ if (i != -1) header[i] = "origin";
147
+ i = htry("cancer", "disease", "diagnosis");
148
+ if (i != -1) header[i] = "disease";
149
+ flag2.snv.header = header;
150
+ flag2.snv.loaded = true;
151
+ return false;
152
+ }
153
+ function parseline2(linei, line, flag2) {
154
+ if (line == "" || line[0] == "#") return;
155
+ const lst = line.split(" ");
156
+ const m = {};
157
+ for (let j = 0; j < flag2.snv.header.length; j++) {
158
+ if (lst[j] == void 0) break;
159
+ m[flag2.snv.header[j]] = lst[j];
160
+ }
161
+ if (!m.gene) {
162
+ flag2.snv.badlines.push([linei, "missing gene", lst]);
163
+ return;
164
+ }
165
+ if (m.gene.toUpperCase() == "UNKNOWN") {
166
+ flag2.snv.badlines.push([linei, "gene name is UNKNOWN", lst]);
167
+ return;
168
+ }
169
+ if (!m.isoform) {
170
+ flag2.snv.badlines.push([linei, "missing isoform", lst]);
171
+ return;
172
+ }
173
+ if (!m.mname) {
174
+ m.mname = m.cdna_change;
175
+ if (!m.mname) {
176
+ flag2.snv.badlines.push([linei, "missing amino acid change", lst]);
177
+ return;
178
+ }
179
+ } else {
180
+ if (m.mname.indexOf("p.") == 0) {
181
+ m.mname = m.mname.replace(/^p\./, "");
182
+ }
183
+ }
184
+ if (!m.class) {
185
+ flag2.snv.badlines.push([linei, "missing mutation class", lst]);
186
+ return;
187
+ }
188
+ let _c = flag2.mclasslabel2key[m.class.toUpperCase()];
189
+ if (_c) {
190
+ m.class = _c;
191
+ } else {
192
+ _c = mclasstester(m.class);
193
+ if (_c) {
194
+ m.class = _c;
195
+ } else {
196
+ flag2.snv.badlines.push([linei, "wrong mutation class: " + m.class, lst]);
197
+ return;
198
+ }
199
+ }
200
+ if (parsesample(m, flag2, linei, lst, flag2.snv.badlines)) {
201
+ return;
202
+ }
203
+ if (!m.chr) {
204
+ flag2.snv.badlines.push([linei, "missing chromosome", lst]);
205
+ return;
206
+ }
207
+ if (m.chr.toLowerCase().indexOf("chr") != 0) {
208
+ m.chr = "chr" + m.chr;
209
+ }
210
+ if (!m.pos) {
211
+ flag2.snv.badlines.push([linei, "missing chromosome position", lst]);
212
+ return;
213
+ }
214
+ const v = Number.parseInt(m.pos);
215
+ if (Number.isNaN(v)) {
216
+ flag2.snv.badlines.push([linei, "invalid chromosome position", lst]);
217
+ return;
218
+ }
219
+ m.pos = v - 1;
220
+ if (m.maf_tumor_v2 != void 0 && m.maf_tumor_v1 != void 0) {
221
+ if (m.maf_tumor_v2 == "") {
222
+ } else {
223
+ let v1 = Number.parseInt(m.maf_tumor_v1), v2 = Number.parseInt(m.maf_tumor_v2);
224
+ if (Number.isNaN(v1) || Number.isNaN(v2)) {
225
+ flag2.snv.badlines.push([
226
+ linei,
227
+ "invalid maf_tumor mutant and/or total read count",
228
+ lst
229
+ ]);
230
+ return;
231
+ }
232
+ m.maf_tumor = { f: v1 / v2, v1, v2 };
233
+ }
234
+ delete m.maf_tumor_v1;
235
+ delete m.maf_tumor_v2;
236
+ }
237
+ if (m.maf_normal_v1 != void 0 && m.maf_normal_v2 != void 0) {
238
+ if (m.maf_normal_v2 == "") {
239
+ } else {
240
+ let v1 = Number.parseInt(m.maf_normal_v1), v2 = Number.parseInt(m.maf_normal_v2);
241
+ if (Number.isNaN(v1) || Number.isNaN(v2)) {
242
+ flag2.snv.badlines.push([
243
+ linei,
244
+ "invalid maf_normal mutant and/or total read count",
245
+ lst
246
+ ]);
247
+ return;
248
+ }
249
+ m.maf_normal = { f: v1 / v2, v1, v2 };
250
+ }
251
+ delete m.maf_normal_v1;
252
+ delete m.maf_normal_v2;
253
+ }
254
+ flag2.good++;
255
+ if (m.class == "M") {
256
+ flag2.snv.missense++;
257
+ } else if (m.class == "S") {
258
+ flag2.snv.silent++;
259
+ }
260
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
261
+ if (!flag2.data[n]) {
262
+ flag2.data[n] = [];
263
+ }
264
+ m.dt = dtsnvindel;
265
+ flag2.data[n].push(m);
266
+ }
267
+
268
+ // ../shared/utils/src/bulk.svjson.js
269
+ function parseheader3(line, flag2) {
270
+ const header = line.toLowerCase().split(" ");
271
+ if (header.length <= 1) return "invalid file header for svjson";
272
+ const htry = (...lst) => {
273
+ for (const a of lst) {
274
+ const j = header.indexOf(a);
275
+ if (j != -1) return j;
276
+ }
277
+ return -1;
278
+ };
279
+ let i = htry("sample");
280
+ if (i != -1) header[i] = "sample";
281
+ i = htry("sampletype");
282
+ if (i != -1) header[i] = "sampletype";
283
+ i = htry("patient");
284
+ if (i != -1) header[i] = "patient";
285
+ i = htry("json", "jsontext");
286
+ if (i == -1) return ["json missing from header"];
287
+ header[i] = "jsontext";
288
+ return [null, header];
289
+ }
290
+ function parseline3(i, line, flag2, header) {
291
+ if (line == "" || line[0] == "#") return;
292
+ const lst = line.split(" ");
293
+ const m = {};
294
+ const badlines = flag2.svjson.badlines;
295
+ for (let j = 0; j < header.length; j++) {
296
+ m[header[j]] = lst[j];
297
+ }
298
+ if (!m.jsontext) {
299
+ badlines.push([i, "missing jsontext", lst]);
300
+ return;
301
+ }
302
+ if (parsesample(m, flag2, i, lst, badlines)) {
303
+ return;
304
+ }
305
+ let json;
306
+ try {
307
+ json = JSON.parse(m.jsontext);
308
+ } catch (e) {
309
+ badlines.push([i, "invalid JSON text", lst]);
310
+ return;
311
+ }
312
+ if (Array.isArray(json)) {
313
+ for (const pair of json) {
314
+ if (pair.a && pair.a.name && pair.a.isoform) {
315
+ flag2.good++;
316
+ const m2 = {
317
+ dt: dtfusionrna,
318
+ class: mclassfusionrna,
319
+ isoform: pair.a.isoform,
320
+ mname: pair.b.name
321
+ };
322
+ for (const k in m) {
323
+ if (k != "jsontext") m2[k] = m[k];
324
+ }
325
+ m2.pairlst = duplicate(json);
326
+ const n = pair.a.name.toUpperCase();
327
+ if (!flag2.data[n]) {
328
+ flag2.data[n] = [];
329
+ }
330
+ flag2.data[n].push(m2);
331
+ }
332
+ if (pair.b && pair.b.name && pair.b.isoform) {
333
+ flag2.good++;
334
+ const m2 = {
335
+ dt: dtfusionrna,
336
+ class: mclassfusionrna,
337
+ isoform: pair.b.isoform,
338
+ mname: pair.a.name
339
+ };
340
+ for (const k in m) {
341
+ if (k != "jsontext") m2[k] = m[k];
342
+ }
343
+ m2.pairlst = duplicate(json);
344
+ const n = pair.b.name.toUpperCase();
345
+ if (!flag2.data[n]) {
346
+ flag2.data[n] = [];
347
+ }
348
+ flag2.data[n].push(m2);
349
+ }
350
+ }
351
+ } else {
352
+ json.dt = json.typecode;
353
+ delete json.typecode;
354
+ switch (json.dt) {
355
+ case dtitd:
356
+ json.class = mclassitd;
357
+ json.mname = "ITD";
358
+ break;
359
+ case dtnloss:
360
+ json.class = mclassnloss;
361
+ json.mname = "N-loss";
362
+ break;
363
+ case dtcloss:
364
+ json.class = mclasscloss;
365
+ json.mname = "C-loss";
366
+ break;
367
+ case dtdel:
368
+ json.class = mclassdel;
369
+ json.mname = "Del";
370
+ break;
371
+ case dtsv:
372
+ json.class = mclasssv;
373
+ json.mname = "SV";
374
+ break;
375
+ default:
376
+ badlines.push([i, "unknown datatype", lst]);
377
+ return;
378
+ }
379
+ if (!json.gene) {
380
+ badlines.push([i, "json.gene missing", lst]);
381
+ return;
382
+ }
383
+ flag2.good++;
384
+ for (const k in m) {
385
+ if (k != "jsontext") {
386
+ json[k] = m[k];
387
+ }
388
+ }
389
+ const n = flag2.geneToUpper ? json.gene.toUpperCase() : json.gene.toUpperCase();
390
+ if (!flag2.data[n]) {
391
+ flag2.data[n] = [];
392
+ }
393
+ flag2.data[n].push(json);
394
+ }
395
+ }
396
+ function duplicate(lst) {
397
+ const d = [];
398
+ for (const pair of lst) {
399
+ const p = { a: {}, b: {} };
400
+ for (const k in pair) {
401
+ if (k != "a" && k != "b") p[k] = pair[k];
402
+ }
403
+ for (const k in pair.a) {
404
+ p.a[k] = pair.a[k];
405
+ }
406
+ for (const k in pair.b) {
407
+ p.b[k] = pair.b[k];
408
+ }
409
+ d.push(p);
410
+ }
411
+ return d;
412
+ }
413
+
414
+ // ../shared/utils/src/bulk.cnv.js
415
+ function parseheader4(line, flag2) {
416
+ const header = line.toLowerCase().split(" ");
417
+ if (header.length <= 1) return "invalid file header for CNV";
418
+ const htry = (...lst) => {
419
+ for (const i2 of lst) {
420
+ const j = header.indexOf(i2);
421
+ if (j != -1) return j;
422
+ }
423
+ return -1;
424
+ };
425
+ let i = htry("gene");
426
+ if (i == -1) return "gene missing from header";
427
+ header[i] = "gene";
428
+ i = htry("cnv");
429
+ if (i == -1) return "CNV missing from header";
430
+ header[i] = "cnv";
431
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
432
+ if (i != -1) header[i] = "sample";
433
+ i = htry("patient", "donor", "target_case_id");
434
+ if (i != -1) header[i] = "patient";
435
+ i = htry("disease");
436
+ if (i != -1) header[i] = "disease";
437
+ i = htry("origin");
438
+ if (i != -1) header[i] = "origin";
439
+ i = htry("sampletype", "sample type", "sample_type");
440
+ if (i != -1) header[i] = "sampletype";
441
+ flag2.cnv.header = header;
442
+ flag2.cnv.loaded = true;
443
+ return false;
444
+ }
445
+ function parseline4(i, line, flag2) {
446
+ if (line == "" || line[0] == "#") return;
447
+ const lst = line.split(" ");
448
+ const m = {};
449
+ for (let j = 0; j < flag2.cnv.header.length; j++) {
450
+ m[flag2.cnv.header[j]] = lst[j];
451
+ }
452
+ if (!m.gene) {
453
+ flag2.cnv.badlines.push([i, "missing gene", lst]);
454
+ return;
455
+ }
456
+ if (!m.cnv) {
457
+ flag2.cnv.badlines.push([i, "missing cnv value", lst]);
458
+ return;
459
+ }
460
+ const value = m.cnv.toLowerCase();
461
+ switch (value) {
462
+ case "amplification":
463
+ case "gain":
464
+ m.class = mclasscnvgain;
465
+ break;
466
+ case "deletion":
467
+ case "loss":
468
+ m.class = mclasscnvloss;
469
+ break;
470
+ case "loh":
471
+ m.class = mclasscnvloh;
472
+ break;
473
+ default:
474
+ flag2.cnv.badlines.push([i, "invalid cnv value: " + m.cnv, lst]);
475
+ m.class = null;
476
+ }
477
+ if (!m.class) {
478
+ return;
479
+ }
480
+ if (parsesample(m, flag2, i, lst, flag2.cnv.badlines)) {
481
+ return;
482
+ }
483
+ m.dt = dtcnv;
484
+ flag2.good++;
485
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
486
+ if (!(n in flag2.data)) {
487
+ flag2.data[n] = [];
488
+ }
489
+ flag2.data[n].push(m);
490
+ }
491
+
492
+ // ../shared/utils/src/bulk.itd.js
493
+ function parseheader5(line, flag2) {
494
+ const header = line.toLowerCase().split(" ");
495
+ if (header.length <= 1) return "invalid header line for ITD";
496
+ const htry = (...lst) => {
497
+ for (const i2 of lst) {
498
+ const j = header.indexOf(i2);
499
+ if (j != -1) return j;
500
+ }
501
+ return -1;
502
+ };
503
+ let i = htry("gene");
504
+ if (i == -1) return "gene missing from header";
505
+ header[i] = "gene";
506
+ i = htry(
507
+ "annovar_isoform",
508
+ "mrna_accession",
509
+ "mrna accession",
510
+ "refseq_mrna_id",
511
+ "annovar_sj_filter_isoform",
512
+ "refseq",
513
+ "isoform"
514
+ );
515
+ if (i == -1) return "isoform missing from header";
516
+ header[i] = "isoform";
517
+ i = htry("rnaposition");
518
+ if (i != -1) {
519
+ header[i] = "rnaposition";
520
+ i = htry("rnaduplength");
521
+ if (i == -1) return "rnaduplength is required when rnaposition is present";
522
+ header[i] = "rnaduplength";
523
+ }
524
+ i = htry("chromosome", "chr");
525
+ if (i != -1) {
526
+ header[i] = "chr";
527
+ i = htry("chr_start");
528
+ if (i == -1) return "chr_start is required when chr is present";
529
+ header[i] = "chrpos1";
530
+ i = htry("chr_stop");
531
+ if (i == -1) return "chr_stop is required when chr is present";
532
+ header[i] = "chrpos2";
533
+ }
534
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
535
+ if (i != -1) header[i] = "sample";
536
+ i = htry("patient", "donor", "target_case_id");
537
+ if (i != -1) header[i] = "patient";
538
+ i = htry("disease");
539
+ if (i != -1) header[i] = "disease";
540
+ i = htry("origin");
541
+ if (i != -1) header[i] = "origin";
542
+ i = htry("sampletype", "sample type", "sample_type");
543
+ if (i != -1) header[i] = "sampletype";
544
+ flag2.itd.header = header;
545
+ flag2.itd.loaded = true;
546
+ return false;
547
+ }
548
+ function parseline5(i, line, flag2) {
549
+ if (line == "" || line[0] == "#") return;
550
+ const lst = line.split(" ");
551
+ const m = {};
552
+ for (let j = 0; j < flag2.itd.header.length; j++) {
553
+ if (lst[j] == void 0) break;
554
+ m[flag2.itd.header[j]] = lst[j];
555
+ }
556
+ if (!m.gene) {
557
+ flag2.itd.badlines.push([i, "missing gene", lst]);
558
+ return;
559
+ }
560
+ if (m.rnaposition) {
561
+ let v = Number.parseInt(m.rnaposition);
562
+ if (Number.isNaN(v) || v < 0) {
563
+ flag2.itd.badlines.push([i, "invalid rnaPosition value", lst]);
564
+ return;
565
+ }
566
+ m.rnaposition = v;
567
+ if (!m.rnaduplength) {
568
+ flag2.itd.badlines.push([i, "missing rnaDuplength value", lst]);
569
+ return;
570
+ }
571
+ v = Number.parseInt(m.rnaduplength);
572
+ if (Number.isNaN(v) || v < 0) {
573
+ flag2.itd.badlines.push([i, "invalid rnaDuplength value", lst]);
574
+ return;
575
+ }
576
+ m.rnaduplength = v;
577
+ }
578
+ if (m.chr) {
579
+ let v = Number.parseInt(m.chrpos1);
580
+ if (Number.isNaN(v) || v < 0) {
581
+ flag2.itd.badlines.push([i, "invalid chr_start value", lst]);
582
+ return;
583
+ }
584
+ m.chrpos1 = v;
585
+ v = Number.parseInt(m.chrpos2);
586
+ if (Number.isNaN(v) || v < 0) {
587
+ flag2.itd.badlines.push([i, "invalid chr_stop value", lst]);
588
+ return;
589
+ }
590
+ m.chrpos2 = v;
591
+ }
592
+ if (parsesample(m, flag2, i, lst, flag2.itd.badlines)) {
593
+ return;
594
+ }
595
+ m.dt = dtitd;
596
+ m.class = mclassitd;
597
+ m.mname = "ITD";
598
+ flag2.good++;
599
+ var n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
600
+ if (!(n in flag2.data)) {
601
+ flag2.data[n] = [];
602
+ }
603
+ flag2.data[n].push(m);
604
+ }
605
+
606
+ // ../shared/utils/src/bulk.del.js
607
+ function parseheader6(line, flag2) {
608
+ const header = line.toLowerCase().split(" ");
609
+ if (header.length <= 1) return "invalid header line for intragenic deletion";
610
+ const htry = (...lst) => {
611
+ for (const i2 of lst) {
612
+ const j = header.indexOf(i2);
613
+ if (j != -1) return j;
614
+ }
615
+ return -1;
616
+ };
617
+ let i = htry("gene");
618
+ if (i == -1) return "gene missing from header";
619
+ header[i] = "gene";
620
+ i = htry(
621
+ "annovar_isoform",
622
+ "mrna_accession",
623
+ "mrna accession",
624
+ "refseq_mrna_id",
625
+ "annovar_sj_filter_isoform",
626
+ "refseq",
627
+ "isoform"
628
+ );
629
+ if (i == -1) return "isoform missing from header";
630
+ header[i] = "isoform";
631
+ i = htry("rnaposition");
632
+ if (i != -1) {
633
+ header[i] = "rnaposition";
634
+ i = htry("rnadellength");
635
+ if (i == -1) return "rnadellength is required when rnaPosition is used";
636
+ header[i] = "rnadellength";
637
+ }
638
+ i = htry("chromosome", "chr");
639
+ if (i != -1) {
640
+ header[i] = "chr";
641
+ i = htry("chr_start");
642
+ if (i == -1) return "chr_start is required when chr is used";
643
+ header[i] = "chrpos1";
644
+ i = htry("chr_stop");
645
+ if (i == -1) return "chr_stop is required when chr is used";
646
+ header[i] = "chrpos2";
647
+ }
648
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
649
+ if (i != -1) header[i] = "sample";
650
+ i = htry("patient", "donor", "target_case_id");
651
+ if (i != -1) header[i] = "patient";
652
+ i = htry("disease");
653
+ if (i != -1) header[i] = "disease";
654
+ i = htry("origin");
655
+ if (i != -1) header[i] = "origin";
656
+ i = htry("sampletype", "sample type", "sample_type");
657
+ if (i != -1) header[i] = "sampletype";
658
+ flag2.del.header = header;
659
+ flag2.del.loaded = true;
660
+ return false;
661
+ }
662
+ function parseline6(i, line, flag2) {
663
+ if (line == "" || line[0] == "#") return;
664
+ const lst = line.split(" ");
665
+ const m = {};
666
+ for (let j = 0; j < flag2.del.header.length; j++) {
667
+ if (lst[j] == void 0) break;
668
+ m[flag2.del.header[j]] = lst[j];
669
+ }
670
+ if (!m.gene) {
671
+ flag2.del.badlines.push([i, "missing gene", lst]);
672
+ return;
673
+ }
674
+ if (m.rnaposition) {
675
+ let v = Number.parseInt(m.rnaposition);
676
+ if (Number.isNaN(v) || v < 0) {
677
+ flag2.del.badlines.push([i, "invalid rnaPosition value", lst]);
678
+ return;
679
+ }
680
+ m.rnaposition = v;
681
+ if (!m.rnadellength) {
682
+ flag2.del.badlines.push([i, "missing rnaDellength value", lst]);
683
+ return;
684
+ }
685
+ v = Number.parseInt(m.rnadellength);
686
+ if (Number.isNaN(v) || v < 0) {
687
+ flag2.del.badlines.push([i, "invalid rnaDellength value", lst]);
688
+ return;
689
+ }
690
+ m.rnadellength = v;
691
+ }
692
+ if (m.chr) {
693
+ let v = Number.parseInt(m.chrpos1);
694
+ if (Number.isNaN(v) || v < 0) {
695
+ flag2.del.badlines.push([i, "invalid chr_start value", lst]);
696
+ return;
697
+ }
698
+ m.chrpos1 = v;
699
+ v = Number.parseInt(m.chrpos2);
700
+ if (Number.isNaN(v) || v < 0) {
701
+ flag2.del.badlines.push([i, "invalid chr_stop value", lst]);
702
+ return;
703
+ }
704
+ m.chrpos2 = v;
705
+ }
706
+ if (parsesample(m, flag2, i, lst, flag2.del.badlines)) {
707
+ return;
708
+ }
709
+ m.dt = dtdel;
710
+ m.class = mclassdel;
711
+ m.mname = "DEL";
712
+ flag2.good++;
713
+ var n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
714
+ if (!(n in flag2.data)) {
715
+ flag2.data[n] = [];
716
+ }
717
+ flag2.data[n].push(m);
718
+ }
719
+
720
+ // ../shared/utils/src/bulk.trunc.js
721
+ function parseheader7(line, flag2) {
722
+ const header = line.toLowerCase().split(" ");
723
+ if (header.length <= 1) return "invalid header line for truncation";
724
+ const htry = (...lst) => {
725
+ for (const e of lst) {
726
+ const j = header.indexOf(e);
727
+ if (j != -1) return j;
728
+ }
729
+ return -1;
730
+ };
731
+ let i = htry("gene");
732
+ if (i == -1) return "gene missing from header";
733
+ header[i] = "gene";
734
+ i = htry(
735
+ "annovar_isoform",
736
+ "mrna_accession",
737
+ "mrna accession",
738
+ "refseq_mrna_id",
739
+ "annovar_sj_filter_isoform",
740
+ "refseq",
741
+ "isoform"
742
+ );
743
+ if (i == -1) return "isoform missing from header";
744
+ header[i] = "isoform";
745
+ let hasrnapos = false;
746
+ i = htry("rnaposition");
747
+ if (i != -1) {
748
+ header[i] = "rnaposition";
749
+ hasrnapos = true;
750
+ }
751
+ i = htry("losstype");
752
+ if (i == -1) return "lossType missing from header";
753
+ header[i] = "losstype";
754
+ let hasgenomic = false;
755
+ i = htry("chromosome", "chr");
756
+ if (i != -1) {
757
+ header[i] = "chr";
758
+ i = htry(
759
+ "start",
760
+ "start_position",
761
+ "wu_hg19_pos",
762
+ "chr_position",
763
+ "position"
764
+ );
765
+ if (i == -1) {
766
+ return "genomic position missing from header";
767
+ }
768
+ header[i] = "pos";
769
+ hasgenomic = true;
770
+ }
771
+ if (!hasrnapos && !hasgenomic) {
772
+ return "neither rnaposition nor genomic position is given";
773
+ }
774
+ i = htry("sample", "sample_name", "tumor_sample_barcode");
775
+ if (i != -1) header[i] = "sample";
776
+ i = htry("patient", "donor", "target_case_id");
777
+ if (i != -1) header[i] = "patient";
778
+ i = htry("disease");
779
+ if (i != -1) header[i] = "disease";
780
+ i = htry("origin");
781
+ if (i != -1) header[i] = "origin";
782
+ i = htry("sampletype", "sample type", "sample_type");
783
+ if (i != -1) header[i] = "sampletype";
784
+ flag2.truncation.header = header;
785
+ flag2.truncation.loaded = true;
786
+ return false;
787
+ }
788
+ function parseline7(i, line, flag2) {
789
+ if (line == "" || line[0] == "#") return;
790
+ const lst = line.split(" ");
791
+ const m = {};
792
+ for (let j = 0; j < flag2.truncation.header.length; j++) {
793
+ m[flag2.truncation.header[j]] = lst[j];
794
+ }
795
+ if (!m.gene) {
796
+ flag2.truncation.badlines.push([i, "missing gene", lst]);
797
+ return;
798
+ }
799
+ if (m.rnaposition) {
800
+ const v = Number.parseInt(m.rnaposition);
801
+ if (Number.isNaN(v) || v < 0) {
802
+ flag2.truncation.badlines.push([i, "invalid rnaPosition value", lst]);
803
+ return;
804
+ }
805
+ m.rnaposition = v;
806
+ }
807
+ if (m.pos) {
808
+ const v = Number.parseInt(m.pos);
809
+ if (Number.isNaN(v) || v < 0) {
810
+ flag2.truncation.badlines.push([i, "invalid genomic position", lst]);
811
+ return;
812
+ }
813
+ m.pos = v;
814
+ }
815
+ if (!m.losstype) {
816
+ flag2.truncation.badlines.push([i, "missing lossType value", lst]);
817
+ return;
818
+ }
819
+ if (m.losstype != "n" && m.losstype != "c") {
820
+ flag2.truncation.badlines.push([i, 'lossType value not "n" or "c"', lst]);
821
+ return;
822
+ }
823
+ if (parsesample(m, flag2, i, lst, flag2.truncation.badlines)) {
824
+ return;
825
+ }
826
+ if (m.losstype == "n") {
827
+ m.dt = dtnloss;
828
+ m.class = mclassnloss;
829
+ m.mname = "N-loss";
830
+ } else {
831
+ m.dt = dtcloss;
832
+ m.class = mclasscloss;
833
+ m.mname = "C-loss";
834
+ }
835
+ flag2.good++;
836
+ const n = flag2.geneToUpper ? m.gene.toUpperCase() : m.gene;
837
+ if (!(n in flag2.data)) {
838
+ flag2.data[n] = [];
839
+ }
840
+ flag2.data[n].push(m);
841
+ }
842
+
843
+ // src/bulk.project.js
844
+ var schemaNames = ["heatmapJSON", "piebarJSON", "survivalJSON", "discoJSON", "riverJSON"];
845
+ var typeIndex = {
846
+ snvindel: 0,
847
+ si: 0,
848
+ sv: 1,
849
+ fusion: 2,
850
+ itd: 3,
851
+ deletion: 4,
852
+ truncation: 5,
853
+ cnv: 6
854
+ };
855
+ var urlProjectLoaded = false;
856
+ var ProjectHandler = class {
857
+ /*
858
+ Create a handler for multiple uploaded or fetched
859
+ files in a project
860
+
861
+ bt = {
862
+ flag: closured flag inside bulkui.bulkui,
863
+ bulkin: bulkui.bulkin,
864
+ content2flag: bulkui.content2flag,
865
+ flag2tp: closured flat2tp,
866
+ filediv: (optional) d3-wrapped container for file-input
867
+ }
868
+ */
869
+ constructor(bt) {
870
+ this.bt = bt;
871
+ this.err = this.errHandler();
872
+ if (!urlProjectLoaded) {
873
+ const params = getParams();
874
+ if (params.project) {
875
+ this.getData(params.project);
876
+ urlProjectLoaded = true;
877
+ }
878
+ }
879
+ if (bt.filediv) {
880
+ this.projectByInput(bt.filediv);
881
+ }
882
+ }
883
+ /*
884
+ Process data files sequentially for rendering
885
+ into a TP div
886
+
887
+ data = {
888
+ schemas: object {
889
+ heatmapJSON (optional),
890
+ piebarJSON (optional),
891
+ survivalJSON (optional)
892
+ },
893
+ files: [] array of {
894
+ name: string
895
+ typeL one of the typeIndex values
896
+ content: string
897
+ }
898
+ }
899
+ */
900
+ processData(data) {
901
+ const file = data.files.pop();
902
+ const i = data.expectedFileNames.indexOf(file.name);
903
+ if (i == -1) {
904
+ if (data.files.length)
905
+ setTimeout(() => {
906
+ this.processData(data);
907
+ }, 1);
908
+ return;
909
+ }
910
+ data.expectedFileNames.splice(i, 1);
911
+ this.cohort = {
912
+ name: "project",
913
+ genome: this.bt.genomes[this.bt.gselect.options[this.bt.gselect.selectedIndex].innerHTML]
914
+ };
915
+ if (!this.flag) {
916
+ this.flag = this.bt.init_bulk_flag(this.cohort.genome);
917
+ }
918
+ const error = this.bt.content2flag(file.content, file.type, this.flag);
919
+ if (error) {
920
+ this.err(error);
921
+ this.processData(data);
922
+ } else if (!data.files.length) {
923
+ if (data.expectedFileNames.length) {
924
+ this.err('These referenced files were not found: "' + data.expectedFileNames.join('", "') + '".');
925
+ }
926
+ this.bt.flag2tp(this.flag, { name: "project" }, Object.assign(this.cohort, data.schema), this.ds);
927
+ return;
928
+ } else {
929
+ if (!this.ds) {
930
+ for (const k in this.cohort.dsset) {
931
+ this.ds = this.cohort.dsset[k];
932
+ break;
933
+ }
934
+ }
935
+ const error1 = this.bt.bulkin(
936
+ {
937
+ flag: this.flag,
938
+ cohort: this.cohort,
939
+ flag2thisds: this.ds,
940
+ filename: "project"
941
+ },
942
+ () => {
943
+ this.processData(data);
944
+ }
945
+ );
946
+ if (error1) {
947
+ this.err("Error with " + file.name + ": " + error1);
948
+ return;
949
+ }
950
+ if (this.flag.good === 0) {
951
+ this.err(file.name + ": no data loaded");
952
+ return;
953
+ }
954
+ }
955
+ }
956
+ getData(project) {
957
+ const [projectname, _refname] = project.split("/");
958
+ const refname = _refname && _refname.trim() ? _refname.trim() : "ref.txt";
959
+ this.gettext("/data/projects/" + projectname + "/" + refname, (text) => {
960
+ const fileNameToType = {};
961
+ const nameToSchemaType = {};
962
+ const data = { schema: {}, files: [], expectedFileNames: [] };
963
+ let schemaFileName = "";
964
+ let numProcessedFiles = 0;
965
+ let numFiles = 0;
966
+ text.trim().split("\n").forEach((line) => {
967
+ const [type, filename] = line.trim().split(" ");
968
+ if (schemaNames.includes(type)) {
969
+ nameToSchemaType[filename] = type;
970
+ numFiles += 1;
971
+ } else if (!typeIndex[type] && typeIndex[type] !== 0) {
972
+ this.err("Unrecognized type " + type + " for file " + filename + " in reference.txt.");
973
+ } else {
974
+ fileNameToType[filename] = typeIndex[type];
975
+ numFiles += 1;
976
+ }
977
+ });
978
+ data.expectedFileNames = Object.keys(fileNameToType);
979
+ const tracker = this.getTracker(numFiles, () => this.processData(data));
980
+ Object.keys(nameToSchemaType).forEach((filename) => {
981
+ this.getjson("/data/projects/" + projectname + "/" + filename, (json) => {
982
+ data.schema[nameToSchemaType[filename]] = json;
983
+ tracker();
984
+ });
985
+ });
986
+ Object.keys(fileNameToType).forEach((filename) => {
987
+ this.gettext("/data/projects/" + projectname + "/" + filename, (text2) => {
988
+ data.files.push({
989
+ name: filename,
990
+ type: fileNameToType[filename],
991
+ content: text2
992
+ });
993
+ tracker();
994
+ });
995
+ });
996
+ });
997
+ }
998
+ gettext(url, callback) {
999
+ fetch(url).then((response) => {
1000
+ if (response.ok) return response.text();
1001
+ else this.err("File request error: " + url);
1002
+ }).then(callback).catch((error) => this.err("File request error: " + url + " " + error));
1003
+ }
1004
+ getjson(url, callback) {
1005
+ fetch(url).then((response) => {
1006
+ if (response.ok) return response.json();
1007
+ else this.err("Network error for " + url);
1008
+ }).then(callback).catch((error) => this.err("file request error: " + url + " " + error));
1009
+ }
1010
+ getTracker(numFiles, callback) {
1011
+ let numProcessedFiles = 0;
1012
+ return function tracker() {
1013
+ numProcessedFiles += 1;
1014
+ if (numProcessedFiles == numFiles) {
1015
+ callback();
1016
+ }
1017
+ };
1018
+ }
1019
+ projectByInput(filediv) {
1020
+ this.tp = null;
1021
+ const advancedDiv = filediv.append("div");
1022
+ advancedDiv.append("span").html("Project: reference &nbsp;");
1023
+ this.refNameInput = advancedDiv.append("input").attr("type", "text").property("value", "ref.txt").style("margin-right", "20px").style("padding-left", "7px");
1024
+ const buttlabel = advancedDiv.append("label").attr("for", "sja-pp-bulk-ui-project-btn").attr("class", "sja_btn").style("padding", "3px 5px").html("Choose folder");
1025
+ 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));
1026
+ 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> |
1027
+ <a href='https://proteinpaint.stjude.org/ppdemo/projects/target-tall-project/ref.txt' target=_blank>Example project reference file</a>`);
1028
+ advancedDiv.append("div").style("margin", "20px").style("width", "100%").html("-- OR --");
1029
+ }
1030
+ /* to be used as a file input (FileList) handler */
1031
+ readFiles(event) {
1032
+ const self = this;
1033
+ const refFileName = self.refNameInput.property("value");
1034
+ const files = Array.from(event.target.files);
1035
+ const ref = files.filter((f) => f.name == refFileName)[0];
1036
+ if (!ref) {
1037
+ self.err("Missing reference file='" + refFileName + "'.");
1038
+ return;
1039
+ }
1040
+ const fileNameToType = {};
1041
+ const nameToSchemaType = {};
1042
+ const data = { schema: {}, files: [], expectedFileNames: [] };
1043
+ const reader = new FileReader();
1044
+ let schemaFileName = "";
1045
+ let numProcessedFiles = 0;
1046
+ reader.onload = (event2) => {
1047
+ event2.target.result.trim().split("\n").forEach((line) => {
1048
+ const [type, filename] = line.trim().split(" ");
1049
+ if (schemaNames.includes(type)) {
1050
+ nameToSchemaType[filename] = type;
1051
+ } else if (!typeIndex[type] && typeIndex[type] !== 0) {
1052
+ self.err("Unrecognized type " + type + " for file " + filename + " in reference.txt.");
1053
+ } else {
1054
+ fileNameToType[filename] = typeIndex[type];
1055
+ }
1056
+ });
1057
+ data.expectedFileNames = Object.keys(fileNameToType);
1058
+ const schemaFiles = files.filter((file) => file.name in nameToSchemaType);
1059
+ let numProcessedSchemas = 0;
1060
+ if (!schemaFiles.length) {
1061
+ files.forEach(processFile);
1062
+ } else {
1063
+ schemaFiles.forEach((file) => {
1064
+ const reader2 = new FileReader();
1065
+ reader2.onload = (event3) => {
1066
+ const schema = JSON.parse(event3.target.result);
1067
+ numProcessedSchemas += 1;
1068
+ if (!schema) {
1069
+ self.err('Unable to parse schema file="' + file.name + '".');
1070
+ } else {
1071
+ data.schema[nameToSchemaType[file.name]] = schema;
1072
+ }
1073
+ if (numProcessedSchemas == schemaFiles.length) {
1074
+ files.forEach(processFile);
1075
+ }
1076
+ };
1077
+ reader2.onerror = () => {
1078
+ self.err("Error reading schema.txt.");
1079
+ };
1080
+ reader2.readAsText(file, "utf8");
1081
+ });
1082
+ }
1083
+ function processFile(file) {
1084
+ if (!data.expectedFileNames.includes(file.name)) {
1085
+ numProcessedFiles += 1;
1086
+ return;
1087
+ }
1088
+ if (!file) {
1089
+ self.err("Error reading file.");
1090
+ numProcessedFiles += 1;
1091
+ return;
1092
+ }
1093
+ if (file.size == 0) {
1094
+ self.err("Wrong file: " + file.name);
1095
+ numProcessedFiles += 1;
1096
+ return;
1097
+ }
1098
+ if (!fileNameToType[file.name] && fileNameToType[file.name] !== 0 && file.name != schemaFileName) {
1099
+ self.err("Missing or invalid type assigned to file " + file.name + ".");
1100
+ numProcessedFiles += 1;
1101
+ return;
1102
+ }
1103
+ const reader2 = new FileReader();
1104
+ reader2.onload = (event3) => {
1105
+ numProcessedFiles += 1;
1106
+ data.files.push({
1107
+ name: file.name,
1108
+ type: fileNameToType[file.name],
1109
+ content: event3.target.result
1110
+ });
1111
+ if (numProcessedFiles == files.length) {
1112
+ self.processData(data);
1113
+ }
1114
+ };
1115
+ reader2.onerror = () => {
1116
+ numProcessedFiles += 1;
1117
+ self.err("Error reading file " + file.name);
1118
+ if (numProcessedFiles == files.length) {
1119
+ self.processData(data);
1120
+ }
1121
+ };
1122
+ reader2.readAsText(file, "utf8");
1123
+ }
1124
+ };
1125
+ reader.onerror = () => {
1126
+ self.err("Error reading reference.txt.");
1127
+ };
1128
+ reader.readAsText(ref, "utf8");
1129
+ }
1130
+ // function to track and display accumulated error messages
1131
+ errHandler() {
1132
+ const errdiv = select_default("body").append("div");
1133
+ let mssg = "";
1134
+ return function(m) {
1135
+ if (!m) return;
1136
+ sayerror(errdiv, m);
1137
+ };
1138
+ }
1139
+ };
1140
+ function getParams() {
1141
+ const params = {};
1142
+ window.location.search.substr(1).split("&").forEach((kv) => {
1143
+ const [key, value] = kv.split("=");
1144
+ params[key] = value;
1145
+ });
1146
+ return params;
1147
+ }
1148
+
1149
+ // src/bulk.ui.js
1150
+ function bulkui(x, y, genomes, hostURL, holder, header) {
1151
+ let pane, inputdiv, gselect, filediv, saydiv, visualdiv;
1152
+ if (holder !== void 0) [inputdiv, gselect, filediv, saydiv, visualdiv] = renderSandboxFormDiv(holder, genomes);
1153
+ else {
1154
+ ;
1155
+ [pane, inputdiv, gselect, filediv, saydiv, visualdiv] = newpane3(x, y, genomes);
1156
+ pane.header.text("Load mutation from text files");
1157
+ }
1158
+ inputdiv.append("div").style("margin", "20px 0px").style("color", "#858585").html(`
1159
+ <p>Choose one file and upload to initiate the display panel.<br>From there you can add additional files.</p>
1160
+ <div>Supported data types:</div>
1161
+ <ul>
1162
+ <li>SNV and indel</li>
1163
+ <ul>
1164
+ <li><a href=https://drive.google.com/open?id=1OJ9aXq2_-a3BfIQdKLYCYzrJRTpu4_9i3gephTY-Z38 target=_blank>Format</a>,
1165
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.snvindel.txt target=_blank>example file</a></li>
1166
+ </ul>
1167
+ <li>SV or fusion transcript</li>
1168
+ <ul>
1169
+ <li><a href=https://drive.google.com/open?id=1klDZ0MHVkQTW2-lCu_AvpRE4_FcbhdB-yI17wNdPaOM target=_blank>Tabular format</a>,
1170
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.svfusion.txt target=_blank>example file</a>
1171
+ </li>
1172
+ <li>JSON-format, to come</li>
1173
+ </ul>
1174
+ <li>CNV, gene-level</li>
1175
+ <ul>
1176
+ <li><a href=https://drive.google.com/open?id=1WHptqOWNf96V0bYEDpj-EsKZGYnbBNc9aQIrhzdEJaU target=_blank>Format</a>,
1177
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.cnv.txt target=_blank>example file</a>
1178
+ </li>
1179
+ </ul>
1180
+ <li>ITD</li>
1181
+ <ul>
1182
+ <li>Internal tandem duplication, in-frame</li>
1183
+ <li><a href=https://drive.google.com/open?id=1Bh9awBsraoHbV8iWXv_3oDeXMsjIAHaOKHr973IJyZc target=_blank>Format</a>,
1184
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.itd.txt target=_blank>example file</a>
1185
+ </li>
1186
+ </ul>
1187
+ <li>Intragenic deletion, in-frame</li>
1188
+ <ul>
1189
+ <li><a href=https://drive.google.com/open?id=1tWbf3rg3BmVIZPGGPk023P0aBkDw_ry5XuZLGyGodyg target=_blank>Format</a>,
1190
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.deletion.txt target=_blank>example file</a>
1191
+ </li>
1192
+ </ul>
1193
+ <li>Truncation</li>
1194
+ <ul>
1195
+ <li>Either N-terminus loss or C-terminus loss</li>
1196
+ <li><a href=https://drive.google.com/open?id=1P1g-Y8r30pSKfan1BhYZcsUtSk7wRb4plaO1S-JCJr4 target=_blank>Format</a>,
1197
+ <a href=https://proteinpaint.stjude.org/ppdemo/hg19/heatmap/exampleFiles/example.truncation.txt target=_blank>example file</a>
1198
+ </li>
1199
+ </ul>
1200
+ </ul>`);
1201
+ const fileui = () => {
1202
+ filediv.selectAll("*").remove();
1203
+ new ProjectHandler({
1204
+ bulkin,
1205
+ genomes,
1206
+ gselect,
1207
+ content2flag,
1208
+ flag2tp,
1209
+ filediv,
1210
+ init_bulk_flag
1211
+ });
1212
+ filediv.append("span").html("Select data type&nbsp;");
1213
+ const typeselect = filetypeselect(filediv).style("margin-right", "20px");
1214
+ const butt = filediv.append("input").attr("type", "file").on("change", (event) => {
1215
+ const flag2 = init_bulk_flag(genomes[gselect.options[gselect.selectedIndex].innerHTML]);
1216
+ flag2.geneToUpper = geneToUpper.property("checked");
1217
+ saydiv.text("");
1218
+ const file = event.target.files[0];
1219
+ if (!file) {
1220
+ fileui();
1221
+ return;
1222
+ }
1223
+ if (file.size == 0) {
1224
+ saydiv.text("Wrong file: " + file.name);
1225
+ fileui();
1226
+ return;
1227
+ }
1228
+ const reader = new FileReader();
1229
+ reader.onload = (event2) => {
1230
+ const error = content2flag(event2.target.result, typeselect.node().selectedIndex, flag2);
1231
+ if (error) {
1232
+ saydiv.text("Error: " + error);
1233
+ fileui();
1234
+ return;
1235
+ }
1236
+ flag2tp(flag2, file);
1237
+ };
1238
+ reader.onerror = function() {
1239
+ saydiv.text("Error reading file " + file.name);
1240
+ fileui();
1241
+ return;
1242
+ };
1243
+ saydiv.text("Parsing file " + file.name + " ...");
1244
+ reader.readAsText(file, "utf8");
1245
+ });
1246
+ setTimeout(() => butt.node().focus(), 1100);
1247
+ };
1248
+ fileui();
1249
+ filediv.append("span").html("<br/>Convert gene name to uppercase &nbsp;");
1250
+ const geneToUpper = filediv.append("span").append("input").attr("type", "checkbox").property("checked", true);
1251
+ function flag2tp(flag2, file, _cohort = null, ds = null) {
1252
+ if (typeof flag2 == "string") {
1253
+ saydiv.text(flag2);
1254
+ fileui();
1255
+ return;
1256
+ }
1257
+ saydiv.text("");
1258
+ fileui();
1259
+ const cohort = _cohort ? _cohort : Object.assign({
1260
+ genome: flag2.genome,
1261
+ name: file.name
1262
+ });
1263
+ const err2 = bulkin({
1264
+ flag: flag2,
1265
+ filename: file.name,
1266
+ cohort,
1267
+ flag2thisds: ds
1268
+ });
1269
+ if (err2) {
1270
+ saydiv.text("Error with " + file.name + ": " + err2);
1271
+ return;
1272
+ }
1273
+ if (flag2.good == 0) {
1274
+ saydiv.text("No mutations can be loaded");
1275
+ return;
1276
+ }
1277
+ let visual_holder;
1278
+ if (pane) {
1279
+ disappear(pane.pane);
1280
+ const pane2 = newpane({ x: 100, y: 100, toshrink: true });
1281
+ pane2.header.html('<span style="opacity:.5">FILE</span> ' + file.name);
1282
+ visual_holder = pane2.body;
1283
+ }
1284
+ if (holder !== void 0) {
1285
+ visual_holder = visualdiv.append("div").html('<span style="opacity:.5">FILE</span> ' + file.name);
1286
+ }
1287
+ inputdiv.selectAll("*").remove();
1288
+ import("./tp.ui-2O4UW5N7.js").then((tpui) => {
1289
+ tpui.default(cohort, visual_holder, hostURL);
1290
+ });
1291
+ return cohort;
1292
+ }
1293
+ return function content2flag2tp(file, type) {
1294
+ const error = content2flag(file.content, type, flag);
1295
+ if (error) {
1296
+ saydiv.text("Error: " + error);
1297
+ fileui();
1298
+ return;
1299
+ }
1300
+ flag2tp(flag, file);
1301
+ };
1302
+ }
1303
+ function content2flag(text, type, flag2) {
1304
+ if (!flag2) return "should not happen!";
1305
+ let err2;
1306
+ switch (type) {
1307
+ case 0:
1308
+ err2 = parse_snvindel(text, flag2);
1309
+ if (err2) return err2;
1310
+ break;
1311
+ case 1:
1312
+ err2 = parse_sv(text, flag2, true);
1313
+ if (err2) return err2;
1314
+ break;
1315
+ case 2:
1316
+ err2 = parse_sv(text, flag2, false);
1317
+ if (err2) return err2;
1318
+ break;
1319
+ case 3:
1320
+ err2 = parse_itd(text, flag2);
1321
+ if (err2) return err2;
1322
+ break;
1323
+ case 4:
1324
+ err2 = parse_del(text, flag2);
1325
+ if (err2) return err2;
1326
+ break;
1327
+ case 5:
1328
+ err2 = parse_trunc(text, flag2);
1329
+ if (err2) return err2;
1330
+ break;
1331
+ case 6:
1332
+ err2 = parse_cnv(text, flag2);
1333
+ if (err2) return err2;
1334
+ break;
1335
+ default:
1336
+ return "unknown option array index from file type <select>: " + type;
1337
+ }
1338
+ }
1339
+ function bulkin(p, callback = null) {
1340
+ const flag2 = p.flag;
1341
+ const cohort = p.cohort;
1342
+ if (!cohort.p2st) {
1343
+ cohort.p2st = {};
1344
+ }
1345
+ if (!cohort.dsset) {
1346
+ cohort.dsset = {};
1347
+ }
1348
+ if (!cohort.assaylst) {
1349
+ cohort.assaylst = [];
1350
+ }
1351
+ if (flag2.variantgene) {
1352
+ if (cohort.variantgene) {
1353
+ return "variantgene already set for this cohort";
1354
+ }
1355
+ cohort.variantgene = flag2.variantgene;
1356
+ }
1357
+ if (flag2.snv.badlines.length > 0) {
1358
+ bulk_badline(flag2.snv.header, flag2.snv.badlines);
1359
+ }
1360
+ if (flag2.fusion.badlines.length > 0) {
1361
+ bulk_badline(flag2.fusion.header, flag2.fusion.badlines);
1362
+ }
1363
+ if (flag2.sv.badlines.length > 0) {
1364
+ bulk_badline(flag2.sv.header, flag2.sv.badlines);
1365
+ }
1366
+ if (flag2.cnv.badlines.length > 0) {
1367
+ bulk_badline(flag2.cnv.header, flag2.cnv.badlines);
1368
+ }
1369
+ if (flag2.itd.badlines.length > 0) {
1370
+ bulk_badline(flag2.itd.header, flag2.itd.badlines);
1371
+ }
1372
+ if (flag2.del.badlines.length > 0) {
1373
+ bulk_badline(flag2.del.header, flag2.del.badlines);
1374
+ }
1375
+ if (flag2.truncation.badlines.length > 0) {
1376
+ bulk_badline(flag2.truncation.header, flag2.truncation.badlines);
1377
+ }
1378
+ if (flag2.good == 0) {
1379
+ return false;
1380
+ }
1381
+ const tmp = {};
1382
+ let hastumormaf = false;
1383
+ if (flag2.snv.loaded) {
1384
+ for (const i of flag2.snv.header) {
1385
+ tmp[i] = 1;
1386
+ }
1387
+ if ("maf_tumor_v1" in tmp && "maf_tumor_v2" in tmp) {
1388
+ hastumormaf = true;
1389
+ }
1390
+ }
1391
+ if (flag2.cnv.loaded) {
1392
+ for (const i of flag2.cnv.header) {
1393
+ tmp[i] = 1;
1394
+ }
1395
+ }
1396
+ if (flag2.fusion.loaded) {
1397
+ for (const i of flag2.fusion.header) {
1398
+ tmp[i] = 1;
1399
+ }
1400
+ }
1401
+ if (flag2.sv.loaded) {
1402
+ for (const i of flag2.sv.header) {
1403
+ tmp[i] = 1;
1404
+ }
1405
+ }
1406
+ if (flag2.itd.loaded) {
1407
+ for (const i of flag2.itd.header) {
1408
+ tmp[i] = 1;
1409
+ }
1410
+ }
1411
+ if (flag2.del.loaded) {
1412
+ for (const i of flag2.del.header) {
1413
+ tmp[i] = 1;
1414
+ }
1415
+ }
1416
+ if (flag2.truncation.loaded) {
1417
+ for (const i of flag2.truncation.header) {
1418
+ tmp[i] = 1;
1419
+ }
1420
+ }
1421
+ const hassample = "sample" in tmp || "patient" in tmp;
1422
+ const hasdisease = "disease" in tmp;
1423
+ const hasst = "sampletype" in tmp;
1424
+ let dsc;
1425
+ if (p.flag2thisds) {
1426
+ dsc = p.flag2thisds;
1427
+ if (hassample && !dsc.hassample) {
1428
+ return '"sample" column found in new data but not in existing data';
1429
+ }
1430
+ if (!hassample && dsc.hassample) {
1431
+ return '"sample" column found in existing data but not in new data';
1432
+ }
1433
+ if (hasdisease && !dsc.hasdisease) {
1434
+ return '"disease" column found in new data but not in existing data';
1435
+ }
1436
+ if (!hasdisease && dsc.hasdisease) {
1437
+ return '"disease" column found in existing data but not in new data';
1438
+ }
1439
+ if (hasst && !dsc.hasst) {
1440
+ return '"sampletype" column found in new data but not in existing data';
1441
+ }
1442
+ if (!hasst && dsc.hasst) {
1443
+ return '"sampletype" column found in existing data but not in new data';
1444
+ }
1445
+ for (const genename in flag2.data) {
1446
+ const lst = dsc.bulkdata[genename];
1447
+ if (lst) {
1448
+ dsc.bulkdata[genename] = lst.concat(flag2.data[genename]);
1449
+ } else {
1450
+ dsc.bulkdata[genename] = flag2.data[genename];
1451
+ }
1452
+ }
1453
+ } else {
1454
+ let dsname = p.filename + (flag2.tpsetname ? "_" + flag2.tpsetname : "");
1455
+ if (dsname in flag2.genome.datasets) {
1456
+ let j = 1;
1457
+ let n2 = dsname + " " + j;
1458
+ while (n2 in flag2.genome.datasets) {
1459
+ j++;
1460
+ n2 = dsname + " " + j;
1461
+ }
1462
+ dsname = n2;
1463
+ }
1464
+ dsc = {
1465
+ label: dsname,
1466
+ bulkdata: flag2.data,
1467
+ // official dataset don't have this
1468
+ hassample,
1469
+ hasdisease,
1470
+ hastumormaf,
1471
+ hasst,
1472
+ genome: cohort.genome,
1473
+ import: {},
1474
+ imported: {},
1475
+ importsilent: flag2.snv.silent == 0 ? false : flag2.snv.missense / flag2.snv.silent >= 5 ? false : true
1476
+ };
1477
+ flag2.genome.datasets[dsname] = dsc;
1478
+ cohort.dsset[dsname] = dsc;
1479
+ if (cohort.dbexpression) {
1480
+ if (cohort.dbexpression.tidy) {
1481
+ try {
1482
+ cohort.dbexpression.tidy = new Function(...cohort.dbexpression.tidy);
1483
+ } catch (e) {
1484
+ err("invalid JavaScript for dbexpression.tidy");
1485
+ delete cohort.dbexpression;
1486
+ }
1487
+ }
1488
+ dsc.dbexpression = cohort.dbexpression;
1489
+ }
1490
+ if (hasdisease) {
1491
+ dsc.stratify = [
1492
+ {
1493
+ label: "disease",
1494
+ attr1: { k: "disease", label: "disease" }
1495
+ }
1496
+ ];
1497
+ }
1498
+ }
1499
+ if (hassample) {
1500
+ for (const gene in flag2.data) {
1501
+ for (const m of flag2.data[gene]) {
1502
+ let pn = m.patient;
1503
+ if (!pn) {
1504
+ pn = m.sample;
1505
+ if (!pn) {
1506
+ continue;
1507
+ }
1508
+ }
1509
+ if (!cohort.p2st[pn]) {
1510
+ cohort.p2st[pn] = {};
1511
+ }
1512
+ let st = m.sampletype;
1513
+ if (!st) {
1514
+ st = pn;
1515
+ }
1516
+ if (!cohort.p2st[pn][st]) {
1517
+ cohort.p2st[pn][st] = {
1518
+ dsset: {},
1519
+ tktemplate: []
1520
+ };
1521
+ }
1522
+ if (!cohort.p2st[pn][st].dsset[dsc.label]) {
1523
+ cohort.p2st[pn][st].dsset[dsc.label] = [];
1524
+ }
1525
+ cohort.p2st[pn][st].dsset[dsc.label].push(m);
1526
+ }
1527
+ }
1528
+ }
1529
+ if (callback) callback();
1530
+ return false;
1531
+ }
1532
+ function bulkembed(arg) {
1533
+ if (!arg.name) arg.name = "Unnamed dataset";
1534
+ let holder = arg.holder;
1535
+ if (!holder) {
1536
+ const pane = newpane({ x: 100, y: 100 });
1537
+ holder = pane.body;
1538
+ }
1539
+ const saydiv = holder.append("div");
1540
+ new Promise((resolve, reject) => {
1541
+ const cohort = {
1542
+ dsset: {}
1543
+ };
1544
+ for (const k in arg) {
1545
+ if (k == "snvindel" || k == "svjson" || k == "cnv" || k == "sv" || k == "mutationset") {
1546
+ continue;
1547
+ }
1548
+ cohort[k] = arg[k];
1549
+ }
1550
+ resolve(cohort);
1551
+ }).then((cohort) => {
1552
+ if (!arg.snvindel && !arg.svjson && !arg.cnv && !arg.sv) return cohort;
1553
+ const flag2 = init_bulk_flag(cohort.genome);
1554
+ if (arg.snvindel) {
1555
+ const e = parse_snvindel(arg.snvindel, flag2);
1556
+ if (e) throw { message: "error in snvindel data: " + e };
1557
+ delete arg.snvindel;
1558
+ }
1559
+ if (arg.svjson) {
1560
+ const e = parse_svjson(arg.svjson, flag2);
1561
+ if (e) throw { message: "error in svjson data: " + e };
1562
+ delete arg.svjson;
1563
+ }
1564
+ if (arg.sv) {
1565
+ const e = parse_sv(arg.sv, flag2);
1566
+ if (e) throw { message: "error in svjson data: " + e };
1567
+ delete arg.sv;
1568
+ }
1569
+ if (arg.cnv) {
1570
+ const e = parse_cnv(arg.cnv, flag2);
1571
+ if (e) throw { message: "error in cnv data: " + e };
1572
+ delete arg.cnv;
1573
+ }
1574
+ const err2 = bulkin({
1575
+ flag: flag2,
1576
+ filename: arg.name,
1577
+ cohort
1578
+ });
1579
+ if (err2) throw { message: "Error parsing data: " + err2 };
1580
+ return cohort;
1581
+ }).then((cohort) => {
1582
+ if (!arg.mutationset) return cohort;
1583
+ if (!Array.isArray(arg.mutationset)) throw { message: "mutationset is not an array" };
1584
+ const tasks2 = [];
1585
+ for (const mset of arg.mutationset) {
1586
+ const flag2 = init_bulk_flag(cohort.genome);
1587
+ const tasks = [];
1588
+ if (mset.snvindel) {
1589
+ const req = new Request(arg.hostURL + "/textfile", {
1590
+ method: "POST",
1591
+ body: '{"file":"' + mset.snvindel + '"}'
1592
+ });
1593
+ const task = fetch(req).then((data) => {
1594
+ return data.json();
1595
+ }).then((data) => {
1596
+ if (data.error) throw { message: "error with snvindel file: " + data.error };
1597
+ const e = parse_snvindel(data.text, flag2);
1598
+ if (e) throw { message: "error with snvindel file: " + e };
1599
+ });
1600
+ tasks.push(task);
1601
+ }
1602
+ if (mset.snvindel_url) {
1603
+ tasks.push(
1604
+ dofetch("urltextfile", { url: mset.snvindel_url }).then((data) => {
1605
+ if (data.error) throw { message: "cannot get snvindel file from url" };
1606
+ const e = parse_snvindel(data.text, flag2);
1607
+ if (e) throw { message: "error with snvindel file: " + e };
1608
+ })
1609
+ );
1610
+ }
1611
+ if (mset.cnv) {
1612
+ const req = new Request(arg.hostURL + "/textfile", {
1613
+ method: "POST",
1614
+ body: '{"file":"' + mset.cnv + '"}'
1615
+ });
1616
+ const task = fetch(req).then((data) => {
1617
+ return data.json();
1618
+ }).then((data) => {
1619
+ if (data.error) throw { message: "error with cnv file: " + data.error };
1620
+ const e = parse_cnv(data.text, flag2);
1621
+ if (e) throw { message: "error with cnv file: " + e };
1622
+ });
1623
+ tasks.push(task);
1624
+ }
1625
+ if (mset.cnv_url) {
1626
+ tasks.push(
1627
+ dofetch("urltextfile", { url: mset.cnv_url }).then((data) => {
1628
+ if (data.error) throw { message: "cannot get cnv file from url" };
1629
+ const e = parse_cnv(data.text, flag2);
1630
+ if (e) throw { message: "error with cnv file: " + e };
1631
+ })
1632
+ );
1633
+ }
1634
+ if (mset.sv) {
1635
+ const req = new Request(arg.hostURL + "/textfile", {
1636
+ method: "POST",
1637
+ body: '{"file":"' + mset.sv + '"}'
1638
+ });
1639
+ const task = fetch(req).then((data) => {
1640
+ return data.json();
1641
+ }).then((data) => {
1642
+ if (data.error) throw { message: "error with sv file: " + data.error };
1643
+ const e = parse_sv(data.text, flag2, true);
1644
+ if (e) throw { message: "error with sv file: " + e };
1645
+ });
1646
+ tasks.push(task);
1647
+ }
1648
+ if (mset.sv_url) {
1649
+ tasks.push(
1650
+ dofetch("urltextfile", { url: mset.sv_url }).then((data) => {
1651
+ if (data.error) throw { message: "cannot get sv file from url" };
1652
+ const e = parse_sv(data.text, flag2);
1653
+ if (e) throw { message: "error with sv file: " + e };
1654
+ })
1655
+ );
1656
+ }
1657
+ if (mset.fusion) {
1658
+ const req = new Request(arg.hostURL + "/textfile", {
1659
+ method: "POST",
1660
+ body: '{"file":"' + mset.fusion + '"}'
1661
+ });
1662
+ const task = fetch(req).then((data) => {
1663
+ return data.json();
1664
+ }).then((data) => {
1665
+ if (data.error) throw { message: "error with fusion file: " + data.error };
1666
+ const e = parse_sv(data.text, flag2, false);
1667
+ if (e) throw { message: "error with fusion file: " + e };
1668
+ });
1669
+ tasks.push(task);
1670
+ }
1671
+ if (mset.svjson) {
1672
+ const req = new Request(arg.hostURL + "/textfile", {
1673
+ method: "POST",
1674
+ body: '{"file":"' + mset.svjson + '"}'
1675
+ });
1676
+ const task = fetch(req).then((data) => {
1677
+ return data.json();
1678
+ }).then((data) => {
1679
+ if (data.error) throw { message: "error with svjson file: " + data.error };
1680
+ const e = parse_svjson(data.text, flag2, false);
1681
+ if (e) throw { message: "error with svjson file: " + e };
1682
+ });
1683
+ tasks.push(task);
1684
+ }
1685
+ if (mset.deletion) {
1686
+ const req = new Request(arg.hostURL + "/textfile", {
1687
+ method: "POST",
1688
+ body: '{"file":"' + mset.deletion + '"}'
1689
+ });
1690
+ const task = fetch(req).then((data) => {
1691
+ return data.json();
1692
+ }).then((data) => {
1693
+ if (data.error) throw { message: "error with deletion file: " + data.error };
1694
+ const e = parse_del(data.text, flag2, false);
1695
+ if (e) throw { message: "error with deletion file: " + e };
1696
+ });
1697
+ tasks.push(task);
1698
+ }
1699
+ if (mset.deletion_url) {
1700
+ tasks.push(
1701
+ dofetch("urltextfile", { url: mset.deletion_url }).then((data) => {
1702
+ if (data.error) throw { message: "cannot get deletion file from url" };
1703
+ const e = parse_del(data.text, flag2);
1704
+ if (e) throw { message: "error with deletion file: " + e };
1705
+ })
1706
+ );
1707
+ }
1708
+ if (mset.truncation) {
1709
+ const req = new Request(arg.hostURL + "/textfile", {
1710
+ method: "POST",
1711
+ body: '{"file":"' + mset.truncation + '"}'
1712
+ });
1713
+ const task = fetch(req).then((data) => {
1714
+ return data.json();
1715
+ }).then((data) => {
1716
+ if (data.error) throw { message: "error with truncation file: " + data.error };
1717
+ const e = parse_trunc(data.text, flag2, false);
1718
+ if (e) throw { message: "error with truncation file: " + e };
1719
+ });
1720
+ tasks.push(task);
1721
+ }
1722
+ if (mset.truncation_url) {
1723
+ tasks.push(
1724
+ dofetch("urltextfile", { url: mset.truncation_url }).then((data) => {
1725
+ if (data.error) throw { message: "cannot get truncation file from url" };
1726
+ const e = parse_trunc(data.text, flag2, false);
1727
+ if (e) throw { message: "error with truncation file: " + e };
1728
+ })
1729
+ );
1730
+ }
1731
+ if (mset.itd) {
1732
+ const req = new Request(arg.hostURL + "/textfile", {
1733
+ method: "POST",
1734
+ body: '{"file":"' + mset.itd + '"}'
1735
+ });
1736
+ const task = fetch(req).then((data) => {
1737
+ return data.json();
1738
+ }).then((data) => {
1739
+ if (data.error) throw { message: "error with itd file: " + data.error };
1740
+ const e = parse_itd(data.text, flag2, false);
1741
+ if (e) throw { message: "error with itd file: " + e };
1742
+ });
1743
+ tasks.push(task);
1744
+ }
1745
+ if (mset.itd_url) {
1746
+ tasks.push(
1747
+ dofetch("urltextfile", { url: mset.itd_url }).then((data) => {
1748
+ if (data.error) throw { message: "cannot get itd file from url" };
1749
+ const e = parse_itd(data.text, flag2, false);
1750
+ if (e) throw { message: "error with itd file: " + e };
1751
+ })
1752
+ );
1753
+ }
1754
+ const task2 = Promise.all(tasks).then((data) => {
1755
+ const err2 = bulkin({
1756
+ flag: flag2,
1757
+ filename: arg.name,
1758
+ cohort
1759
+ });
1760
+ if (err2) throw { message: "Error parsing data from " + mset.name + ": " + err2 };
1761
+ });
1762
+ tasks2.push(task2);
1763
+ }
1764
+ return Promise.all(tasks2).then((data) => {
1765
+ return cohort;
1766
+ });
1767
+ }).then((cohort) => {
1768
+ const err2 = tpinit(cohort);
1769
+ if (err2) throw { message: "Error parsing study: " + err2 };
1770
+ saydiv.text("");
1771
+ import("./tp.ui-2O4UW5N7.js").then((p) => {
1772
+ p.default(cohort, holder, arg.hostURL);
1773
+ });
1774
+ }).catch((err2) => {
1775
+ saydiv.text(err2.message);
1776
+ if (err2.stack) {
1777
+ console.log(err2.stack);
1778
+ }
1779
+ });
1780
+ }
1781
+ function parse_snvindel(text, flag2) {
1782
+ const lines = text.trim().split(/\r?\n/);
1783
+ let headerline = lines[0];
1784
+ let lineidx = 0;
1785
+ while (headerline[0] == "#") {
1786
+ lineidx++;
1787
+ headerline = lines[lineidx];
1788
+ }
1789
+ if (!headerline) return "no header line";
1790
+ const err2 = parseheader2(headerline, flag2);
1791
+ if (err2) return "header error: " + err2;
1792
+ for (let i = lineidx + 1; i < lines.length; i++) {
1793
+ if (lines[i] == "") continue;
1794
+ if (lines[i][0] == "#") continue;
1795
+ parseline2(i, lines[i], flag2);
1796
+ }
1797
+ }
1798
+ function parse_svjson(text, flag2) {
1799
+ const lines = text.split(/\r?\n/);
1800
+ let headerline = lines[0];
1801
+ let lineidx = 0;
1802
+ while (headerline[0] == "#") {
1803
+ lineidx++;
1804
+ headerline = lines[lineidx];
1805
+ }
1806
+ if (!headerline) return "no header line";
1807
+ const [err2, header] = parseheader3(headerline, flag2);
1808
+ if (err2) return "header error: " + err2;
1809
+ for (let i = lineidx + 1; i < lines.length; i++) {
1810
+ if (lines[i] == "") continue;
1811
+ if (lines[i][0] == "#") continue;
1812
+ parseline3(i, lines[i], flag2, header);
1813
+ }
1814
+ }
1815
+ function parse_cnv(text, flag2) {
1816
+ const lines = text.split(/\r?\n/);
1817
+ let headerline = lines[0];
1818
+ let lineidx = 0;
1819
+ while (headerline[0] == "#") {
1820
+ lineidx++;
1821
+ headerline = lines[lineidx];
1822
+ }
1823
+ if (!headerline) return "no header line";
1824
+ const err2 = parseheader4(headerline, flag2);
1825
+ if (err2) return "header error: " + err2;
1826
+ for (let i = lineidx + 1; i < lines.length; i++) {
1827
+ if (lines[i] == "") continue;
1828
+ if (lines[i][0] == "#") continue;
1829
+ parseline4(i, lines[i], flag2);
1830
+ }
1831
+ }
1832
+ function parse_itd(text, flag2) {
1833
+ const lines = text.split(/\r?\n/);
1834
+ let headerline = lines[0];
1835
+ let lineidx = 0;
1836
+ while (headerline[0] == "#") {
1837
+ lineidx++;
1838
+ headerline = lines[lineidx];
1839
+ }
1840
+ if (!headerline) return "no header line";
1841
+ const err2 = parseheader5(headerline, flag2);
1842
+ if (err2) return "header error: " + err2;
1843
+ for (let i = lineidx + 1; i < lines.length; i++) {
1844
+ if (lines[i] == "") continue;
1845
+ if (lines[i][0] == "#") continue;
1846
+ parseline5(i, lines[i], flag2);
1847
+ }
1848
+ }
1849
+ function parse_del(text, flag2) {
1850
+ const lines = text.split(/\r?\n/);
1851
+ let headerline = lines[0];
1852
+ let lineidx = 0;
1853
+ while (headerline[0] == "#") {
1854
+ lineidx++;
1855
+ headerline = lines[lineidx];
1856
+ }
1857
+ if (!headerline) return "no header line";
1858
+ const err2 = parseheader6(headerline, flag2);
1859
+ if (err2) return "header error: " + err2;
1860
+ for (let i = lineidx + 1; i < lines.length; i++) {
1861
+ if (lines[i] == "") continue;
1862
+ if (lines[i][0] == "#") continue;
1863
+ parseline6(i, lines[i], flag2);
1864
+ }
1865
+ }
1866
+ function parse_trunc(text, flag2) {
1867
+ const lines = text.split(/\r?\n/);
1868
+ let headerline = lines[0];
1869
+ let lineidx = 0;
1870
+ while (headerline[0] == "#") {
1871
+ lineidx++;
1872
+ headerline = lines[lineidx];
1873
+ }
1874
+ if (!headerline) return "no header line";
1875
+ const err2 = parseheader7(headerline, flag2);
1876
+ if (err2) return "header error: " + err2;
1877
+ for (let i = lineidx + 1; i < lines.length; i++) {
1878
+ if (lines[i] == "") continue;
1879
+ if (lines[i][0] == "#") continue;
1880
+ parseline7(i, lines[i], flag2);
1881
+ }
1882
+ }
1883
+ function parse_sv(text, flag2, isSv) {
1884
+ const lines = text.split(/\r?\n/);
1885
+ let headerline = lines[0];
1886
+ let lineidx = 0;
1887
+ while (headerline[0] == "#") {
1888
+ lineidx++;
1889
+ headerline = lines[lineidx];
1890
+ }
1891
+ if (!headerline) return "no header line";
1892
+ const err2 = parseheader(headerline, flag2, isSv);
1893
+ if (err2) return "header error: " + err2;
1894
+ for (let i = lineidx + 1; i < lines.length; i++) {
1895
+ if (lines[i] == "") continue;
1896
+ if (lines[i][0] == "#") continue;
1897
+ parseline(i, lines[i], flag2, isSv);
1898
+ }
1899
+ }
1900
+
1901
+ // src/tp.init.js
1902
+ function tpinit(cohort) {
1903
+ if (!cohort.p2st) {
1904
+ cohort.p2st = {};
1905
+ }
1906
+ if (!cohort.assays) {
1907
+ cohort.assays = [];
1908
+ }
1909
+ if (!Array.isArray(cohort.assays)) {
1910
+ return ".assays should be an array";
1911
+ }
1912
+ cohort.assaylst = [];
1913
+ let assaynum = 0;
1914
+ for (const assayname of cohort.assays) {
1915
+ const rawassay = cohort[assayname];
1916
+ if (!rawassay) {
1917
+ return 'Assay "' + assayname + '" not found in cohort';
1918
+ }
1919
+ const config = rawassay.config;
1920
+ if (!config) {
1921
+ return '.config object missing for assay "' + assayname + '"';
1922
+ }
1923
+ delete rawassay.config;
1924
+ if (!config.type) {
1925
+ return '.config.type missing for assay "' + assayname + '"';
1926
+ }
1927
+ if (config.type.toLowerCase() == "vcf") {
1928
+ config.type = tkt.ds;
1929
+ config.isvcf = true;
1930
+ } else {
1931
+ if (!validtkt(config.type)) {
1932
+ return 'unknown .config.type "' + config.type + '" for assay "' + assayname + '"';
1933
+ }
1934
+ }
1935
+ config.id = (++assaynum).toString();
1936
+ if (!config.name) {
1937
+ config.name = assayname;
1938
+ }
1939
+ if (config.type == tkt.junction) {
1940
+ if (config.readcountcutoff) {
1941
+ if (!Number.isInteger(config.readcountcutoff) || config.readcountcutoff < 0) {
1942
+ return 'invalid .config.readcountcutoff for assay "' + assayname + '"';
1943
+ }
1944
+ }
1945
+ }
1946
+ cohort.assaylst.push(config);
1947
+ for (const pn in rawassay) {
1948
+ if (!cohort.p2st[pn]) {
1949
+ cohort.p2st[pn] = {};
1950
+ }
1951
+ for (const st in rawassay[pn]) {
1952
+ if (!cohort.p2st[pn][st]) {
1953
+ cohort.p2st[pn][st] = {
1954
+ tktemplate: []
1955
+ };
1956
+ }
1957
+ if (config.type == tkt.vafs1) {
1958
+ for (const name in rawassay[pn][st]) {
1959
+ const tk = rawassay[pn][st][name];
1960
+ if (!tk.file && !tk.url) {
1961
+ return "no file or URL for " + name + " vafs1 of " + pn + ", " + st;
1962
+ }
1963
+ tk.type = tkt.vafs1;
1964
+ tk.patient = pn;
1965
+ tk.sampletype = st;
1966
+ tk.assayname = assayname;
1967
+ tk.id = config.id;
1968
+ tk.tkid = Math.random().toString();
1969
+ if (!tk.name) {
1970
+ tk.name = name + " vaf";
1971
+ }
1972
+ cohort.p2st[pn][st].tktemplate.push(tk);
1973
+ }
1974
+ continue;
1975
+ }
1976
+ let rawtklst = [];
1977
+ if (Array.isArray(rawassay[pn][st])) {
1978
+ rawtklst = rawassay[pn][st];
1979
+ } else {
1980
+ rawtklst.push(rawassay[pn][st]);
1981
+ }
1982
+ for (const _tk of rawtklst) {
1983
+ let tk = _tk;
1984
+ if (!tk.file && !tk.url) {
1985
+ return "track has no file or url (sample: " + pn + ", assay: " + assayname + ")";
1986
+ }
1987
+ if (tk.name) {
1988
+ } else if (tk.partname) {
1989
+ tk.name = pn + (st == pn ? "" : " " + st) + " " + assayname + " " + tk.partname;
1990
+ } else {
1991
+ tk.name = pn + (st == pn ? "" : " " + st) + " " + assayname;
1992
+ }
1993
+ if (config.isvcf) {
1994
+ const [err2, tk2] = vcf2dstk({
1995
+ name: tk.name,
1996
+ file: tk.file,
1997
+ url: tk.url
1998
+ });
1999
+ if (err2) {
2000
+ return "VCF track error: " + err2;
2001
+ }
2002
+ tk = tk2;
2003
+ } else {
2004
+ if (tk.type) {
2005
+ if (!validtkt(tk.type)) {
2006
+ return 'invalid track type "' + tk.type + '" (sample: ' + pn + ", assay: " + assayname + ")";
2007
+ }
2008
+ } else {
2009
+ tk.type = config.type;
2010
+ }
2011
+ }
2012
+ tk.patient = pn;
2013
+ tk.sampletype = st;
2014
+ tk.assayname = assayname;
2015
+ tk.id = config.id;
2016
+ tk.tkid = Math.random().toString();
2017
+ cohort.p2st[pn][st].tktemplate.push(tk);
2018
+ switch (config.type) {
2019
+ case tkt.bigwig:
2020
+ const e = tidy_qtk(tk, config);
2021
+ if (e) {
2022
+ return "Assay " + assayname + ": " + config.type + " track error: " + e;
2023
+ }
2024
+ break;
2025
+ case tkt.junction:
2026
+ tk.categories = config.categories;
2027
+ tk.readcountcutoff = config.readcountcutoff;
2028
+ break;
2029
+ }
2030
+ }
2031
+ }
2032
+ }
2033
+ }
2034
+ delete cohort.assays;
2035
+ {
2036
+ const err2 = cohort2genometkset(cohort);
2037
+ if (err2) {
2038
+ return "Error: " + err2;
2039
+ }
2040
+ }
2041
+ if (cohort.patientannotation) {
2042
+ const err2 = parse_patientannotation(cohort);
2043
+ if (err2) return err2;
2044
+ }
2045
+ if (cohort.browserview) {
2046
+ const err2 = parse_browserview(cohort);
2047
+ if (err2) return err2;
2048
+ }
2049
+ if (cohort.e2pca) {
2050
+ if (!cohort.e2pca.list) return ".list missing from e2pca";
2051
+ if (!Array.isArray(cohort.e2pca.list)) return "e2pca.list should be an array";
2052
+ if (cohort.e2pca.list.length == 0) return "e2pca.list[] length 0";
2053
+ if (!cohort.e2pca.label) {
2054
+ cohort.e2pca.label = "Expression - PCA";
2055
+ }
2056
+ for (const obj of cohort.e2pca.list) {
2057
+ if (!obj.vectorfile) return "vectorfile missing from e2pca";
2058
+ if (!obj.dbfile) return "dbfile missing from e2pca";
2059
+ }
2060
+ }
2061
+ return;
2062
+ }
2063
+ function loadstudycohort(genomes, file, holder, hostURL, jwt, noshow, app) {
2064
+ const wait = holder.append("div").style("color", "#858585");
2065
+ wait.text("Loading " + file + " ...");
2066
+ return fetch(hostURL + "/study", {
2067
+ method: "POST",
2068
+ body: JSON.stringify({ file, jwt })
2069
+ }).then((res) => res.json()).then((data) => {
2070
+ if (!data) {
2071
+ wait.text("Server error!");
2072
+ return;
2073
+ }
2074
+ if (data.error) {
2075
+ wait.text("Error loading study: " + data.error);
2076
+ return;
2077
+ }
2078
+ const cohort = data.cohort;
2079
+ if (!cohort) {
2080
+ wait.text(".cohort missing");
2081
+ return;
2082
+ }
2083
+ if (!cohort.genome) {
2084
+ wait.text("No genome specified in the cohort JSON content");
2085
+ return;
2086
+ }
2087
+ const g = genomes[cohort.genome];
2088
+ if (!g) {
2089
+ wait.text("Invalid genome from cohort: " + cohort.genome);
2090
+ return;
2091
+ }
2092
+ cohort.genome = g;
2093
+ cohort.jwt = jwt;
2094
+ if (!data.flagset) {
2095
+ wait.text(".flagset missing");
2096
+ return;
2097
+ }
2098
+ wait.text("");
2099
+ cohort.dsset = {};
2100
+ for (const k in data.flagset) {
2101
+ const flag2 = data.flagset[k];
2102
+ flag2.genome = g;
2103
+ bulkin({
2104
+ flag: flag2,
2105
+ filename: file,
2106
+ cohort,
2107
+ err: (m) => sayerror(wait, m)
2108
+ });
2109
+ }
2110
+ const err2 = tpinit(cohort);
2111
+ if (err2) {
2112
+ sayerror(wait, err2);
2113
+ }
2114
+ if (!noshow) {
2115
+ return import("./tp.ui-2O4UW5N7.js").then(async (p) => {
2116
+ getsjcharts().catch(console.error);
2117
+ p.default(cohort, holder, hostURL, app);
2118
+ return app;
2119
+ });
2120
+ }
2121
+ });
2122
+ }
2123
+ function tidy_qtk(tk, config) {
2124
+ if (!config) {
2125
+ config = {};
2126
+ }
2127
+ if (!tk.file && !tk.url) {
2128
+ return "no file or url";
2129
+ }
2130
+ if (!tk.pcolor) {
2131
+ tk.pcolor = config.pcolor || "#0066CC";
2132
+ }
2133
+ if (!tk.pcolor2) {
2134
+ tk.pcolor2 = config.pcolor2 || "#CC0000";
2135
+ }
2136
+ if (!tk.ncolor) {
2137
+ tk.ncolor = config.ncolor || "#FF850A";
2138
+ }
2139
+ if (!tk.ncolor2) {
2140
+ tk.ncolor2 = config.ncolor2 || "#0A85FF";
2141
+ }
2142
+ if (!tk.height) {
2143
+ tk.height = config.height || 50;
2144
+ }
2145
+ const scale = {};
2146
+ if (config.scale) {
2147
+ for (const k in config.scale) {
2148
+ scale[k] = config.scale[k];
2149
+ }
2150
+ }
2151
+ if (tk.scale) {
2152
+ for (const k in tk.scale) {
2153
+ scale[k] = tk.scale[k];
2154
+ }
2155
+ }
2156
+ scale.auto = true;
2157
+ if (Number.isFinite(scale.min) && Number.isFinite(scale.max)) {
2158
+ delete scale.auto;
2159
+ } else if (Number.isFinite(scale.percentile)) {
2160
+ delete scale.auto;
2161
+ }
2162
+ tk.scale = scale;
2163
+ }
2164
+ function cohort2genometkset(cohort) {
2165
+ const lst = [];
2166
+ for (const pn in cohort.p2st) {
2167
+ for (const st in cohort.p2st[pn]) {
2168
+ const templates = cohort.p2st[pn][st].tktemplate;
2169
+ if (!templates) continue;
2170
+ for (const t of templates) {
2171
+ lst.push(t);
2172
+ }
2173
+ }
2174
+ }
2175
+ if (cohort.browserview && cohort.browserview.assays) {
2176
+ for (const assayname in cohort.browserview.assays) {
2177
+ const assayview = cohort.browserview.assays[assayname];
2178
+ if (assayview.combined && assayview.combinetk) {
2179
+ lst.push(assayview.combinetk);
2180
+ }
2181
+ }
2182
+ }
2183
+ if (!cohort.genome.tkset) {
2184
+ cohort.genome.tkset = [];
2185
+ }
2186
+ const thisset = {
2187
+ name: cohort.name,
2188
+ tklst: lst
2189
+ };
2190
+ if (cohort.trackfacets) {
2191
+ if (!Array.isArray(cohort.trackfacets)) {
2192
+ return ".trackfacets is not an array";
2193
+ }
2194
+ const lst2 = [];
2195
+ for (const fc of cohort.trackfacets) {
2196
+ if (!fc.samples) {
2197
+ return "trackfacets: .samples missing from facet " + fc.name;
2198
+ }
2199
+ if (!Array.isArray(fc.samples)) {
2200
+ return "trackfacets: .samples is not array from facet " + fc.name;
2201
+ }
2202
+ if (!fc.assays) {
2203
+ return "trackfacets: .assays missing from a facet " + fc.name;
2204
+ }
2205
+ if (!Array.isArray(fc.assays)) {
2206
+ return "trackfacets: .assays is not array from a facet " + fc.name;
2207
+ }
2208
+ lst2.push(fc);
2209
+ }
2210
+ if (lst2.length) {
2211
+ thisset.facetlst = lst2;
2212
+ }
2213
+ }
2214
+ cohort.genome.tkset.push(thisset);
2215
+ return null;
2216
+ }
2217
+ function parse_browserview(cohort) {
2218
+ if (cohort.browserview.position) {
2219
+ let pos;
2220
+ if (typeof cohort.browserview.position == "string") {
2221
+ pos = string2pos(cohort.browserview.position, cohort.genome);
2222
+ if (!pos) {
2223
+ return ".browserview.position invalid value";
2224
+ }
2225
+ } else {
2226
+ pos = cohort.browserview.position;
2227
+ }
2228
+ const e = invalidcoord(cohort.genome, pos.chr, pos.start, pos.stop);
2229
+ if (e) {
2230
+ return ".browserview.position error: " + e;
2231
+ }
2232
+ cohort.browserview.position = pos;
2233
+ } else {
2234
+ cohort.browserview.position = {
2235
+ chr: cohort.genome.defaultcoord.chr,
2236
+ start: cohort.genome.defaultcoord.start,
2237
+ stop: cohort.genome.defaultcoord.stop
2238
+ };
2239
+ }
2240
+ if (cohort.browserview.assays) {
2241
+ for (const assayname in cohort.browserview.assays) {
2242
+ if (typeof cohort.browserview.assays[assayname] != "object") {
2243
+ cohort.browserview.assays[assayname] = {};
2244
+ }
2245
+ const assayview = cohort.browserview.assays[assayname];
2246
+ for (const a of cohort.assaylst) {
2247
+ if (a.name == assayname) {
2248
+ assayview.assayobj = a;
2249
+ break;
2250
+ }
2251
+ }
2252
+ if (!assayview.assayobj) {
2253
+ console.log("missing assayobj for assayview of " + assayname);
2254
+ continue;
2255
+ }
2256
+ if (assayview.sum_view) {
2257
+ delete assayview.sum_view;
2258
+ assayview.combined = true;
2259
+ }
2260
+ if (assayview.combined) {
2261
+ const combinetk = {};
2262
+ for (const k in assayview.assayobj) {
2263
+ combinetk[k] = assayview.assayobj[k];
2264
+ }
2265
+ for (const k in assayview) {
2266
+ if (k == "assayobj") continue;
2267
+ combinetk[k] = assayview[k];
2268
+ }
2269
+ if (!combinetk.name) {
2270
+ combinetk.name = assayname;
2271
+ }
2272
+ combinetk.tracks = [];
2273
+ for (const pn in cohort.p2st) {
2274
+ for (const st in cohort.p2st[pn]) {
2275
+ for (const t of cohort.p2st[pn][st].tktemplate) {
2276
+ if (t.id == assayview.assayobj.id) {
2277
+ t.patient = pn;
2278
+ t.sampletype = st;
2279
+ combinetk.tracks.push(t);
2280
+ }
2281
+ }
2282
+ }
2283
+ }
2284
+ if (combinetk.isvcf) {
2285
+ combinetk.ds = {
2286
+ id2vcf: {},
2287
+ label: combinetk.name
2288
+ };
2289
+ for (const t of combinetk.tracks) {
2290
+ for (const i in t.ds.id2vcf) {
2291
+ t.__vcfobj = t.ds.id2vcf[i];
2292
+ }
2293
+ combinetk.ds.id2vcf[t.__vcfobj.vcfid] = t.__vcfobj;
2294
+ }
2295
+ }
2296
+ assayview.combinetk = combinetk;
2297
+ }
2298
+ }
2299
+ }
2300
+ if (cohort.browserview.defaultassaytracks) {
2301
+ if (!Array.isArray(cohort.browserview.defaultassaytracks)) return ".browserview.defaultassaytracks must be array";
2302
+ for (let i = 0; i < cohort.browserview.defaultassaytracks.length; i++) {
2303
+ const t = cohort.browserview.defaultassaytracks[i];
2304
+ if (!t.assay) return ".assay missing from .defaultassaytracks #" + (i + 1);
2305
+ if (!cohort[t.assay]) return "unknown assay name from .defaultassaytracks #" + (i + 1) + ": " + t.assay;
2306
+ if (!t.level1) return ".level1 missing from .defaultassaytracks #" + (i + 1);
2307
+ if (!cohort[t.assay][t.level1])
2308
+ return "level1 not exist in assay from .defaultassaytracks #" + (i + 1) + ": " + t.level1;
2309
+ if (t.level2) {
2310
+ if (!cohort[t.assay][t.level1][t.level2])
2311
+ return "level2 not exist in assay from .defaultassaytracks #" + (i + 1) + ": " + t.level2;
2312
+ }
2313
+ }
2314
+ }
2315
+ return null;
2316
+ }
2317
+ function parse_patientannotation(cohort) {
2318
+ if (!cohort.patientannotation.annotation) {
2319
+ return ".patientannotation.annotation missing";
2320
+ }
2321
+ if (!cohort.patientannotation.metadata) {
2322
+ return ".patientannotation.metadata missing";
2323
+ }
2324
+ if (!Array.isArray(cohort.patientannotation.metadata)) {
2325
+ return ".patientannotation.metadata should be an array";
2326
+ }
2327
+ const mdh = {};
2328
+ for (const md of cohort.patientannotation.metadata) {
2329
+ if (md.key == void 0) {
2330
+ return "patientannotation: key missing for a metadata term";
2331
+ }
2332
+ if (!md.values) {
2333
+ return "patientannotation: values missing for metadata term " + md.key;
2334
+ }
2335
+ if (!Array.isArray(md.values)) {
2336
+ return "patientannotation: .values not an array for metadata term " + md.key;
2337
+ }
2338
+ if (!md.label) {
2339
+ md.label = md.key;
2340
+ }
2341
+ mdh[md.key] = {
2342
+ label: md.label,
2343
+ values: {}
2344
+ };
2345
+ const colorfunc = ordinal(category10_default);
2346
+ for (const at of md.values) {
2347
+ if (at.key == void 0) {
2348
+ return "key missing for an attribute of term " + md.key;
2349
+ }
2350
+ if (!at.label) {
2351
+ at.label = at.key;
2352
+ }
2353
+ if (!at.color) {
2354
+ at.color = colorfunc(at.key);
2355
+ }
2356
+ mdh[md.key].values[at.key] = at;
2357
+ }
2358
+ }
2359
+ cohort.patientannotation.mdh = mdh;
2360
+ return null;
2361
+ }
2362
+
2363
+ export {
2364
+ loadstudycohort,
2365
+ bulkui,
2366
+ content2flag,
2367
+ bulkin,
2368
+ bulkembed
2369
+ };
2370
+ //# sourceMappingURL=chunk-L2HBHFTK.js.map