@sjcrh/proteinpaint-client 2.166.0 → 2.167.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (882) hide show
  1. package/dist/2dmaf-6M6QWXAQ.js +1364 -0
  2. package/dist/AIProjectAdmin-2NHMC3IV.js +780 -0
  3. package/dist/AppHeader-CTHEWSZD.js +813 -0
  4. package/dist/BoxPlot-3U6ZAKKO.js +44 -0
  5. package/dist/CorrelationVolcano-2ASIR6KY.js +616 -0
  6. package/dist/DifferentialAnalysis-C3NYGF7U.js +237 -0
  7. package/dist/Disco-2QLBZ3X5.js +3089 -0
  8. package/dist/Disco.UI-GPIIPM2P.js +238 -0
  9. package/dist/DziViewer-OHPZOH72.js +16328 -0
  10. package/dist/GB-FH6YQGHI.js +1099 -0
  11. package/dist/HicApp-TI2II3SZ.js +2218 -0
  12. package/dist/NumBinaryEditor-O42T63EX.js +259 -0
  13. package/dist/NumBinaryEditor.unit.spec-UMB2PHT5.js +277 -0
  14. package/dist/NumContEditor-7NOUKPCV.js +98 -0
  15. package/dist/NumContEditor.unit.spec-JGXJ2HLE.js +160 -0
  16. package/dist/NumCustomBinEditor-6CHN3KX3.js +29 -0
  17. package/dist/NumCustomBinEditor.unit.spec-RJPQLE3E.js +275 -0
  18. package/dist/NumDiscreteEditor-AFTUKU4K.js +145 -0
  19. package/dist/NumDiscreteEditor.unit.spec-GKR6ZNBQ.js +193 -0
  20. package/dist/NumRegularBinEditor-UJ5WQPHR.js +29 -0
  21. package/dist/NumRegularBinEditor.unit.spec-5HGJQEX7.js +220 -0
  22. package/dist/NumSplineEditor-JANA2DUE.js +181 -0
  23. package/dist/NumSplineEditor.unit.spec-UYAMAKZD.js +190 -0
  24. package/dist/NumericDensity-YE5R4CNP.js +29 -0
  25. package/dist/NumericDensity.unit.spec-SVEB5U2S.js +212 -0
  26. package/dist/NumericHandler-WW4M7YW2.js +30 -0
  27. package/dist/NumericHandler.unit.spec-2BWDFO53.js +210 -0
  28. package/dist/SC-UGJGMBL7.js +714 -0
  29. package/dist/Volcano-IU76MEIL.js +1018 -0
  30. package/dist/WSIViewer-3S7N4UDO.js +46959 -0
  31. package/dist/WsiSamplesPlot-4CAOHWCL.js +153 -0
  32. package/dist/adSandbox-AEBS3RTL.js +29 -0
  33. package/dist/alphaGenome-F2PB4SGI.js +170 -0
  34. package/dist/app-6SKETLMT.js +28 -0
  35. package/dist/app-GBEF2HBR.js +54 -0
  36. package/dist/app.js +16 -16
  37. package/dist/bam-5SE6XQJV.js +842 -0
  38. package/dist/barchart-AUSOT2XB.js +48 -0
  39. package/dist/barchart.data-GYCNBRPY.js +30 -0
  40. package/dist/barchart.events-QTSWNYXO.js +44 -0
  41. package/dist/barchart.integration.spec-LORJLJVX.js +1600 -0
  42. package/dist/bars.renderer-4N4QOUNI.js +12 -0
  43. package/dist/bars.settings-SDU7PZOS.js +10 -0
  44. package/dist/block-QLSIELXK.js +6291 -0
  45. package/dist/block.init-OOLEA6ZK.js +29 -0
  46. package/dist/block.mds.expressionrank-D2KUISXZ.js +350 -0
  47. package/dist/block.mds.geneboxplot-AMYBWXPS.js +819 -0
  48. package/dist/block.mds.junction-OG335MBK.js +1536 -0
  49. package/dist/block.mds.svcnv-WYDBQ6FV.js +6792 -0
  50. package/dist/block.svg-OH73245R.js +155 -0
  51. package/dist/block.tk.aicheck-CG5THFW2.js +274 -0
  52. package/dist/block.tk.ase-G2L3G5MQ.js +356 -0
  53. package/dist/block.tk.bam-DXWCA6EU.js +1897 -0
  54. package/dist/block.tk.bedgraphdot-LF3TFPNL.js +375 -0
  55. package/dist/block.tk.bigwig.ui-JKXZ3VDF.js +202 -0
  56. package/dist/block.tk.hicstraw-ZK4RKFB6.js +814 -0
  57. package/dist/block.tk.junction-ZB7Q2NLB.js +2355 -0
  58. package/dist/block.tk.junction.textmatrixui-ZYNQWKIW.js +190 -0
  59. package/dist/block.tk.ld-7H64HGER.js +90 -0
  60. package/dist/block.tk.menu-WFVKAH74.js +1020 -0
  61. package/dist/block.tk.pgv-632LLSBI.js +935 -0
  62. package/dist/brainImaging-AEPTHIQF.js +417 -0
  63. package/dist/chat-3XZCAFDD.js +142 -0
  64. package/dist/chat-3XZCAFDD.js.map +7 -0
  65. package/dist/chunk-22O6F463.js +619 -0
  66. package/dist/chunk-2HJ7OD7H.js +252 -0
  67. package/dist/chunk-2MN5JLZB.js +2878 -0
  68. package/dist/chunk-2OVIUIIL.js +1720 -0
  69. package/dist/chunk-2OVIUIIL.js.map +7 -0
  70. package/dist/chunk-37CK5IGW.js +480 -0
  71. package/dist/chunk-3JFEWVHR.js +80 -0
  72. package/dist/chunk-3MGBC64I.js +133 -0
  73. package/dist/chunk-3NWLWH4G.js +6364 -0
  74. package/dist/chunk-46T54RUY.js +1133 -0
  75. package/dist/chunk-46T54RUY.js.map +7 -0
  76. package/dist/chunk-4GKQ5PWY.js +142 -0
  77. package/dist/chunk-4PHD5H4A.js +226 -0
  78. package/dist/chunk-56IFQMJK.js +413 -0
  79. package/dist/chunk-5AMBV2JE.js +797 -0
  80. package/dist/chunk-5AMBV2JE.js.map +7 -0
  81. package/dist/chunk-5DMFTXUZ.js +158 -0
  82. package/dist/chunk-5QJDZHRU.js +95 -0
  83. package/dist/chunk-5WAVKWL6.js +1275 -0
  84. package/dist/chunk-6ISTNHM6.js +144 -0
  85. package/dist/chunk-6VQ4C735.js +1536 -0
  86. package/dist/chunk-74WMSW3E.js +229 -0
  87. package/dist/chunk-AFU66YOW.js +459 -0
  88. package/dist/chunk-AUJ2YUXV.js +14 -0
  89. package/dist/chunk-B65X5UQH.js +518 -0
  90. package/dist/chunk-B6I64LSV.js +634 -0
  91. package/dist/chunk-BAJ74DKS.js +419 -0
  92. package/dist/chunk-BAJ74DKS.js.map +7 -0
  93. package/dist/chunk-BTYCW3D5.js +85 -0
  94. package/dist/chunk-CCB5KYFQ.js +1415 -0
  95. package/dist/chunk-CKLYFA7H.js +467 -0
  96. package/dist/chunk-CLYRJ466.js +272 -0
  97. package/dist/chunk-CPHCZZWT.js +82 -0
  98. package/dist/chunk-CUADOD2T.js +217 -0
  99. package/dist/chunk-CV6ID6T7.js +422 -0
  100. package/dist/chunk-CWHBWY3B.js +190 -0
  101. package/dist/chunk-D53HBTYQ.js +238 -0
  102. package/dist/chunk-DDOM4XYV.js +1177 -0
  103. package/dist/chunk-DDOM4XYV.js.map +7 -0
  104. package/dist/chunk-DKI7YOTJ.js +196 -0
  105. package/dist/chunk-DNU4IPD2.js +165 -0
  106. package/dist/chunk-FN5XPUPH.js +83 -0
  107. package/dist/chunk-FN5XPUPH.js.map +7 -0
  108. package/dist/chunk-GLSDMBHR.js +55 -0
  109. package/dist/chunk-GLSDMBHR.js.map +7 -0
  110. package/dist/chunk-H3BSKMND.js +487 -0
  111. package/dist/chunk-H3BSKMND.js.map +7 -0
  112. package/dist/chunk-H6HP4H3U.js +2327 -0
  113. package/dist/chunk-HPEMEDXB.js +123 -0
  114. package/dist/chunk-HUDESZGX.js +1151 -0
  115. package/dist/chunk-ITJ2SXU5.js +467 -0
  116. package/dist/chunk-ITJ2SXU5.js.map +7 -0
  117. package/dist/chunk-J7IU77CA.js +166 -0
  118. package/dist/chunk-JMO7ENSD.js +381 -0
  119. package/dist/chunk-JTPN3BRG.js +129 -0
  120. package/dist/chunk-KCAMFDJH.js +323 -0
  121. package/dist/chunk-LD45BCVM.js +177 -0
  122. package/dist/chunk-LMELY5Z2.js +1412 -0
  123. package/dist/chunk-LVQK62CV.js +215 -0
  124. package/dist/chunk-MCVLRF66.js +157 -0
  125. package/dist/chunk-MK7RRJTX.js +1968 -0
  126. package/dist/chunk-MK7RRJTX.js.map +7 -0
  127. package/dist/chunk-MLD7DW5I.js +613 -0
  128. package/dist/chunk-NEF7LGNE.js +2789 -0
  129. package/dist/chunk-O7BAQPP3.js +256 -0
  130. package/dist/chunk-O7BAQPP3.js.map +7 -0
  131. package/dist/chunk-OARG7PAV.js +401 -0
  132. package/dist/chunk-OGCF6E6I.js +4947 -0
  133. package/dist/chunk-OGCF6E6I.js.map +7 -0
  134. package/dist/chunk-OGWY4MOB.js +748 -0
  135. package/dist/chunk-PQD6K5W5.js +2784 -0
  136. package/dist/chunk-Q4FYGFTQ.js +91 -0
  137. package/dist/chunk-QX5QVWUP.js +451 -0
  138. package/dist/chunk-QX5QVWUP.js.map +7 -0
  139. package/dist/chunk-RA2KI64U.js +303 -0
  140. package/dist/chunk-RHHLAKYS.js +1088 -0
  141. package/dist/chunk-RKV3CP4C.js +258 -0
  142. package/dist/chunk-RL7RU2V7.js +368 -0
  143. package/dist/chunk-RQ7CE7SK.js +161 -0
  144. package/dist/chunk-RX552WU6.js +1143 -0
  145. package/dist/chunk-S7V4SFKB.js +276 -0
  146. package/dist/chunk-SEL5UNRC.js +142 -0
  147. package/dist/chunk-SRBO57AD.js +297 -0
  148. package/dist/chunk-SYGLOTOV.js +1197 -0
  149. package/dist/chunk-TGZA4ETW.js +311 -0
  150. package/dist/chunk-TGZA4ETW.js.map +7 -0
  151. package/dist/chunk-UZ466XO3.js +203 -0
  152. package/dist/chunk-VDF5W47R.js +149 -0
  153. package/dist/chunk-W4SEWZF2.js +279 -0
  154. package/dist/chunk-W4SEWZF2.js.map +7 -0
  155. package/dist/chunk-W5EG334J.js +15083 -0
  156. package/dist/chunk-W5EG334J.js.map +7 -0
  157. package/dist/chunk-WTPVXDJT.js +31 -0
  158. package/dist/chunk-XRIM2YJZ.js +228 -0
  159. package/dist/chunk-YSWMQO23.js +55 -0
  160. package/dist/chunk-ZBZXIWSK.js +402 -0
  161. package/dist/chunk-ZFFHOEBE.js +117 -0
  162. package/dist/chunk-ZG63ZUDE.js +102 -0
  163. package/dist/chunk-ZGQ3BMLW.js +2676 -0
  164. package/dist/chunk-ZNINQ3FN.js +293 -0
  165. package/dist/chunk-ZQZWM544.js +4172 -0
  166. package/dist/condition-4FVKPSQ2.js +323 -0
  167. package/dist/controls-ZWBN566I.js +35 -0
  168. package/dist/controls.btns-H4TWTHTW.js +10 -0
  169. package/dist/controls.config-YU4W3CDL.js +31 -0
  170. package/dist/correlation-VADB4SQO.js +102 -0
  171. package/dist/cuminc-4BXE2YS6.js +1143 -0
  172. package/dist/cuminc.integration.spec-XQREKHVA.js +669 -0
  173. package/dist/customdata.inputui-VBQWT3M7.js +278 -0
  174. package/dist/dataDownload-QIZKBKH7.js +320 -0
  175. package/dist/dataDownload.integration.spec-MLJEHLYD.js +184 -0
  176. package/dist/databrowser.ui-6UIR4ULJ.js +426 -0
  177. package/dist/dictionary-FLWIWAC6.js +90 -0
  178. package/dist/e2pca-NKWSJRXM.js +341 -0
  179. package/dist/ep-EPN3AR6D.js +1247 -0
  180. package/dist/expclust.gdc.spec-ZRUH5E6E.js +298 -0
  181. package/dist/facet-BM7SLACF.js +437 -0
  182. package/dist/frequencyChart-HBXRIBAW.js +371 -0
  183. package/dist/frequencyChart.integration.spec-YJUYZWM6.js +301 -0
  184. package/dist/geneExpClustering-4VD5PAWN.js +242 -0
  185. package/dist/geneExpression-6OT2Y4P6.js +54 -0
  186. package/dist/geneExpression-EAMEZXJQ.js +310 -0
  187. package/dist/geneORA-RI2AG7JT.js +272 -0
  188. package/dist/geneVariant-FYYEOTWA.js +32 -0
  189. package/dist/geneVariant-PAKVDVC4.js +29 -0
  190. package/dist/genefusion.ui-QWC42XWQ.js +242 -0
  191. package/dist/geneset-XA6IWP3Q.js +186 -0
  192. package/dist/genomeBrowser.spec-LRKXWXNT.js +272 -0
  193. package/dist/grin2-O6TETVZ3.js +1044 -0
  194. package/dist/grin2-O6TETVZ3.js.map +7 -0
  195. package/dist/grin2-WLB7BY3S.js +1547 -0
  196. package/dist/gsea-ZM4WOPSQ.js +43 -0
  197. package/dist/hierCluster-LD43LLRC.js +60 -0
  198. package/dist/hierCluster-ZGYRS2WV.js +56 -0
  199. package/dist/hierCluster.config-O5HUOFNH.js +32 -0
  200. package/dist/hierCluster.integration.spec-37UNKHTH.js +389 -0
  201. package/dist/hierCluster.interactivity-B27ETKRP.js +45 -0
  202. package/dist/hierCluster.renderers-GWFH5ZX7.js +21 -0
  203. package/dist/imagePlot-LJZVGNDJ.js +134 -0
  204. package/dist/importPlot-RMVENQRD.js +8 -0
  205. package/dist/launch.adhoc-S3XHRSLN.js +36 -0
  206. package/dist/leftlabel.sample-J6PCA3UB.js +249 -0
  207. package/dist/lollipop-OZTV4C7A.js +159 -0
  208. package/dist/maf-3SRLCKGO.js +435 -0
  209. package/dist/maf-3SRLCKGO.js.map +7 -0
  210. package/dist/maftimeline-6F2LQJU6.js +584 -0
  211. package/dist/matrix-FIXOFAB4.js +60 -0
  212. package/dist/matrix-O5KPDLM2.js +55 -0
  213. package/dist/matrix.cells-SCLZA3P4.js +30 -0
  214. package/dist/matrix.config-WG7HFJL4.js +33 -0
  215. package/dist/matrix.controls-QQLBUUYP.js +31 -0
  216. package/dist/matrix.data-6JLF5HVI.js +35 -0
  217. package/dist/matrix.dom-QO7BXZ27.js +11 -0
  218. package/dist/matrix.groups-QMZMZ6Q7.js +26 -0
  219. package/dist/matrix.integration.spec-ZJYWNQ57.js +2936 -0
  220. package/dist/matrix.interactivity-ZZY5ET4E.js +36 -0
  221. package/dist/matrix.layout-XKFB4PKY.js +35 -0
  222. package/dist/matrix.legend-CS6DNC5V.js +22 -0
  223. package/dist/matrix.renderers-4LST6PBA.js +29 -0
  224. package/dist/matrix.serieses-3SERD6CV.js +21 -0
  225. package/dist/matrix.sort-UVS6WHIS.js +27 -0
  226. package/dist/matrix.sort.unit.spec-CTSUNUWB.js +464 -0
  227. package/dist/matrix.sorterUi-JDGLTLJM.js +18 -0
  228. package/dist/matrix.sorterUi.unit.spec-VQFMHIYI.js +335 -0
  229. package/dist/mavb-ECQ2CQ7F.js +723 -0
  230. package/dist/mds.fimo-JDYDT5NK.js +509 -0
  231. package/dist/mds.samplescatterplot-PEJBVSTO.js +1541 -0
  232. package/dist/mds.survivalplot-GYK6VRQT.js +474 -0
  233. package/dist/mutationSignature-43SECPTY.js +72 -0
  234. package/dist/numericDictTermCluster-2ER4FUKO.js +72 -0
  235. package/dist/oncomatrix-ZXDJMLN3.js +287 -0
  236. package/dist/oncomatrix.spec-HOPRIG3I.js +439 -0
  237. package/dist/plot.2dvaf-Y4SZUHLD.js +368 -0
  238. package/dist/plot.app-W5Z3C7P5.js +35 -0
  239. package/dist/plot.barplot-B2PRZDKV.js +93 -0
  240. package/dist/plot.boxplot-J7ET34FY.js +143 -0
  241. package/dist/plot.brainImaging-ISY4P6RT.js +51 -0
  242. package/dist/plot.disco-D7AL42PW.js +100 -0
  243. package/dist/plot.dzi-O32LH65U.js +33 -0
  244. package/dist/plot.ssgq-WF7262IZ.js +130 -0
  245. package/dist/plot.vaf2cov-OB6UKSFQ.js +250 -0
  246. package/dist/plot.wsi-J5S4YYXN.js +36 -0
  247. package/dist/polar-LIJORXR6.js +179 -0
  248. package/dist/profile.spec-3KE4CREI.js +71 -0
  249. package/dist/profileBarchart-UQHOJB5V.js +260 -0
  250. package/dist/profileForms-WTYVTIUN.js +365 -0
  251. package/dist/profilePlot-SOXXEUAT.js +50 -0
  252. package/dist/profileRadar-2OHJ2RIU.js +256 -0
  253. package/dist/profileRadarFacility-GHLG3QNG.js +256 -0
  254. package/dist/qualitative-B3OY7A7P.js +34 -0
  255. package/dist/regression-HO2TO4XT.js +57 -0
  256. package/dist/regression.inputs-JN3ZMIOP.js +49 -0
  257. package/dist/regression.inputs.term-67HVMXFZ.js +49 -0
  258. package/dist/regression.inputs.values.table-JXJK2YZT.js +46 -0
  259. package/dist/regression.integration.spec-L54ZS5VY.js +777 -0
  260. package/dist/regression.results-3ZSFKUNN.js +31 -0
  261. package/dist/regression.spec-SVWCQX2U.js +699 -0
  262. package/dist/report-IHX7XSOI.js +220 -0
  263. package/dist/runChart-QLQMK3OE.js +54 -0
  264. package/dist/runchart.integration.spec-5NVY5GHR.js +362 -0
  265. package/dist/sampleScatter.spec-4Q5CQQWH.js +193 -0
  266. package/dist/sampleView-7WHDFHB5.js +42 -0
  267. package/dist/samplelst-34GJVLVD.js +102 -0
  268. package/dist/samplematrix-L2HOSLUT.js +2189 -0
  269. package/dist/scatter-X6AAM2LJ.js +55 -0
  270. package/dist/scatter.integration.spec-QSH3PLBK.js +1026 -0
  271. package/dist/selectGenomeWithTklst-AJS2IPPW.js +125 -0
  272. package/dist/singleCellPlot-7JEWDVSR.js +50 -0
  273. package/dist/singlecell-IC5KU72L.js +1563 -0
  274. package/dist/singlecell-NWANPXWM.js +80 -0
  275. package/dist/snp-PSRNMTL6.js +73 -0
  276. package/dist/snplocus-QCAVDYLR.js +199 -0
  277. package/dist/spliceevent.a53ss.diagram-SGDJKUEC.js +142 -0
  278. package/dist/spliceevent.exonskip.diagram-BUYTHCK5.js +268 -0
  279. package/dist/spliceevent.noeventdiagram-OJZJUHXP.js +451 -0
  280. package/dist/ssGSEA-UUZG57MF.js +53 -0
  281. package/dist/stattable-324FS2HA.js +89 -0
  282. package/dist/summarizeCnvGeneexp-ZVZYWP43.js +136 -0
  283. package/dist/summarizeGeneexpSurvival-7XJRMT6M.js +90 -0
  284. package/dist/summarizeMutationDiagnosis-ZKLXOVY2.js +32 -0
  285. package/dist/summarizeMutationSurvival-S4YPGLWA.js +92 -0
  286. package/dist/summary-RVG7JL6Y.js +55 -0
  287. package/dist/summary.integration.spec-SCD35GO4.js +405 -0
  288. package/dist/summaryInput-DMN6DTSW.js +170 -0
  289. package/dist/sunburst-QZXYILRC.js +275 -0
  290. package/dist/survival-6CWEBRSF.js +41 -0
  291. package/dist/survival-J657VYLI.js +49 -0
  292. package/dist/survival.integration.spec-S5WE4V6M.js +601 -0
  293. package/dist/svgraph-NEKJL24M.js +1378 -0
  294. package/dist/svmr-5RQ5JQF2.js +3833 -0
  295. package/dist/table-CG6Z6NCJ.js +193 -0
  296. package/dist/termCollection-FOQNVXB7.js +80 -0
  297. package/dist/termInfo-5USFZGDB.js +9 -0
  298. package/dist/tk-2O7XOVGJ.js +37 -0
  299. package/dist/tp.ui-S4YUVCZH.js +1450 -0
  300. package/dist/tvs.dtcnv.continuous-7BPIXZ6C.js +65 -0
  301. package/dist/tvs.numeric-FCC2EY62.js +355 -0
  302. package/dist/tvs.samplelst-PKGFTULN.js +95 -0
  303. package/dist/violin-C7IBRTYP.js +47 -0
  304. package/dist/violin.integration.spec-WXRD3Z4E.js +1425 -0
  305. package/dist/violin.interactivity-BMG4TG5L.js +39 -0
  306. package/dist/violin.renderer-WUNW6ULV.js +31 -0
  307. package/dist/vocabulary-UUNEEBM3.js +32 -0
  308. package/package.json +3 -3
  309. package/dist/2dmaf-E4NOGWWO.js +0 -1364
  310. package/dist/AIProjectAdmin-3QDXMCOK.js +0 -780
  311. package/dist/AppHeader-IFZ57DJE.js +0 -813
  312. package/dist/BoxPlot-GXDTPRA5.js +0 -44
  313. package/dist/CorrelationVolcano-S4GUYIPT.js +0 -616
  314. package/dist/DifferentialAnalysis-YLKYWPUT.js +0 -237
  315. package/dist/Disco-OQMP3HRQ.js +0 -3089
  316. package/dist/Disco.UI-XB3XQP33.js +0 -238
  317. package/dist/DziViewer-UIRNTFNS.js +0 -16328
  318. package/dist/GB-KDPJTOLP.js +0 -1099
  319. package/dist/HicApp-XJERMLKH.js +0 -2218
  320. package/dist/NumBinaryEditor-5MWWWNLW.js +0 -259
  321. package/dist/NumBinaryEditor.unit.spec-ROGT5FOH.js +0 -277
  322. package/dist/NumContEditor-RRCB4CKG.js +0 -98
  323. package/dist/NumContEditor.unit.spec-AJTKOF7W.js +0 -160
  324. package/dist/NumCustomBinEditor-3GJITZ7V.js +0 -29
  325. package/dist/NumCustomBinEditor.unit.spec-DNBDZSHT.js +0 -275
  326. package/dist/NumDiscreteEditor-TARWA6CZ.js +0 -145
  327. package/dist/NumDiscreteEditor.unit.spec-TCSLTQ25.js +0 -193
  328. package/dist/NumRegularBinEditor-QF5ALVV4.js +0 -29
  329. package/dist/NumRegularBinEditor.unit.spec-GFNDBWNM.js +0 -220
  330. package/dist/NumSplineEditor-MOEUXR34.js +0 -181
  331. package/dist/NumSplineEditor.unit.spec-XPJOOXS4.js +0 -190
  332. package/dist/NumericDensity-JDE263EQ.js +0 -29
  333. package/dist/NumericDensity.unit.spec-RX6UGV56.js +0 -212
  334. package/dist/NumericHandler-XM7LUYHN.js +0 -30
  335. package/dist/NumericHandler.unit.spec-5EYRMII7.js +0 -210
  336. package/dist/SC-Z4KBNK7P.js +0 -714
  337. package/dist/Volcano-WYJLKM4K.js +0 -1018
  338. package/dist/WSIViewer-3RMG3VOA.js +0 -46959
  339. package/dist/WsiSamplesPlot-PAWNKI7R.js +0 -153
  340. package/dist/adSandbox-7H5H46SE.js +0 -29
  341. package/dist/alphaGenome-PODWDV5T.js +0 -170
  342. package/dist/app-JPURIGQW.js +0 -28
  343. package/dist/app-YL7S55T5.js +0 -54
  344. package/dist/bam-XEO47VYA.js +0 -842
  345. package/dist/barchart-B5M6SSJH.js +0 -48
  346. package/dist/barchart.data-6A6WVV4Y.js +0 -30
  347. package/dist/barchart.events-2GNB5KWY.js +0 -44
  348. package/dist/barchart.integration.spec-JEOTKIWC.js +0 -1600
  349. package/dist/bars.renderer-NLUBMQEO.js +0 -12
  350. package/dist/bars.settings-UQZ63KU4.js +0 -8
  351. package/dist/block-B7WMYLPO.js +0 -6291
  352. package/dist/block.init-KCIXEYQC.js +0 -29
  353. package/dist/block.mds.expressionrank-RYZXAH5Y.js +0 -350
  354. package/dist/block.mds.geneboxplot-LNWUEI6N.js +0 -819
  355. package/dist/block.mds.junction-CVIY7QMD.js +0 -1536
  356. package/dist/block.mds.svcnv-EUGWHSCA.js +0 -6792
  357. package/dist/block.svg-QBLNIGUF.js +0 -155
  358. package/dist/block.tk.aicheck-U6NG22FX.js +0 -274
  359. package/dist/block.tk.ase-U3TRZAOH.js +0 -356
  360. package/dist/block.tk.bam-6Y6YFVR2.js +0 -1897
  361. package/dist/block.tk.bedgraphdot-O3VCFX6K.js +0 -375
  362. package/dist/block.tk.bigwig.ui-DNBJAF72.js +0 -202
  363. package/dist/block.tk.hicstraw-2EIFJX7E.js +0 -814
  364. package/dist/block.tk.junction-UXSO5EJP.js +0 -2355
  365. package/dist/block.tk.junction.textmatrixui-HQ6ZKCHM.js +0 -190
  366. package/dist/block.tk.ld-NEB4F3UG.js +0 -90
  367. package/dist/block.tk.menu-BN4JPJSD.js +0 -1020
  368. package/dist/block.tk.pgv-A4QFVSPF.js +0 -935
  369. package/dist/brainImaging-ESQGNGZH.js +0 -417
  370. package/dist/chat-AY7RCQYY.js +0 -145
  371. package/dist/chat-AY7RCQYY.js.map +0 -7
  372. package/dist/chunk-236ZRGXA.js +0 -297
  373. package/dist/chunk-2DZWOGEH.js +0 -272
  374. package/dist/chunk-2HQJMZNY.js +0 -14
  375. package/dist/chunk-2MRZFUHZ.js +0 -165
  376. package/dist/chunk-2ZEORJCF.js +0 -215
  377. package/dist/chunk-3WA7SJTR.js +0 -82
  378. package/dist/chunk-47HG7LGD.js +0 -133
  379. package/dist/chunk-47X254B7.js +0 -91
  380. package/dist/chunk-4TPDYPGD.js +0 -1098
  381. package/dist/chunk-4TPDYPGD.js.map +0 -7
  382. package/dist/chunk-4WA2H5DE.js +0 -75
  383. package/dist/chunk-4WA2H5DE.js.map +0 -7
  384. package/dist/chunk-4XDKCFFT.js +0 -613
  385. package/dist/chunk-5CJJLBUZ.js +0 -229
  386. package/dist/chunk-5TDKRZN5.js +0 -1931
  387. package/dist/chunk-5TDKRZN5.js.map +0 -7
  388. package/dist/chunk-6MSJ3TLQ.js +0 -1151
  389. package/dist/chunk-7JAFXNAL.js +0 -256
  390. package/dist/chunk-7JAFXNAL.js.map +0 -7
  391. package/dist/chunk-7LKSKJCV.js +0 -480
  392. package/dist/chunk-7P67W6NF.js +0 -190
  393. package/dist/chunk-7RIC35AF.js +0 -129
  394. package/dist/chunk-A76B53VT.js +0 -158
  395. package/dist/chunk-AZ276Z7T.js +0 -2327
  396. package/dist/chunk-B662XJMJ.js +0 -748
  397. package/dist/chunk-BK7GIOC5.js +0 -4924
  398. package/dist/chunk-BK7GIOC5.js.map +0 -7
  399. package/dist/chunk-BP2F2GRB.js +0 -2676
  400. package/dist/chunk-BRO4KZSZ.js +0 -417
  401. package/dist/chunk-BRO4KZSZ.js.map +0 -7
  402. package/dist/chunk-C5YNONHQ.js +0 -144
  403. package/dist/chunk-CT3LPTWW.js +0 -1197
  404. package/dist/chunk-CZTC4MTE.js +0 -161
  405. package/dist/chunk-DA5VGV5L.js +0 -280
  406. package/dist/chunk-DA5VGV5L.js.map +0 -7
  407. package/dist/chunk-DPU66MZ7.js +0 -381
  408. package/dist/chunk-E6NE5IWR.js +0 -102
  409. package/dist/chunk-ECKWM4HB.js +0 -1536
  410. package/dist/chunk-EEX5VPJG.js +0 -467
  411. package/dist/chunk-EIMEUZP2.js +0 -323
  412. package/dist/chunk-ETFPL4UP.js +0 -4172
  413. package/dist/chunk-F3FTQWTA.js +0 -303
  414. package/dist/chunk-F4APZ34G.js +0 -55
  415. package/dist/chunk-FOXJTDTH.js +0 -166
  416. package/dist/chunk-FYTZCTJC.js +0 -1157
  417. package/dist/chunk-FYTZCTJC.js.map +0 -7
  418. package/dist/chunk-GBS5I24E.js +0 -1706
  419. package/dist/chunk-GBS5I24E.js.map +0 -7
  420. package/dist/chunk-GBWRKJAH.js +0 -413
  421. package/dist/chunk-GG67VPVD.js +0 -238
  422. package/dist/chunk-GZ2B634M.js +0 -123
  423. package/dist/chunk-HEFXMCSF.js +0 -6364
  424. package/dist/chunk-I26R4NJJ.js +0 -228
  425. package/dist/chunk-I2GCD26Y.js +0 -55
  426. package/dist/chunk-I2GCD26Y.js.map +0 -7
  427. package/dist/chunk-ICNJQHQZ.js +0 -117
  428. package/dist/chunk-IPAGDFO4.js +0 -80
  429. package/dist/chunk-J2E4FALN.js +0 -1415
  430. package/dist/chunk-JXHU2FIA.js +0 -2789
  431. package/dist/chunk-K7LZ77GD.js +0 -468
  432. package/dist/chunk-K7LZ77GD.js.map +0 -7
  433. package/dist/chunk-KACWSU3U.js +0 -487
  434. package/dist/chunk-KACWSU3U.js.map +0 -7
  435. package/dist/chunk-KGSCQRQ5.js +0 -203
  436. package/dist/chunk-KGYPMYQD.js +0 -1143
  437. package/dist/chunk-L3PMRBTA.js +0 -422
  438. package/dist/chunk-M7QVMSRW.js +0 -293
  439. package/dist/chunk-MG6GRQKO.js +0 -459
  440. package/dist/chunk-N5VBIEH5.js +0 -1412
  441. package/dist/chunk-NRYOB7WU.js +0 -252
  442. package/dist/chunk-NXOWHUR4.js +0 -311
  443. package/dist/chunk-NXOWHUR4.js.map +0 -7
  444. package/dist/chunk-OFQV6PRB.js +0 -1275
  445. package/dist/chunk-OMO754MK.js +0 -177
  446. package/dist/chunk-OQSP66C6.js +0 -226
  447. package/dist/chunk-OS46MR72.js +0 -368
  448. package/dist/chunk-PBJFLQGL.js +0 -142
  449. package/dist/chunk-PMZS3SHH.js +0 -2877
  450. package/dist/chunk-PPJSDC3Z.js +0 -157
  451. package/dist/chunk-QIS45Z4Y.js +0 -2784
  452. package/dist/chunk-RCVZ4L7K.js +0 -402
  453. package/dist/chunk-ROWCKPNW.js +0 -1088
  454. package/dist/chunk-RQUXELHE.js +0 -276
  455. package/dist/chunk-RYRCMHYR.js +0 -196
  456. package/dist/chunk-S7EKSDVS.js +0 -258
  457. package/dist/chunk-SN5QKRXO.js +0 -85
  458. package/dist/chunk-TZRD3FPN.js +0 -634
  459. package/dist/chunk-U5QRRS7K.js +0 -619
  460. package/dist/chunk-UOMRXQNW.js +0 -401
  461. package/dist/chunk-UT6W4ZZL.js +0 -15048
  462. package/dist/chunk-UT6W4ZZL.js.map +0 -7
  463. package/dist/chunk-UZV3QI5M.js +0 -518
  464. package/dist/chunk-VALBVQXS.js +0 -217
  465. package/dist/chunk-VDR5JXI2.js +0 -444
  466. package/dist/chunk-VDR5JXI2.js.map +0 -7
  467. package/dist/chunk-W4D2EYE4.js +0 -95
  468. package/dist/chunk-XATIKUGU.js +0 -142
  469. package/dist/chunk-ZHWC5SJP.js +0 -797
  470. package/dist/chunk-ZHWC5SJP.js.map +0 -7
  471. package/dist/chunk-ZL4CNBYY.js +0 -149
  472. package/dist/chunk-ZQ7L66GP.js +0 -31
  473. package/dist/condition-24HPVH23.js +0 -323
  474. package/dist/controls-5CSAKANR.js +0 -35
  475. package/dist/controls.btns-QLLBCT65.js +0 -10
  476. package/dist/controls.config-H4FMU5LI.js +0 -31
  477. package/dist/correlation-RB77VSXB.js +0 -102
  478. package/dist/cuminc-YZSLH5IO.js +0 -1143
  479. package/dist/cuminc.integration.spec-MZPT3Y5A.js +0 -669
  480. package/dist/customdata.inputui-CBTZFODT.js +0 -278
  481. package/dist/dataDownload-ZTGRVI4Q.js +0 -320
  482. package/dist/dataDownload.integration.spec-Q6GUTUYD.js +0 -184
  483. package/dist/databrowser.ui-V7E6CLUZ.js +0 -426
  484. package/dist/dictionary-RPC5OZMM.js +0 -90
  485. package/dist/e2pca-WDQHMAUM.js +0 -341
  486. package/dist/ep-NAM34BBI.js +0 -1247
  487. package/dist/expclust.gdc.spec-QB4GVDJA.js +0 -298
  488. package/dist/facet-DOXBBIG6.js +0 -437
  489. package/dist/frequencyChart-GLOIGP3T.js +0 -371
  490. package/dist/frequencyChart.integration.spec-B7NBBLH2.js +0 -301
  491. package/dist/geneExpClustering-B4S6GFNT.js +0 -242
  492. package/dist/geneExpression-DMU4AQP6.js +0 -310
  493. package/dist/geneExpression-MVVXRNEY.js +0 -54
  494. package/dist/geneORA-XDAITCQF.js +0 -272
  495. package/dist/geneVariant-N6IGEIRR.js +0 -29
  496. package/dist/geneVariant-QYLA2V6J.js +0 -32
  497. package/dist/genefusion.ui-FRBMNK7V.js +0 -242
  498. package/dist/geneset-GZYNBG7Y.js +0 -186
  499. package/dist/genomeBrowser.spec-WFIVQSE7.js +0 -272
  500. package/dist/grin2-I6GJF35U.js +0 -882
  501. package/dist/grin2-I6GJF35U.js.map +0 -7
  502. package/dist/grin2-ZKNNZXON.js +0 -1547
  503. package/dist/gsea-GFGAEC4K.js +0 -43
  504. package/dist/hierCluster-MF4TI3E4.js +0 -60
  505. package/dist/hierCluster-SDJMQLOQ.js +0 -56
  506. package/dist/hierCluster.config-RMEX3VTC.js +0 -32
  507. package/dist/hierCluster.integration.spec-3H63OHMU.js +0 -389
  508. package/dist/hierCluster.interactivity-4DZBRQ6P.js +0 -45
  509. package/dist/hierCluster.renderers-UOW7BI6N.js +0 -21
  510. package/dist/imagePlot-P2UHJRSL.js +0 -134
  511. package/dist/importPlot-PPCMNVOW.js +0 -8
  512. package/dist/launch.adhoc-RJWUEVRA.js +0 -36
  513. package/dist/leftlabel.sample-OYP6MICL.js +0 -249
  514. package/dist/lollipop-BXQOWLGO.js +0 -159
  515. package/dist/maf-YJJO773K.js +0 -448
  516. package/dist/maf-YJJO773K.js.map +0 -7
  517. package/dist/maftimeline-GHKDDWYR.js +0 -584
  518. package/dist/matrix-FWDLHZYR.js +0 -60
  519. package/dist/matrix-YMJFP53F.js +0 -55
  520. package/dist/matrix.cells-JH7FPY3E.js +0 -30
  521. package/dist/matrix.config-HIHOLDCE.js +0 -33
  522. package/dist/matrix.controls-EKZ543FY.js +0 -31
  523. package/dist/matrix.data-NKAZI2BF.js +0 -35
  524. package/dist/matrix.dom-RGZ52GJ2.js +0 -11
  525. package/dist/matrix.groups-BO53ZXXV.js +0 -26
  526. package/dist/matrix.integration.spec-BXTATNAC.js +0 -2936
  527. package/dist/matrix.interactivity-UGUMKCFN.js +0 -36
  528. package/dist/matrix.layout-WBIF5QTG.js +0 -35
  529. package/dist/matrix.legend-P3GFCXXK.js +0 -22
  530. package/dist/matrix.renderers-I54IHQ3S.js +0 -29
  531. package/dist/matrix.serieses-R2T57OYI.js +0 -21
  532. package/dist/matrix.sort-3GCA2GDU.js +0 -27
  533. package/dist/matrix.sort.unit.spec-AXGPCZZD.js +0 -464
  534. package/dist/matrix.sorterUi-QWRK6OGE.js +0 -18
  535. package/dist/matrix.sorterUi.unit.spec-H7GUVWRJ.js +0 -335
  536. package/dist/mavb-4EECWXYX.js +0 -723
  537. package/dist/mds.fimo-NHZOY43X.js +0 -509
  538. package/dist/mds.samplescatterplot-7A5IZ6W7.js +0 -1541
  539. package/dist/mds.survivalplot-SQDPUFQE.js +0 -474
  540. package/dist/mutationSignature-QH7PZYKL.js +0 -72
  541. package/dist/numericDictTermCluster-X5SGSC5K.js +0 -72
  542. package/dist/oncomatrix-M4C4XPQK.js +0 -287
  543. package/dist/oncomatrix.spec-3C642O7O.js +0 -439
  544. package/dist/plot.2dvaf-TILP7J53.js +0 -368
  545. package/dist/plot.app-DE2UQP2M.js +0 -35
  546. package/dist/plot.barplot-FJHS765K.js +0 -93
  547. package/dist/plot.boxplot-YRSHGNYZ.js +0 -143
  548. package/dist/plot.brainImaging-JV4OUVJY.js +0 -51
  549. package/dist/plot.disco-DBVPBMLG.js +0 -100
  550. package/dist/plot.dzi-O2OA4EBK.js +0 -33
  551. package/dist/plot.ssgq-YFQEZQYK.js +0 -130
  552. package/dist/plot.vaf2cov-YNFP5LJ4.js +0 -250
  553. package/dist/plot.wsi-DJB7TDIS.js +0 -36
  554. package/dist/polar-K5Z5FYKV.js +0 -179
  555. package/dist/profile.spec-A6EADWEC.js +0 -71
  556. package/dist/profileBarchart-EFLPJK2P.js +0 -260
  557. package/dist/profileForms-TG35YNLD.js +0 -365
  558. package/dist/profilePlot-2EW2XVTK.js +0 -50
  559. package/dist/profileRadar-AKUYC2O5.js +0 -256
  560. package/dist/profileRadarFacility-EAT66XTX.js +0 -256
  561. package/dist/qualitative-PHQU5DXE.js +0 -34
  562. package/dist/regression-EOMJRRDO.js +0 -57
  563. package/dist/regression.inputs-LIH5X2JM.js +0 -49
  564. package/dist/regression.inputs.term-OO4RZ3QB.js +0 -49
  565. package/dist/regression.inputs.values.table-E7WCTO2L.js +0 -46
  566. package/dist/regression.integration.spec-62VEQP6X.js +0 -777
  567. package/dist/regression.results-WAHFJ6NA.js +0 -31
  568. package/dist/regression.spec-IBIOTZVX.js +0 -699
  569. package/dist/report-MKDJXHGY.js +0 -220
  570. package/dist/runChart-ETM2EETF.js +0 -54
  571. package/dist/runchart.integration.spec-QFA4XBKB.js +0 -362
  572. package/dist/sampleScatter.spec-N4N7ZGZF.js +0 -193
  573. package/dist/sampleView-JTY3RV7I.js +0 -42
  574. package/dist/samplelst-RRUMBVT6.js +0 -102
  575. package/dist/samplematrix-L37O664Y.js +0 -2189
  576. package/dist/scatter-E5QHW32W.js +0 -55
  577. package/dist/scatter.integration.spec-FNVAJSVU.js +0 -1026
  578. package/dist/selectGenomeWithTklst-J6VXCYGG.js +0 -125
  579. package/dist/singleCellPlot-S6S6CKYX.js +0 -50
  580. package/dist/singlecell-4BMIKFY4.js +0 -80
  581. package/dist/singlecell-B4TNI23F.js +0 -1563
  582. package/dist/snp-PAUQ24NZ.js +0 -73
  583. package/dist/snplocus-HVFYZTEE.js +0 -199
  584. package/dist/spliceevent.a53ss.diagram-GGGHVNBF.js +0 -142
  585. package/dist/spliceevent.exonskip.diagram-HLMFD6LJ.js +0 -268
  586. package/dist/spliceevent.noeventdiagram-CKZ3BZ7Y.js +0 -451
  587. package/dist/ssGSEA-UGT4GH55.js +0 -53
  588. package/dist/stattable-6JWMALGB.js +0 -89
  589. package/dist/summarizeCnvGeneexp-BJOQY62E.js +0 -136
  590. package/dist/summarizeGeneexpSurvival-4HDHL7PE.js +0 -90
  591. package/dist/summarizeMutationDiagnosis-TDWO5CKU.js +0 -32
  592. package/dist/summarizeMutationSurvival-CJJFABOX.js +0 -92
  593. package/dist/summary-WOAXXIHG.js +0 -55
  594. package/dist/summary.integration.spec-GM73ERMN.js +0 -405
  595. package/dist/summaryInput-FD4SONTY.js +0 -170
  596. package/dist/sunburst-3LCJTBRN.js +0 -275
  597. package/dist/survival-A3A7IVXT.js +0 -41
  598. package/dist/survival-XF72VMM6.js +0 -49
  599. package/dist/survival.integration.spec-AU7MCAQV.js +0 -601
  600. package/dist/svgraph-BEMS4JDJ.js +0 -1378
  601. package/dist/svmr-CDEMTZPK.js +0 -3833
  602. package/dist/table-WYF6QCGB.js +0 -193
  603. package/dist/termCollection-BVQMNVY7.js +0 -80
  604. package/dist/termInfo-JXLIVCSO.js +0 -9
  605. package/dist/tk-TGIIJYBO.js +0 -37
  606. package/dist/tp.ui-USYF67P7.js +0 -1450
  607. package/dist/tvs.dtcnv.continuous-7SCTSFK3.js +0 -65
  608. package/dist/tvs.numeric-OLVW6US3.js +0 -355
  609. package/dist/tvs.samplelst-BHZHCX5V.js +0 -95
  610. package/dist/violin-OEOWVIZF.js +0 -47
  611. package/dist/violin.integration.spec-AW2U3RHO.js +0 -1425
  612. package/dist/violin.interactivity-3O2UDNPQ.js +0 -39
  613. package/dist/violin.renderer-W26FA6M7.js +0 -31
  614. package/dist/vocabulary-BIQYDKVY.js +0 -32
  615. /package/dist/{2dmaf-E4NOGWWO.js.map → 2dmaf-6M6QWXAQ.js.map} +0 -0
  616. /package/dist/{AIProjectAdmin-3QDXMCOK.js.map → AIProjectAdmin-2NHMC3IV.js.map} +0 -0
  617. /package/dist/{AppHeader-IFZ57DJE.js.map → AppHeader-CTHEWSZD.js.map} +0 -0
  618. /package/dist/{BoxPlot-GXDTPRA5.js.map → BoxPlot-3U6ZAKKO.js.map} +0 -0
  619. /package/dist/{CorrelationVolcano-S4GUYIPT.js.map → CorrelationVolcano-2ASIR6KY.js.map} +0 -0
  620. /package/dist/{DifferentialAnalysis-YLKYWPUT.js.map → DifferentialAnalysis-C3NYGF7U.js.map} +0 -0
  621. /package/dist/{Disco-OQMP3HRQ.js.map → Disco-2QLBZ3X5.js.map} +0 -0
  622. /package/dist/{Disco.UI-XB3XQP33.js.map → Disco.UI-GPIIPM2P.js.map} +0 -0
  623. /package/dist/{DziViewer-UIRNTFNS.js.map → DziViewer-OHPZOH72.js.map} +0 -0
  624. /package/dist/{GB-KDPJTOLP.js.map → GB-FH6YQGHI.js.map} +0 -0
  625. /package/dist/{HicApp-XJERMLKH.js.map → HicApp-TI2II3SZ.js.map} +0 -0
  626. /package/dist/{NumBinaryEditor-5MWWWNLW.js.map → NumBinaryEditor-O42T63EX.js.map} +0 -0
  627. /package/dist/{NumBinaryEditor.unit.spec-ROGT5FOH.js.map → NumBinaryEditor.unit.spec-UMB2PHT5.js.map} +0 -0
  628. /package/dist/{NumContEditor-RRCB4CKG.js.map → NumContEditor-7NOUKPCV.js.map} +0 -0
  629. /package/dist/{NumContEditor.unit.spec-AJTKOF7W.js.map → NumContEditor.unit.spec-JGXJ2HLE.js.map} +0 -0
  630. /package/dist/{NumCustomBinEditor-3GJITZ7V.js.map → NumCustomBinEditor-6CHN3KX3.js.map} +0 -0
  631. /package/dist/{NumCustomBinEditor.unit.spec-DNBDZSHT.js.map → NumCustomBinEditor.unit.spec-RJPQLE3E.js.map} +0 -0
  632. /package/dist/{NumDiscreteEditor-TARWA6CZ.js.map → NumDiscreteEditor-AFTUKU4K.js.map} +0 -0
  633. /package/dist/{NumDiscreteEditor.unit.spec-TCSLTQ25.js.map → NumDiscreteEditor.unit.spec-GKR6ZNBQ.js.map} +0 -0
  634. /package/dist/{NumRegularBinEditor-QF5ALVV4.js.map → NumRegularBinEditor-UJ5WQPHR.js.map} +0 -0
  635. /package/dist/{NumRegularBinEditor.unit.spec-GFNDBWNM.js.map → NumRegularBinEditor.unit.spec-5HGJQEX7.js.map} +0 -0
  636. /package/dist/{NumSplineEditor-MOEUXR34.js.map → NumSplineEditor-JANA2DUE.js.map} +0 -0
  637. /package/dist/{NumSplineEditor.unit.spec-XPJOOXS4.js.map → NumSplineEditor.unit.spec-UYAMAKZD.js.map} +0 -0
  638. /package/dist/{NumericDensity-JDE263EQ.js.map → NumericDensity-YE5R4CNP.js.map} +0 -0
  639. /package/dist/{NumericDensity.unit.spec-RX6UGV56.js.map → NumericDensity.unit.spec-SVEB5U2S.js.map} +0 -0
  640. /package/dist/{NumericHandler-XM7LUYHN.js.map → NumericHandler-WW4M7YW2.js.map} +0 -0
  641. /package/dist/{NumericHandler.unit.spec-5EYRMII7.js.map → NumericHandler.unit.spec-2BWDFO53.js.map} +0 -0
  642. /package/dist/{SC-Z4KBNK7P.js.map → SC-UGJGMBL7.js.map} +0 -0
  643. /package/dist/{Volcano-WYJLKM4K.js.map → Volcano-IU76MEIL.js.map} +0 -0
  644. /package/dist/{WSIViewer-3RMG3VOA.js.map → WSIViewer-3S7N4UDO.js.map} +0 -0
  645. /package/dist/{WsiSamplesPlot-PAWNKI7R.js.map → WsiSamplesPlot-4CAOHWCL.js.map} +0 -0
  646. /package/dist/{adSandbox-7H5H46SE.js.map → adSandbox-AEBS3RTL.js.map} +0 -0
  647. /package/dist/{alphaGenome-PODWDV5T.js.map → alphaGenome-F2PB4SGI.js.map} +0 -0
  648. /package/dist/{app-JPURIGQW.js.map → app-6SKETLMT.js.map} +0 -0
  649. /package/dist/{app-YL7S55T5.js.map → app-GBEF2HBR.js.map} +0 -0
  650. /package/dist/{bam-XEO47VYA.js.map → bam-5SE6XQJV.js.map} +0 -0
  651. /package/dist/{barchart-B5M6SSJH.js.map → barchart-AUSOT2XB.js.map} +0 -0
  652. /package/dist/{barchart.data-6A6WVV4Y.js.map → barchart.data-GYCNBRPY.js.map} +0 -0
  653. /package/dist/{barchart.events-2GNB5KWY.js.map → barchart.events-QTSWNYXO.js.map} +0 -0
  654. /package/dist/{barchart.integration.spec-JEOTKIWC.js.map → barchart.integration.spec-LORJLJVX.js.map} +0 -0
  655. /package/dist/{bars.renderer-NLUBMQEO.js.map → bars.renderer-4N4QOUNI.js.map} +0 -0
  656. /package/dist/{bars.settings-UQZ63KU4.js.map → bars.settings-SDU7PZOS.js.map} +0 -0
  657. /package/dist/{block-B7WMYLPO.js.map → block-QLSIELXK.js.map} +0 -0
  658. /package/dist/{block.init-KCIXEYQC.js.map → block.init-OOLEA6ZK.js.map} +0 -0
  659. /package/dist/{block.mds.expressionrank-RYZXAH5Y.js.map → block.mds.expressionrank-D2KUISXZ.js.map} +0 -0
  660. /package/dist/{block.mds.geneboxplot-LNWUEI6N.js.map → block.mds.geneboxplot-AMYBWXPS.js.map} +0 -0
  661. /package/dist/{block.mds.junction-CVIY7QMD.js.map → block.mds.junction-OG335MBK.js.map} +0 -0
  662. /package/dist/{block.mds.svcnv-EUGWHSCA.js.map → block.mds.svcnv-WYDBQ6FV.js.map} +0 -0
  663. /package/dist/{block.svg-QBLNIGUF.js.map → block.svg-OH73245R.js.map} +0 -0
  664. /package/dist/{block.tk.aicheck-U6NG22FX.js.map → block.tk.aicheck-CG5THFW2.js.map} +0 -0
  665. /package/dist/{block.tk.ase-U3TRZAOH.js.map → block.tk.ase-G2L3G5MQ.js.map} +0 -0
  666. /package/dist/{block.tk.bam-6Y6YFVR2.js.map → block.tk.bam-DXWCA6EU.js.map} +0 -0
  667. /package/dist/{block.tk.bedgraphdot-O3VCFX6K.js.map → block.tk.bedgraphdot-LF3TFPNL.js.map} +0 -0
  668. /package/dist/{block.tk.bigwig.ui-DNBJAF72.js.map → block.tk.bigwig.ui-JKXZ3VDF.js.map} +0 -0
  669. /package/dist/{block.tk.hicstraw-2EIFJX7E.js.map → block.tk.hicstraw-ZK4RKFB6.js.map} +0 -0
  670. /package/dist/{block.tk.junction-UXSO5EJP.js.map → block.tk.junction-ZB7Q2NLB.js.map} +0 -0
  671. /package/dist/{block.tk.junction.textmatrixui-HQ6ZKCHM.js.map → block.tk.junction.textmatrixui-ZYNQWKIW.js.map} +0 -0
  672. /package/dist/{block.tk.ld-NEB4F3UG.js.map → block.tk.ld-7H64HGER.js.map} +0 -0
  673. /package/dist/{block.tk.menu-BN4JPJSD.js.map → block.tk.menu-WFVKAH74.js.map} +0 -0
  674. /package/dist/{block.tk.pgv-A4QFVSPF.js.map → block.tk.pgv-632LLSBI.js.map} +0 -0
  675. /package/dist/{brainImaging-ESQGNGZH.js.map → brainImaging-AEPTHIQF.js.map} +0 -0
  676. /package/dist/{chunk-U5QRRS7K.js.map → chunk-22O6F463.js.map} +0 -0
  677. /package/dist/{chunk-NRYOB7WU.js.map → chunk-2HJ7OD7H.js.map} +0 -0
  678. /package/dist/{chunk-PMZS3SHH.js.map → chunk-2MN5JLZB.js.map} +0 -0
  679. /package/dist/{chunk-7LKSKJCV.js.map → chunk-37CK5IGW.js.map} +0 -0
  680. /package/dist/{chunk-IPAGDFO4.js.map → chunk-3JFEWVHR.js.map} +0 -0
  681. /package/dist/{chunk-47HG7LGD.js.map → chunk-3MGBC64I.js.map} +0 -0
  682. /package/dist/{chunk-HEFXMCSF.js.map → chunk-3NWLWH4G.js.map} +0 -0
  683. /package/dist/{chunk-XATIKUGU.js.map → chunk-4GKQ5PWY.js.map} +0 -0
  684. /package/dist/{chunk-OQSP66C6.js.map → chunk-4PHD5H4A.js.map} +0 -0
  685. /package/dist/{chunk-GBWRKJAH.js.map → chunk-56IFQMJK.js.map} +0 -0
  686. /package/dist/{chunk-A76B53VT.js.map → chunk-5DMFTXUZ.js.map} +0 -0
  687. /package/dist/{chunk-W4D2EYE4.js.map → chunk-5QJDZHRU.js.map} +0 -0
  688. /package/dist/{chunk-OFQV6PRB.js.map → chunk-5WAVKWL6.js.map} +0 -0
  689. /package/dist/{chunk-C5YNONHQ.js.map → chunk-6ISTNHM6.js.map} +0 -0
  690. /package/dist/{chunk-ECKWM4HB.js.map → chunk-6VQ4C735.js.map} +0 -0
  691. /package/dist/{chunk-5CJJLBUZ.js.map → chunk-74WMSW3E.js.map} +0 -0
  692. /package/dist/{chunk-MG6GRQKO.js.map → chunk-AFU66YOW.js.map} +0 -0
  693. /package/dist/{chunk-2HQJMZNY.js.map → chunk-AUJ2YUXV.js.map} +0 -0
  694. /package/dist/{chunk-UZV3QI5M.js.map → chunk-B65X5UQH.js.map} +0 -0
  695. /package/dist/{chunk-TZRD3FPN.js.map → chunk-B6I64LSV.js.map} +0 -0
  696. /package/dist/{chunk-SN5QKRXO.js.map → chunk-BTYCW3D5.js.map} +0 -0
  697. /package/dist/{chunk-J2E4FALN.js.map → chunk-CCB5KYFQ.js.map} +0 -0
  698. /package/dist/{chunk-EEX5VPJG.js.map → chunk-CKLYFA7H.js.map} +0 -0
  699. /package/dist/{chunk-2DZWOGEH.js.map → chunk-CLYRJ466.js.map} +0 -0
  700. /package/dist/{chunk-3WA7SJTR.js.map → chunk-CPHCZZWT.js.map} +0 -0
  701. /package/dist/{chunk-VALBVQXS.js.map → chunk-CUADOD2T.js.map} +0 -0
  702. /package/dist/{chunk-L3PMRBTA.js.map → chunk-CV6ID6T7.js.map} +0 -0
  703. /package/dist/{chunk-7P67W6NF.js.map → chunk-CWHBWY3B.js.map} +0 -0
  704. /package/dist/{chunk-GG67VPVD.js.map → chunk-D53HBTYQ.js.map} +0 -0
  705. /package/dist/{chunk-RYRCMHYR.js.map → chunk-DKI7YOTJ.js.map} +0 -0
  706. /package/dist/{chunk-2MRZFUHZ.js.map → chunk-DNU4IPD2.js.map} +0 -0
  707. /package/dist/{chunk-AZ276Z7T.js.map → chunk-H6HP4H3U.js.map} +0 -0
  708. /package/dist/{chunk-GZ2B634M.js.map → chunk-HPEMEDXB.js.map} +0 -0
  709. /package/dist/{chunk-6MSJ3TLQ.js.map → chunk-HUDESZGX.js.map} +0 -0
  710. /package/dist/{chunk-FOXJTDTH.js.map → chunk-J7IU77CA.js.map} +0 -0
  711. /package/dist/{chunk-DPU66MZ7.js.map → chunk-JMO7ENSD.js.map} +0 -0
  712. /package/dist/{chunk-7RIC35AF.js.map → chunk-JTPN3BRG.js.map} +0 -0
  713. /package/dist/{chunk-EIMEUZP2.js.map → chunk-KCAMFDJH.js.map} +0 -0
  714. /package/dist/{chunk-OMO754MK.js.map → chunk-LD45BCVM.js.map} +0 -0
  715. /package/dist/{chunk-N5VBIEH5.js.map → chunk-LMELY5Z2.js.map} +0 -0
  716. /package/dist/{chunk-2ZEORJCF.js.map → chunk-LVQK62CV.js.map} +0 -0
  717. /package/dist/{chunk-PPJSDC3Z.js.map → chunk-MCVLRF66.js.map} +0 -0
  718. /package/dist/{chunk-4XDKCFFT.js.map → chunk-MLD7DW5I.js.map} +0 -0
  719. /package/dist/{chunk-JXHU2FIA.js.map → chunk-NEF7LGNE.js.map} +0 -0
  720. /package/dist/{chunk-UOMRXQNW.js.map → chunk-OARG7PAV.js.map} +0 -0
  721. /package/dist/{chunk-B662XJMJ.js.map → chunk-OGWY4MOB.js.map} +0 -0
  722. /package/dist/{chunk-QIS45Z4Y.js.map → chunk-PQD6K5W5.js.map} +0 -0
  723. /package/dist/{chunk-47X254B7.js.map → chunk-Q4FYGFTQ.js.map} +0 -0
  724. /package/dist/{chunk-F3FTQWTA.js.map → chunk-RA2KI64U.js.map} +0 -0
  725. /package/dist/{chunk-ROWCKPNW.js.map → chunk-RHHLAKYS.js.map} +0 -0
  726. /package/dist/{chunk-S7EKSDVS.js.map → chunk-RKV3CP4C.js.map} +0 -0
  727. /package/dist/{chunk-OS46MR72.js.map → chunk-RL7RU2V7.js.map} +0 -0
  728. /package/dist/{chunk-CZTC4MTE.js.map → chunk-RQ7CE7SK.js.map} +0 -0
  729. /package/dist/{chunk-KGYPMYQD.js.map → chunk-RX552WU6.js.map} +0 -0
  730. /package/dist/{chunk-RQUXELHE.js.map → chunk-S7V4SFKB.js.map} +0 -0
  731. /package/dist/{chunk-PBJFLQGL.js.map → chunk-SEL5UNRC.js.map} +0 -0
  732. /package/dist/{chunk-236ZRGXA.js.map → chunk-SRBO57AD.js.map} +0 -0
  733. /package/dist/{chunk-CT3LPTWW.js.map → chunk-SYGLOTOV.js.map} +0 -0
  734. /package/dist/{chunk-KGSCQRQ5.js.map → chunk-UZ466XO3.js.map} +0 -0
  735. /package/dist/{chunk-ZL4CNBYY.js.map → chunk-VDF5W47R.js.map} +0 -0
  736. /package/dist/{chunk-ZQ7L66GP.js.map → chunk-WTPVXDJT.js.map} +0 -0
  737. /package/dist/{chunk-I26R4NJJ.js.map → chunk-XRIM2YJZ.js.map} +0 -0
  738. /package/dist/{chunk-F4APZ34G.js.map → chunk-YSWMQO23.js.map} +0 -0
  739. /package/dist/{chunk-RCVZ4L7K.js.map → chunk-ZBZXIWSK.js.map} +0 -0
  740. /package/dist/{chunk-ICNJQHQZ.js.map → chunk-ZFFHOEBE.js.map} +0 -0
  741. /package/dist/{chunk-E6NE5IWR.js.map → chunk-ZG63ZUDE.js.map} +0 -0
  742. /package/dist/{chunk-BP2F2GRB.js.map → chunk-ZGQ3BMLW.js.map} +0 -0
  743. /package/dist/{chunk-M7QVMSRW.js.map → chunk-ZNINQ3FN.js.map} +0 -0
  744. /package/dist/{chunk-ETFPL4UP.js.map → chunk-ZQZWM544.js.map} +0 -0
  745. /package/dist/{condition-24HPVH23.js.map → condition-4FVKPSQ2.js.map} +0 -0
  746. /package/dist/{controls-5CSAKANR.js.map → controls-ZWBN566I.js.map} +0 -0
  747. /package/dist/{controls.btns-QLLBCT65.js.map → controls.btns-H4TWTHTW.js.map} +0 -0
  748. /package/dist/{controls.config-H4FMU5LI.js.map → controls.config-YU4W3CDL.js.map} +0 -0
  749. /package/dist/{correlation-RB77VSXB.js.map → correlation-VADB4SQO.js.map} +0 -0
  750. /package/dist/{cuminc-YZSLH5IO.js.map → cuminc-4BXE2YS6.js.map} +0 -0
  751. /package/dist/{cuminc.integration.spec-MZPT3Y5A.js.map → cuminc.integration.spec-XQREKHVA.js.map} +0 -0
  752. /package/dist/{customdata.inputui-CBTZFODT.js.map → customdata.inputui-VBQWT3M7.js.map} +0 -0
  753. /package/dist/{dataDownload-ZTGRVI4Q.js.map → dataDownload-QIZKBKH7.js.map} +0 -0
  754. /package/dist/{dataDownload.integration.spec-Q6GUTUYD.js.map → dataDownload.integration.spec-MLJEHLYD.js.map} +0 -0
  755. /package/dist/{databrowser.ui-V7E6CLUZ.js.map → databrowser.ui-6UIR4ULJ.js.map} +0 -0
  756. /package/dist/{dictionary-RPC5OZMM.js.map → dictionary-FLWIWAC6.js.map} +0 -0
  757. /package/dist/{e2pca-WDQHMAUM.js.map → e2pca-NKWSJRXM.js.map} +0 -0
  758. /package/dist/{ep-NAM34BBI.js.map → ep-EPN3AR6D.js.map} +0 -0
  759. /package/dist/{expclust.gdc.spec-QB4GVDJA.js.map → expclust.gdc.spec-ZRUH5E6E.js.map} +0 -0
  760. /package/dist/{facet-DOXBBIG6.js.map → facet-BM7SLACF.js.map} +0 -0
  761. /package/dist/{frequencyChart-GLOIGP3T.js.map → frequencyChart-HBXRIBAW.js.map} +0 -0
  762. /package/dist/{frequencyChart.integration.spec-B7NBBLH2.js.map → frequencyChart.integration.spec-YJUYZWM6.js.map} +0 -0
  763. /package/dist/{geneExpClustering-B4S6GFNT.js.map → geneExpClustering-4VD5PAWN.js.map} +0 -0
  764. /package/dist/{geneExpression-MVVXRNEY.js.map → geneExpression-6OT2Y4P6.js.map} +0 -0
  765. /package/dist/{geneExpression-DMU4AQP6.js.map → geneExpression-EAMEZXJQ.js.map} +0 -0
  766. /package/dist/{geneORA-XDAITCQF.js.map → geneORA-RI2AG7JT.js.map} +0 -0
  767. /package/dist/{geneVariant-N6IGEIRR.js.map → geneVariant-FYYEOTWA.js.map} +0 -0
  768. /package/dist/{geneVariant-QYLA2V6J.js.map → geneVariant-PAKVDVC4.js.map} +0 -0
  769. /package/dist/{genefusion.ui-FRBMNK7V.js.map → genefusion.ui-QWC42XWQ.js.map} +0 -0
  770. /package/dist/{geneset-GZYNBG7Y.js.map → geneset-XA6IWP3Q.js.map} +0 -0
  771. /package/dist/{genomeBrowser.spec-WFIVQSE7.js.map → genomeBrowser.spec-LRKXWXNT.js.map} +0 -0
  772. /package/dist/{grin2-ZKNNZXON.js.map → grin2-WLB7BY3S.js.map} +0 -0
  773. /package/dist/{gsea-GFGAEC4K.js.map → gsea-ZM4WOPSQ.js.map} +0 -0
  774. /package/dist/{hierCluster-MF4TI3E4.js.map → hierCluster-LD43LLRC.js.map} +0 -0
  775. /package/dist/{hierCluster-SDJMQLOQ.js.map → hierCluster-ZGYRS2WV.js.map} +0 -0
  776. /package/dist/{hierCluster.config-RMEX3VTC.js.map → hierCluster.config-O5HUOFNH.js.map} +0 -0
  777. /package/dist/{hierCluster.integration.spec-3H63OHMU.js.map → hierCluster.integration.spec-37UNKHTH.js.map} +0 -0
  778. /package/dist/{hierCluster.interactivity-4DZBRQ6P.js.map → hierCluster.interactivity-B27ETKRP.js.map} +0 -0
  779. /package/dist/{hierCluster.renderers-UOW7BI6N.js.map → hierCluster.renderers-GWFH5ZX7.js.map} +0 -0
  780. /package/dist/{imagePlot-P2UHJRSL.js.map → imagePlot-LJZVGNDJ.js.map} +0 -0
  781. /package/dist/{importPlot-PPCMNVOW.js.map → importPlot-RMVENQRD.js.map} +0 -0
  782. /package/dist/{launch.adhoc-RJWUEVRA.js.map → launch.adhoc-S3XHRSLN.js.map} +0 -0
  783. /package/dist/{leftlabel.sample-OYP6MICL.js.map → leftlabel.sample-J6PCA3UB.js.map} +0 -0
  784. /package/dist/{lollipop-BXQOWLGO.js.map → lollipop-OZTV4C7A.js.map} +0 -0
  785. /package/dist/{maftimeline-GHKDDWYR.js.map → maftimeline-6F2LQJU6.js.map} +0 -0
  786. /package/dist/{matrix-FWDLHZYR.js.map → matrix-FIXOFAB4.js.map} +0 -0
  787. /package/dist/{matrix-YMJFP53F.js.map → matrix-O5KPDLM2.js.map} +0 -0
  788. /package/dist/{matrix.cells-JH7FPY3E.js.map → matrix.cells-SCLZA3P4.js.map} +0 -0
  789. /package/dist/{matrix.config-HIHOLDCE.js.map → matrix.config-WG7HFJL4.js.map} +0 -0
  790. /package/dist/{matrix.controls-EKZ543FY.js.map → matrix.controls-QQLBUUYP.js.map} +0 -0
  791. /package/dist/{matrix.data-NKAZI2BF.js.map → matrix.data-6JLF5HVI.js.map} +0 -0
  792. /package/dist/{matrix.dom-RGZ52GJ2.js.map → matrix.dom-QO7BXZ27.js.map} +0 -0
  793. /package/dist/{matrix.groups-BO53ZXXV.js.map → matrix.groups-QMZMZ6Q7.js.map} +0 -0
  794. /package/dist/{matrix.integration.spec-BXTATNAC.js.map → matrix.integration.spec-ZJYWNQ57.js.map} +0 -0
  795. /package/dist/{matrix.interactivity-UGUMKCFN.js.map → matrix.interactivity-ZZY5ET4E.js.map} +0 -0
  796. /package/dist/{matrix.layout-WBIF5QTG.js.map → matrix.layout-XKFB4PKY.js.map} +0 -0
  797. /package/dist/{matrix.legend-P3GFCXXK.js.map → matrix.legend-CS6DNC5V.js.map} +0 -0
  798. /package/dist/{matrix.renderers-I54IHQ3S.js.map → matrix.renderers-4LST6PBA.js.map} +0 -0
  799. /package/dist/{matrix.serieses-R2T57OYI.js.map → matrix.serieses-3SERD6CV.js.map} +0 -0
  800. /package/dist/{matrix.sort-3GCA2GDU.js.map → matrix.sort-UVS6WHIS.js.map} +0 -0
  801. /package/dist/{matrix.sort.unit.spec-AXGPCZZD.js.map → matrix.sort.unit.spec-CTSUNUWB.js.map} +0 -0
  802. /package/dist/{matrix.sorterUi-QWRK6OGE.js.map → matrix.sorterUi-JDGLTLJM.js.map} +0 -0
  803. /package/dist/{matrix.sorterUi.unit.spec-H7GUVWRJ.js.map → matrix.sorterUi.unit.spec-VQFMHIYI.js.map} +0 -0
  804. /package/dist/{mavb-4EECWXYX.js.map → mavb-ECQ2CQ7F.js.map} +0 -0
  805. /package/dist/{mds.fimo-NHZOY43X.js.map → mds.fimo-JDYDT5NK.js.map} +0 -0
  806. /package/dist/{mds.samplescatterplot-7A5IZ6W7.js.map → mds.samplescatterplot-PEJBVSTO.js.map} +0 -0
  807. /package/dist/{mds.survivalplot-SQDPUFQE.js.map → mds.survivalplot-GYK6VRQT.js.map} +0 -0
  808. /package/dist/{mutationSignature-QH7PZYKL.js.map → mutationSignature-43SECPTY.js.map} +0 -0
  809. /package/dist/{numericDictTermCluster-X5SGSC5K.js.map → numericDictTermCluster-2ER4FUKO.js.map} +0 -0
  810. /package/dist/{oncomatrix-M4C4XPQK.js.map → oncomatrix-ZXDJMLN3.js.map} +0 -0
  811. /package/dist/{oncomatrix.spec-3C642O7O.js.map → oncomatrix.spec-HOPRIG3I.js.map} +0 -0
  812. /package/dist/{plot.2dvaf-TILP7J53.js.map → plot.2dvaf-Y4SZUHLD.js.map} +0 -0
  813. /package/dist/{plot.app-DE2UQP2M.js.map → plot.app-W5Z3C7P5.js.map} +0 -0
  814. /package/dist/{plot.barplot-FJHS765K.js.map → plot.barplot-B2PRZDKV.js.map} +0 -0
  815. /package/dist/{plot.boxplot-YRSHGNYZ.js.map → plot.boxplot-J7ET34FY.js.map} +0 -0
  816. /package/dist/{plot.brainImaging-JV4OUVJY.js.map → plot.brainImaging-ISY4P6RT.js.map} +0 -0
  817. /package/dist/{plot.disco-DBVPBMLG.js.map → plot.disco-D7AL42PW.js.map} +0 -0
  818. /package/dist/{plot.dzi-O2OA4EBK.js.map → plot.dzi-O32LH65U.js.map} +0 -0
  819. /package/dist/{plot.ssgq-YFQEZQYK.js.map → plot.ssgq-WF7262IZ.js.map} +0 -0
  820. /package/dist/{plot.vaf2cov-YNFP5LJ4.js.map → plot.vaf2cov-OB6UKSFQ.js.map} +0 -0
  821. /package/dist/{plot.wsi-DJB7TDIS.js.map → plot.wsi-J5S4YYXN.js.map} +0 -0
  822. /package/dist/{polar-K5Z5FYKV.js.map → polar-LIJORXR6.js.map} +0 -0
  823. /package/dist/{profile.spec-A6EADWEC.js.map → profile.spec-3KE4CREI.js.map} +0 -0
  824. /package/dist/{profileBarchart-EFLPJK2P.js.map → profileBarchart-UQHOJB5V.js.map} +0 -0
  825. /package/dist/{profileForms-TG35YNLD.js.map → profileForms-WTYVTIUN.js.map} +0 -0
  826. /package/dist/{profilePlot-2EW2XVTK.js.map → profilePlot-SOXXEUAT.js.map} +0 -0
  827. /package/dist/{profileRadar-AKUYC2O5.js.map → profileRadar-2OHJ2RIU.js.map} +0 -0
  828. /package/dist/{profileRadarFacility-EAT66XTX.js.map → profileRadarFacility-GHLG3QNG.js.map} +0 -0
  829. /package/dist/{qualitative-PHQU5DXE.js.map → qualitative-B3OY7A7P.js.map} +0 -0
  830. /package/dist/{regression-EOMJRRDO.js.map → regression-HO2TO4XT.js.map} +0 -0
  831. /package/dist/{regression.inputs-LIH5X2JM.js.map → regression.inputs-JN3ZMIOP.js.map} +0 -0
  832. /package/dist/{regression.inputs.term-OO4RZ3QB.js.map → regression.inputs.term-67HVMXFZ.js.map} +0 -0
  833. /package/dist/{regression.inputs.values.table-E7WCTO2L.js.map → regression.inputs.values.table-JXJK2YZT.js.map} +0 -0
  834. /package/dist/{regression.integration.spec-62VEQP6X.js.map → regression.integration.spec-L54ZS5VY.js.map} +0 -0
  835. /package/dist/{regression.results-WAHFJ6NA.js.map → regression.results-3ZSFKUNN.js.map} +0 -0
  836. /package/dist/{regression.spec-IBIOTZVX.js.map → regression.spec-SVWCQX2U.js.map} +0 -0
  837. /package/dist/{report-MKDJXHGY.js.map → report-IHX7XSOI.js.map} +0 -0
  838. /package/dist/{runChart-ETM2EETF.js.map → runChart-QLQMK3OE.js.map} +0 -0
  839. /package/dist/{runchart.integration.spec-QFA4XBKB.js.map → runchart.integration.spec-5NVY5GHR.js.map} +0 -0
  840. /package/dist/{sampleScatter.spec-N4N7ZGZF.js.map → sampleScatter.spec-4Q5CQQWH.js.map} +0 -0
  841. /package/dist/{sampleView-JTY3RV7I.js.map → sampleView-7WHDFHB5.js.map} +0 -0
  842. /package/dist/{samplelst-RRUMBVT6.js.map → samplelst-34GJVLVD.js.map} +0 -0
  843. /package/dist/{samplematrix-L37O664Y.js.map → samplematrix-L2HOSLUT.js.map} +0 -0
  844. /package/dist/{scatter-E5QHW32W.js.map → scatter-X6AAM2LJ.js.map} +0 -0
  845. /package/dist/{scatter.integration.spec-FNVAJSVU.js.map → scatter.integration.spec-QSH3PLBK.js.map} +0 -0
  846. /package/dist/{selectGenomeWithTklst-J6VXCYGG.js.map → selectGenomeWithTklst-AJS2IPPW.js.map} +0 -0
  847. /package/dist/{singleCellPlot-S6S6CKYX.js.map → singleCellPlot-7JEWDVSR.js.map} +0 -0
  848. /package/dist/{singlecell-B4TNI23F.js.map → singlecell-IC5KU72L.js.map} +0 -0
  849. /package/dist/{singlecell-4BMIKFY4.js.map → singlecell-NWANPXWM.js.map} +0 -0
  850. /package/dist/{snp-PAUQ24NZ.js.map → snp-PSRNMTL6.js.map} +0 -0
  851. /package/dist/{snplocus-HVFYZTEE.js.map → snplocus-QCAVDYLR.js.map} +0 -0
  852. /package/dist/{spliceevent.a53ss.diagram-GGGHVNBF.js.map → spliceevent.a53ss.diagram-SGDJKUEC.js.map} +0 -0
  853. /package/dist/{spliceevent.exonskip.diagram-HLMFD6LJ.js.map → spliceevent.exonskip.diagram-BUYTHCK5.js.map} +0 -0
  854. /package/dist/{spliceevent.noeventdiagram-CKZ3BZ7Y.js.map → spliceevent.noeventdiagram-OJZJUHXP.js.map} +0 -0
  855. /package/dist/{ssGSEA-UGT4GH55.js.map → ssGSEA-UUZG57MF.js.map} +0 -0
  856. /package/dist/{stattable-6JWMALGB.js.map → stattable-324FS2HA.js.map} +0 -0
  857. /package/dist/{summarizeCnvGeneexp-BJOQY62E.js.map → summarizeCnvGeneexp-ZVZYWP43.js.map} +0 -0
  858. /package/dist/{summarizeGeneexpSurvival-4HDHL7PE.js.map → summarizeGeneexpSurvival-7XJRMT6M.js.map} +0 -0
  859. /package/dist/{summarizeMutationDiagnosis-TDWO5CKU.js.map → summarizeMutationDiagnosis-ZKLXOVY2.js.map} +0 -0
  860. /package/dist/{summarizeMutationSurvival-CJJFABOX.js.map → summarizeMutationSurvival-S4YPGLWA.js.map} +0 -0
  861. /package/dist/{summary-WOAXXIHG.js.map → summary-RVG7JL6Y.js.map} +0 -0
  862. /package/dist/{summary.integration.spec-GM73ERMN.js.map → summary.integration.spec-SCD35GO4.js.map} +0 -0
  863. /package/dist/{summaryInput-FD4SONTY.js.map → summaryInput-DMN6DTSW.js.map} +0 -0
  864. /package/dist/{sunburst-3LCJTBRN.js.map → sunburst-QZXYILRC.js.map} +0 -0
  865. /package/dist/{survival-A3A7IVXT.js.map → survival-6CWEBRSF.js.map} +0 -0
  866. /package/dist/{survival-XF72VMM6.js.map → survival-J657VYLI.js.map} +0 -0
  867. /package/dist/{survival.integration.spec-AU7MCAQV.js.map → survival.integration.spec-S5WE4V6M.js.map} +0 -0
  868. /package/dist/{svgraph-BEMS4JDJ.js.map → svgraph-NEKJL24M.js.map} +0 -0
  869. /package/dist/{svmr-CDEMTZPK.js.map → svmr-5RQ5JQF2.js.map} +0 -0
  870. /package/dist/{table-WYF6QCGB.js.map → table-CG6Z6NCJ.js.map} +0 -0
  871. /package/dist/{termCollection-BVQMNVY7.js.map → termCollection-FOQNVXB7.js.map} +0 -0
  872. /package/dist/{termInfo-JXLIVCSO.js.map → termInfo-5USFZGDB.js.map} +0 -0
  873. /package/dist/{tk-TGIIJYBO.js.map → tk-2O7XOVGJ.js.map} +0 -0
  874. /package/dist/{tp.ui-USYF67P7.js.map → tp.ui-S4YUVCZH.js.map} +0 -0
  875. /package/dist/{tvs.dtcnv.continuous-7SCTSFK3.js.map → tvs.dtcnv.continuous-7BPIXZ6C.js.map} +0 -0
  876. /package/dist/{tvs.numeric-OLVW6US3.js.map → tvs.numeric-FCC2EY62.js.map} +0 -0
  877. /package/dist/{tvs.samplelst-BHZHCX5V.js.map → tvs.samplelst-PKGFTULN.js.map} +0 -0
  878. /package/dist/{violin-OEOWVIZF.js.map → violin-C7IBRTYP.js.map} +0 -0
  879. /package/dist/{violin.integration.spec-AW2U3RHO.js.map → violin.integration.spec-WXRD3Z4E.js.map} +0 -0
  880. /package/dist/{violin.interactivity-3O2UDNPQ.js.map → violin.interactivity-BMG4TG5L.js.map} +0 -0
  881. /package/dist/{violin.renderer-W26FA6M7.js.map → violin.renderer-WUNW6ULV.js.map} +0 -0
  882. /package/dist/{vocabulary-BIQYDKVY.js.map → vocabulary-UUNEEBM3.js.map} +0 -0
@@ -1,2189 +0,0 @@
1
- import {
2
- appear2 as appear,
3
- disappear2 as disappear,
4
- export_data,
5
- first_genetrack_tolist,
6
- font,
7
- make_table_2col,
8
- newpane,
9
- sayerror
10
- } from "./chunk-UT6W4ZZL.js";
11
- import {
12
- invalidcoord,
13
- string2pos
14
- } from "./chunk-HJ6L54YS.js";
15
- import {
16
- dofetch,
17
- dofetch2,
18
- dofetch3,
19
- vcfparsemeta
20
- } from "./chunk-5TDKRZN5.js";
21
- import "./chunk-RYRCMHYR.js";
22
- import {
23
- bplen,
24
- dt2label,
25
- dtcnv,
26
- dtfusionrna,
27
- dtitd,
28
- dtloh,
29
- dtsnvindel,
30
- dtsv,
31
- getMax_byiqr,
32
- mclass,
33
- mclassitd,
34
- tkt,
35
- validtkt
36
- } from "./chunk-ECKWM4HB.js";
37
- import {
38
- Menu
39
- } from "./chunk-NXOWHUR4.js";
40
- import "./chunk-5MWX5HUZ.js";
41
- import "./chunk-IQIXGTQV.js";
42
- import "./chunk-ICNJQHQZ.js";
43
- import "./chunk-FYTZCTJC.js";
44
- import "./chunk-7NTZWOJV.js";
45
- import "./chunk-OMO754MK.js";
46
- import "./chunk-RA5EXEHB.js";
47
- import {
48
- category10_default
49
- } from "./chunk-PMZS3SHH.js";
50
- import "./chunk-LOZEKOES.js";
51
- import "./chunk-TOU7EVFQ.js";
52
- import {
53
- linear,
54
- ordinal
55
- } from "./chunk-W2IWHXLL.js";
56
- import "./chunk-5OHXYXLD.js";
57
- import "./chunk-UJUXE42U.js";
58
- import "./chunk-OMR2DT66.js";
59
- import "./chunk-NDWTN4U5.js";
60
- import "./chunk-HFNDKYVF.js";
61
-
62
- // src/samplematrix.featuremenu.js
63
- function showMenu_isgenevalue(smat, f) {
64
- smat.menu.d.append("div").attr("class", "sja_menuoption").text("Sort").on("click", () => {
65
- smat.menu.hide();
66
- if (f.sort) {
67
- return;
68
- }
69
- for (const f2 of smat.features) {
70
- if (f2.isgenevalue) delete f2.sort;
71
- }
72
- f.sort = 1;
73
- smat.draw_matrix();
74
- });
75
- }
76
- function showMenu_iscnv(smat, f, obj) {
77
- {
78
- const row = smat.menu.d.append("div").style("margin", "10px");
79
- row.append("span").html("CNV log2(ratio) cutoff ");
80
- row.append("input").property("value", obj.valuecutoff || 0).attr("type", "number").style("width", "50px").on("keyup", (event2) => {
81
- if (event2.code != "Enter" && event2.code != "NumpadEnter") return;
82
- let v = Number.parseFloat(event2.target.value);
83
- if (!v || v < 0) {
84
- v = 0;
85
- }
86
- if (v == 0) {
87
- if (obj.valuecutoff) {
88
- obj.valuecutoff = 0;
89
- smat.update_singlefeature(f);
90
- } else {
91
- }
92
- return;
93
- }
94
- if (obj.valuecutoff) {
95
- if (obj.valuecutoff == v) {
96
- } else {
97
- obj.valuecutoff = v;
98
- smat.update_singlefeature(f);
99
- }
100
- } else {
101
- obj.valuecutoff = v;
102
- smat.update_singlefeature(f);
103
- }
104
- });
105
- row.append("div").style("font-size", ".7em").style("opacity", 0.5).html("Only show CNV with absolute log2(ratio) no less than cutoff.<br>Set to 0 to cancel.");
106
- }
107
- {
108
- const row = smat.menu.d.append("div").style("margin", "10px");
109
- row.append("span").html("CNV segment size limit&nbsp;");
110
- row.append("input").property("value", obj.focalsizelimit || 0).attr("type", "number").style("width", "100px").on("keyup", (event2) => {
111
- if (event2.code != "Enter" && event2.code != "NumpadEnter") return;
112
- let v = Number.parseInt(event2.target.value);
113
- if (!v || v < 0) {
114
- v = 0;
115
- }
116
- if (v == 0) {
117
- if (obj.focalsizelimit) {
118
- obj.focalsizelimit = 0;
119
- smat.update_singlefeature(f);
120
- } else {
121
- }
122
- return;
123
- }
124
- if (obj.focalsizelimit) {
125
- if (obj.focalsizelimit == v) {
126
- } else {
127
- obj.focalsizelimit = v;
128
- smat.update_singlefeature(f);
129
- }
130
- } else {
131
- obj.focalsizelimit = v;
132
- smat.update_singlefeature(f);
133
- }
134
- });
135
- row.append("span").text("bp");
136
- row.append("div").style("font-size", ".7em").style("opacity", 0.5).html("Limit the CNV segment length to show only focal events.<br>Set to 0 to cancel.");
137
- }
138
- }
139
- function showMenu_isloh(smat, f, obj) {
140
- {
141
- const row = smat.menu.d.append("div").style("margin", "10px");
142
- row.append("span").html("LOH segmean cutoff&nbsp;");
143
- row.append("input").property("value", obj.valuecutoff || 0).attr("type", "number").style("width", "50px").on("keyup", (event2) => {
144
- if (event2.code != "Enter" && event2.code != "NumpadEnter") return;
145
- let v = Number.parseFloat(event2.target.value);
146
- if (!v || v < 0) {
147
- v = 0;
148
- }
149
- if (v == 0) {
150
- if (obj.valuecutoff) {
151
- obj.valuecutoff = 0;
152
- smat.update_singlefeature(f);
153
- } else {
154
- }
155
- return;
156
- }
157
- if (obj.valuecutoff) {
158
- if (obj.valuecutoff == v) {
159
- } else {
160
- obj.valuecutoff = v;
161
- smat.update_singlefeature(f);
162
- }
163
- } else {
164
- obj.valuecutoff = v;
165
- smat.update_singlefeature(f);
166
- }
167
- });
168
- row.append("div").style("font-size", ".7em").style("opacity", 0.5).html("Only show LOH with segmean no less than cutoff.<br>Set to 0 to cancel.");
169
- }
170
- {
171
- const row = smat.menu.d.append("div").style("margin", "10px");
172
- row.append("span").html("LOH segment size limit&nbsp;");
173
- row.append("input").property("value", obj.focalsizelimit || 0).attr("type", "number").style("width", "100px").on("keyup", (event2) => {
174
- if (event2.code != "Enter" && event2.code != "NumpadEnter") return;
175
- let v = Number.parseInt(event2.target.value);
176
- if (!v || v < 0) {
177
- v = 0;
178
- }
179
- if (v == 0) {
180
- if (obj.focalsizelimit) {
181
- obj.focalsizelimit = 0;
182
- smat.update_singlefeature(f);
183
- } else {
184
- }
185
- return;
186
- }
187
- if (obj.focalsizelimit) {
188
- if (obj.focalsizelimit == v) {
189
- } else {
190
- obj.focalsizelimit = v;
191
- smat.update_singlefeature(f);
192
- }
193
- } else {
194
- obj.focalsizelimit = v;
195
- smat.update_singlefeature(f);
196
- }
197
- });
198
- row.append("span").text("bp");
199
- row.append("div").style("font-size", ".7em").style("opacity", 0.5).html("Limit the LOH segment length to show only focal events.<br>Set to 0 to cancel.");
200
- }
201
- }
202
- function showMenu_ismutation(smat, f) {
203
- {
204
- const div = smat.menu.d.append("div").style("margin", "10px").style("border", "solid 1px #ededed");
205
- const update = () => {
206
- smat.update_singlefeature(f);
207
- smat.menu.hide();
208
- };
209
- const table = div.append("table").style("margin", "10px").style("border-spacing", "1px");
210
- const tbody = table.append("tbody");
211
- {
212
- const tr = tbody.append("tr");
213
- tr.append("td").style("opacity", 0.5).text("CNV");
214
- tr.append("td").attr("class", "sja_menuoption").text(f.cnv.hidden ? "Show" : "Hide").on("click", () => {
215
- f.cnv.hidden = !f.cnv.hidden;
216
- update();
217
- });
218
- tr.append("td").attr("class", "sja_menuoption").text("Show only").on("click", () => {
219
- ismutation_hideallclass(f);
220
- delete f.cnv.hidden;
221
- update();
222
- });
223
- const td = tr.append("td");
224
- if (!f.cnv.hidden) {
225
- td.attr("class", "sja_menuoption").style("font-size", ".8em").text("CONFIG").on("click", () => {
226
- smat.menu.clear();
227
- showMenu_iscnv(smat, f, f.cnv);
228
- });
229
- }
230
- }
231
- {
232
- const tr = tbody.append("tr");
233
- tr.append("td").style("opacity", 0.5).text("LOH");
234
- tr.append("td").attr("class", "sja_menuoption").text(f.loh.hidden ? "Show" : "Hide").on("click", () => {
235
- f.loh.hidden = !f.loh.hidden;
236
- update();
237
- });
238
- tr.append("td").attr("class", "sja_menuoption").text("Show only").on("click", () => {
239
- ismutation_hideallclass(f);
240
- delete f.loh.hidden;
241
- update();
242
- });
243
- const td = tr.append("td");
244
- if (!f.loh.hidden) {
245
- td.attr("class", "sja_menuoption").style("font-size", ".8em").text("CONFIG").on("click", () => {
246
- smat.menu.clear();
247
- showMenu_isloh(smat, f, f.loh);
248
- });
249
- }
250
- }
251
- {
252
- const tr = tbody.append("tr");
253
- tr.append("td").style("opacity", 0.5).text("ITD");
254
- tr.append("td").attr("class", "sja_menuoption").text(f.itd.hidden ? "Show" : "Hide").on("click", () => {
255
- f.itd.hidden = !f.itd.hidden;
256
- update();
257
- });
258
- tr.append("td").attr("class", "sja_menuoption").text("Show only").on("click", () => {
259
- ismutation_hideallclass(f);
260
- delete f.itd.hidden;
261
- update();
262
- });
263
- const td = tr.append("td");
264
- if (!f.itd.hidden) {
265
- }
266
- }
267
- {
268
- const tr = tbody.append("tr");
269
- tr.append("td").style("opacity", 0.5).text("SV");
270
- tr.append("td").attr("class", "sja_menuoption").text(f.sv.hidden ? "Show" : "Hide").on("click", () => {
271
- f.sv.hidden = !f.sv.hidden;
272
- update();
273
- });
274
- tr.append("td").attr("class", "sja_menuoption").text("Show only").on("click", () => {
275
- ismutation_hideallclass(f);
276
- delete f.sv.hidden;
277
- update();
278
- });
279
- const td = tr.append("td");
280
- if (!f.sv.hidden) {
281
- }
282
- }
283
- {
284
- const tr = tbody.append("tr");
285
- tr.append("td").style("opacity", 0.5).text("Fusion");
286
- tr.append("td").attr("class", "sja_menuoption").text(f.fusion.hidden ? "show" : "hide").on("click", () => {
287
- f.fusion.hidden = !f.fusion.hidden;
288
- update();
289
- });
290
- tr.append("td").attr("class", "sja_menuoption").text("show only").on("click", () => {
291
- ismutation_hideallclass(f);
292
- delete f.fusion.hidden;
293
- update();
294
- });
295
- const td = tr.append("td");
296
- if (!f.fusion.hidden) {
297
- }
298
- }
299
- table.append("tbody").append("tr").append("td").attr("colspan", 4).style("padding-top", "10px").append("span").style("font-size", ".8em").text("List SNV/indel").attr("class", "sja_clbtext").on("click", () => {
300
- if (tbody2.style("display") == "none") {
301
- tbody2.style("display", "table-row-group");
302
- } else {
303
- tbody2.style("display", "none");
304
- }
305
- });
306
- const tbody2 = table.append("tbody").style("display", "none");
307
- for (const k in mclass) {
308
- const c = mclass[k];
309
- if (c.dt != dtsnvindel) {
310
- continue;
311
- }
312
- const tr = tbody2.append("tr");
313
- tr.append("td").style("opacity", 0.5).text(c.label);
314
- tr.append("td").attr("class", "sja_menuoption").text(f.snvindel.excludeclasses[k] ? "Show" : "Hide").on("click", () => {
315
- if (f.snvindel.excludeclasses[k]) {
316
- delete f.snvindel.excludeclasses[k];
317
- } else {
318
- f.snvindel.excludeclasses[k] = 1;
319
- }
320
- update();
321
- });
322
- tr.append("td").attr("class", "sja_menuoption").text("Show only").on("click", () => {
323
- ismutation_hideallclass(f);
324
- delete f.snvindel.excludeclasses[k];
325
- update();
326
- });
327
- const td = tr.append("td");
328
- }
329
- div.append("div").style("margin", "10px").append("span").style("font-size", ".8em").text("Show all classes").attr("class", "sja_clbtext").on("click", () => {
330
- f.cnv.hidden = false;
331
- f.loh.hidden = false;
332
- f.itd.hidden = false;
333
- f.sv.hidden = false;
334
- f.fusion.hidden = false;
335
- f.snvindel.excludeclasses = {};
336
- update();
337
- });
338
- }
339
- }
340
- function ismutation_hideallclass(f) {
341
- f.cnv.hidden = true;
342
- f.loh.hidden = true;
343
- f.itd.hidden = true;
344
- f.sv.hidden = true;
345
- f.fusion.hidden = true;
346
- f.snvindel.excludeclasses = {};
347
- for (const k in mclass) {
348
- if (mclass[k].dt == dtsnvindel) f.snvindel.excludeclasses[k] = 1;
349
- }
350
- }
351
-
352
- // src/samplematrix.kmplot.js
353
- function may_add_kmplotbutton(smat, buttonrow) {
354
- if (!smat.mds || !smat.mds.survivalplot) return;
355
- buttonrow.append("span").style("margin-right", "20px").style("font-size", ".8em").text("SURVIVAL PLOT").attr("class", "sja_clbtext").on("click", (event2) => {
356
- smat.menu.clear().showunder(event2.target);
357
- kmplot_menu(smat);
358
- });
359
- }
360
- async function kmplot_menu(smat) {
361
- const mutation_features = smat.features.filter((i) => i.ismutation);
362
- try {
363
- if (mutation_features.length != 2) throw "only works with two genomic features.";
364
- await kmplot_do(smat, mutation_features[0], mutation_features[1]);
365
- } catch (e) {
366
- smat.menu.d.append("div").style("margin", "20px").text("Cannot make survival plot: " + (e.message || e));
367
- }
368
- }
369
- async function kmplot_do(smat, f1, f2) {
370
- const s1 = [], s2 = [], s12 = [];
371
- for (const i of smat.samples) {
372
- const in1 = f1.items.find((j) => j.sample == i.name);
373
- const in2 = f2.items.find((j) => j.sample == i.name);
374
- if (in1) {
375
- if (in2) s12.push(i.name);
376
- else s1.push(i.name);
377
- } else {
378
- s2.push(i.name);
379
- }
380
- }
381
- const plot = {
382
- renderplot: 1,
383
- samplerule: {
384
- full: {},
385
- mutated_sets: [
386
- { name: f1.label + " mutated (n=" + s1.length + ")", samplenames: s1 },
387
- { name: f2.label + " mutated (n=" + s2.length + ")", samplenames: s2 },
388
- { name: f1.label + " and " + f2.label + " mutated (n=" + s12.length + ")", samplenames: s12 }
389
- ]
390
- }
391
- };
392
- if (smat.limitsamplebyeitherannotation) {
393
- plot.samplerule.full = {
394
- byattr: 1,
395
- key: smat.limitsamplebyeitherannotation[0].key,
396
- value: smat.limitsamplebyeitherannotation[0].value,
397
- immutable: 1
398
- };
399
- }
400
- const pane = newpane({ x: 100, y: 100 });
401
- pane.header.text(
402
- (smat.limitsamplebyeitherannotation ? smat.limitsamplebyeitherannotation[0].value + " " : "") + "survival by " + f1.label + " and " + f2.label + " mutation status"
403
- );
404
- const _ = await import("./mds.survivalplot-SQDPUFQE.js");
405
- _.init(
406
- {
407
- mds: smat.mds,
408
- genome: smat.genome,
409
- plotlist: [plot]
410
- },
411
- pane.body
412
- );
413
- }
414
-
415
- // src/samplematrix.js
416
- var saynovalue = "na";
417
- var default_cnvgaincolor = "#D6683C";
418
- var default_cnvlosscolor = "#67a9cf";
419
- var default_genevaluecolor = "#095873";
420
- var default_lohcolor = "#858585";
421
- var default_svcolor = "#858585";
422
- var minheight2showname = 8;
423
- var Samplematrix = class {
424
- /*
425
- init ui
426
- */
427
- constructor(p) {
428
- for (const k in p) {
429
- this[k] = p[k];
430
- }
431
- if (this.debugmode) window.smat = this;
432
- this.tip = new Menu({ padding: "0px", hideXmute: 1, hideYmute: 1 });
433
- this.menu = new Menu({ padding: "0px" });
434
- this.errdiv = this.holder.append("div");
435
- if (!this.iscustom) {
436
- try {
437
- if (!this.dslabel) throw "not custom data but dslabel is missing";
438
- this.mds = this.genome.datasets[this.dslabel];
439
- if (!this.mds) throw "invalid dataset name: " + this.dslabel;
440
- if (!this.mds.isMds) throw "improper dataset: " + this.dslabel;
441
- } catch (e) {
442
- this.error(e);
443
- }
444
- }
445
- init_controlui(this);
446
- if (this.header) {
447
- this.holder.append("div").style("margin-bottom", "20px").html(this.header);
448
- }
449
- this.wait_div = this.holder.append("div");
450
- this.wait_div.style("display", "block").text("Loading...");
451
- this.svg = this.holder.append("svg");
452
- this.validate_config().then(() => {
453
- return this.get_features();
454
- }).catch((err) => {
455
- if (typeof err == "string") {
456
- this.error(err);
457
- } else {
458
- this.error(err.message);
459
- if (err.stack) console.log(err.stack);
460
- }
461
- });
462
- }
463
- error(m) {
464
- sayerror(this.errdiv, m);
465
- }
466
- async validate_config() {
467
- if (this.iscustom) {
468
- if (!this.querykey2tracks) throw "querykey2tracks missing for custom dataset";
469
- let novalidtk = true;
470
- for (const key in this.querykey2tracks) {
471
- const tk = this.querykey2tracks[key];
472
- if (!tk.file && !tk.url) throw "no file or url for a custom track by key " + key;
473
- if (!tk.type) throw "missing type for member track by key " + key;
474
- if (!validtkt(tk.type)) throw "invalid type for a member track: " + tk.type;
475
- novalidtk = false;
476
- }
477
- if (novalidtk) throw "no custom tracks from querykey2tracks";
478
- let vcftk;
479
- for (const key in this.querykey2tracks) {
480
- const tk = this.querykey2tracks[key];
481
- if (tk.type == tkt.mdsvcf) {
482
- vcftk = tk;
483
- }
484
- }
485
- if (vcftk) {
486
- await this.may_init_customvcf(vcftk);
487
- }
488
- } else {
489
- if (this.mds.mdsIsUninitiated) {
490
- const d = await dofetch3(`getDataset?genome=${this.genome.name}&dsname=${this.mds.label}`);
491
- if (d.error) throw d.error;
492
- if (!d.ds) throw "ds missing";
493
- Object.assign(this.mds, d.ds);
494
- delete this.mds.mdsIsUninitiated;
495
- }
496
- }
497
- if (this.limitsamplebyeitherannotation) {
498
- if (!Array.isArray(this.limitsamplebyeitherannotation)) throw "limitsamplebyeitherannotation must be an array";
499
- const tr = this.legendtable.append("tr");
500
- for (const anno of this.limitsamplebyeitherannotation) {
501
- if (!anno.key) throw ".key missing from an element of limitsamplebyeitherannotation";
502
- if (!anno.value) throw ".value missing from an element of limitsamplebyeitherannotation";
503
- }
504
- this.showlegend_limitsample();
505
- }
506
- const cnv_tr = this.legendtable.append("tr");
507
- cnv_tr.append("td").style("opacity", 0.5).style("text-align", "right").text("CNV cutoff");
508
- this.legendtable.cnv_td = cnv_tr.append("td");
509
- const loh_tr = this.legendtable.append("tr");
510
- loh_tr.append("td").style("opacity", 0.5).style("text-align", "right").text("LOH cutoff");
511
- this.legendtable.loh_td = loh_tr.append("td");
512
- if (this.limitbysamplesetgroup) {
513
- if (!Array.isArray(this.limitbysamplesetgroup.samples)) throw ".limitbysamplesetgroup.samples is not array";
514
- }
515
- if (!this.rowspace) this.rowspace = 1;
516
- if (!this.colspace) this.colspace = 1;
517
- if (!this.rowlabspace) this.rowlabspace = 5;
518
- if (!this.collabspace) this.collabspace = 5;
519
- if (!this.rowlabticksize) this.rowlabticksize = 5;
520
- if (!this.collabticksize) this.collabticksize = 5;
521
- if (!this.features) throw "missing features[]";
522
- if (!Array.isArray(this.features)) throw "features must be an array";
523
- if (this.features[0].height) this.ori_feature_height = this.features[0].height;
524
- if (this.features[0].width) this.ori_feature_width = this.features[0].width;
525
- for (const f of this.features) {
526
- await this.validate_feature(f);
527
- }
528
- }
529
- showlegend_limitsample() {
530
- if (!this.limitsamplebyeitherannotation) return;
531
- }
532
- feature_parseposition_maygene(f) {
533
- return Promise.resolve().then(() => {
534
- if (f.position) {
535
- const o = string2pos(f.position, this.genome);
536
- if (o) {
537
- f.chr = o.chr;
538
- f.start = o.start;
539
- f.stop = o.stop;
540
- }
541
- }
542
- if (f.chr) {
543
- const err = invalidcoord(this.genome, f.chr, f.start, f.stop);
544
- if (err) {
545
- throw 'feature "' + f.label + '" position error: ' + err;
546
- } else {
547
- return;
548
- }
549
- }
550
- if (!f.genename) throw "position required for a feature: no position or genename given";
551
- return dofetch("/genelookup", {
552
- input: f.genename,
553
- genome: this.genome.name,
554
- deep: 1
555
- }).then((data) => {
556
- if (data.error) throw data.error;
557
- if (!data.gmlst || data.gmlst.length == 0) throw "no gene can be found for " + f.genename;
558
- const regions = [];
559
- for (const gm of data.gmlst) {
560
- let nooverlap = true;
561
- for (const region of regions) {
562
- if (gm.chr == region.chr && Math.max(gm.start, region.start) < Math.min(gm.stop, region.stop)) {
563
- nooverlap = false;
564
- region.start = Math.min(region.start, gm.start);
565
- region.stop = Math.max(region.stop, gm.stop);
566
- break;
567
- }
568
- }
569
- if (nooverlap) {
570
- regions.push({
571
- chr: gm.chr,
572
- start: gm.start,
573
- stop: gm.stop
574
- });
575
- }
576
- }
577
- if (regions.length > 1) {
578
- sayerror(
579
- this.errdiv,
580
- "multiple regions found for gene " + f.genename + " you'd better specify one in feature"
581
- );
582
- }
583
- f.chr = regions[0].chr;
584
- f.start = regions[0].start;
585
- f.stop = regions[0].stop;
586
- });
587
- });
588
- }
589
- validate_feature(f) {
590
- return Promise.resolve().then(() => {
591
- f.id = Math.random().toString();
592
- const tr = this.legendtable.append("tr");
593
- f.legend_tr = tr;
594
- if (f.isgenevalue) {
595
- if (!f.genename) throw ".genename missing for isgenevalue feature";
596
- f.label = f.genename + " expression";
597
- if (this.dslabel) {
598
- if (!f.querykey) throw ".querykey missing for isgenevalue feature while loading from official dataset";
599
- } else {
600
- }
601
- if (!f.scale) f.scale = { auto: 1 };
602
- if (f.missingvalue == void 0) f.missingvalue = 0;
603
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
604
- f.legendholder = tr.append("td");
605
- if (!f.width) f.width = 20;
606
- if (!f.color) f.color = default_genevaluecolor;
607
- return this.feature_parseposition_maygene(f);
608
- }
609
- if (f.iscnv) {
610
- if (this.dslabel) {
611
- if (!f.querykey) throw ".querykey missing for iscnv feature while loading from official dataset";
612
- } else {
613
- }
614
- if (!f.label && f.genename) {
615
- f.label = f.genename + " CNV";
616
- }
617
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
618
- f.legendholder = tr.append("td");
619
- if (!f.width) f.width = 40;
620
- if (!f.colorgain) f.colorgain = default_cnvgaincolor;
621
- if (!f.colorloss) f.colorloss = default_cnvlosscolor;
622
- return this.feature_parseposition_maygene(f).then(() => {
623
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " CNV";
624
- f.coordscale = linear().domain([f.start, f.stop]).range([0, this.features_on_rows ? f.height : f.width]);
625
- });
626
- }
627
- if (f.isloh) {
628
- if (this.dslabel) {
629
- if (!f.querykey) throw ".querykey missing for isloh feature while loading from official dataset";
630
- } else {
631
- }
632
- if (!f.label && f.genename) {
633
- f.label = f.genename + " LOH";
634
- }
635
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
636
- f.legendholder = tr.append("td");
637
- if (!f.width) f.width = 40;
638
- if (!f.color) f.color = default_lohcolor;
639
- return this.feature_parseposition_maygene(f).then(() => {
640
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " LOH";
641
- f.coordscale = linear().domain([f.start, f.stop]).range([0, this.features_on_rows ? f.height : f.width]);
642
- });
643
- }
644
- if (f.isvcf) {
645
- if (this.dslabel) {
646
- if (!f.querykey) throw ".querykey missing for isvcf feature while loading from official dataset";
647
- } else {
648
- }
649
- if (!f.label && f.genename) {
650
- f.label = f.genename + " SNV/indel";
651
- }
652
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
653
- f.legendholder = tr.append("td");
654
- if (!f.width) f.width = 20;
655
- if (!f.snvindel) f.snvindel = {};
656
- return this.feature_parseposition_maygene(f).then(() => {
657
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " SNV/indel";
658
- });
659
- }
660
- if (f.isitd) {
661
- if (this.dslabel) {
662
- if (!f.querykey) throw ".querykey missing for isitd feature while loading from official dataset";
663
- } else {
664
- }
665
- if (!f.label && f.genename) {
666
- f.label = f.genename + " ITD";
667
- }
668
- if (!f.width) f.width = 20;
669
- if (!f.color) f.color = mclass[mclassitd].color;
670
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
671
- f.legendholder = tr.append("td");
672
- f.legendholder.append("div").style("width", "20px").html("&nbsp;").style("background", f.color);
673
- return this.feature_parseposition_maygene(f).then(() => {
674
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " ITD";
675
- });
676
- }
677
- if (f.issvfusion) {
678
- if (this.dslabel) {
679
- if (!f.querykey) throw ".querykey missing for issvfusion feature while loading from official dataset";
680
- } else {
681
- }
682
- if (!f.label && f.genename) {
683
- f.label = f.genename + " SV/fusion";
684
- }
685
- if (!f.width) f.width = 20;
686
- if (!f.color) f.color = default_svcolor;
687
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
688
- f.legendholder = tr.append("td");
689
- return this.feature_parseposition_maygene(f).then(() => {
690
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " SV/fusion";
691
- });
692
- }
693
- if (f.issvcnv) {
694
- if (this.dslabel) {
695
- if (!f.querykey) throw ".querykey missing for issvcnv feature while loading from official dataset";
696
- } else {
697
- }
698
- if (!f.label && f.genename) {
699
- f.label = f.genename + " CNV/SV";
700
- }
701
- tr.append("td").text(f.label).style("color", "#858585").style("text-align", "right");
702
- f.legendholder = tr.append("td");
703
- initfeature_polymutation(f);
704
- return this.feature_parseposition_maygene(f).then(() => {
705
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " CNV/SV";
706
- });
707
- }
708
- if (f.ismutation) {
709
- if (this.dslabel) {
710
- if (!f.querykeylst) throw ".querykeylst missing for ismutation feature";
711
- if (!Array.isArray(f.querykeylst)) throw ".querykeylst[] should be array for ismutation feature";
712
- if (f.querykeylst.length == 0) throw "querykeylst[] empty array for ismutation feature";
713
- } else {
714
- }
715
- if (!f.label && f.genename) {
716
- f.label = f.genename + " mutation";
717
- }
718
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
719
- f.legendholder = tr.append("td");
720
- initfeature_polymutation(f);
721
- return this.feature_parseposition_maygene(f).then(() => {
722
- if (!f.label) f.label = f.chr + ":" + f.start + "-" + f.stop + " mutation";
723
- f.coordscale = linear().domain([f.start, f.stop]).range([0, this.features_on_rows ? f.height : f.width]);
724
- });
725
- }
726
- if (f.issampleattribute) {
727
- if (!this.dslabel) throw ".dslabel missing: sampleattribute only works for official dataset";
728
- if (!f.key) throw ".key missing for issampleattribute feature";
729
- if (!f.label) f.label = f.key;
730
- if (this.mds && this.mds.sampleAttribute && this.mds.sampleAttribute.attributes) {
731
- const registry = this.mds.sampleAttribute.attributes[f.key];
732
- if (registry) {
733
- f.values = registry.values;
734
- }
735
- }
736
- if (!f.values) {
737
- f.values = {};
738
- }
739
- f.assignmissingcolor = ordinal(category10_default);
740
- if (!f.width && !this.features_on_rows) f.width = 20;
741
- else if (!f.height && this.features_on_rows) f.height = 50;
742
- tr.append("td").text(f.label).style("opacity", 0.5).style("text-align", "right");
743
- f.legendholder = tr.append("td");
744
- return Promise.resolve();
745
- }
746
- throw "unknown feature type in validating feature";
747
- });
748
- }
749
- get_features(featureset) {
750
- this.max_cnv = 0;
751
- this.min_cnv = 0;
752
- this.max_loh = 0;
753
- this.min_loh = 0;
754
- const arg = {
755
- genome: this.genome.name,
756
- limitsamplebyeitherannotation: this.limitsamplebyeitherannotation,
757
- features: (featureset || this.features).map(feature2arg)
758
- };
759
- if (this.limitbysamplesetgroup) {
760
- arg.sampleset = this.limitbysamplesetgroup.samples;
761
- }
762
- if (this.iscustom) {
763
- arg.iscustom = 1;
764
- arg.querykey2tracks = {};
765
- for (const f of arg.features) {
766
- if (f.querykey) {
767
- arg.querykey2tracks[f.querykey] = this.querykey2tracks[f.querykey];
768
- } else if (f.querykeylst) {
769
- for (const k of f.querykeylst) arg.querykey2tracks[k] = this.querykey2tracks[k];
770
- }
771
- }
772
- } else {
773
- arg.dslabel = this.mds.label;
774
- }
775
- return dofetch("/samplematrix", arg).then((data) => {
776
- if (data.error) {
777
- for (const f0 of arg.features) {
778
- const f = this.features.find((f2) => f2.id == f0.id);
779
- if (f) f.items = [];
780
- }
781
- throw data.error;
782
- }
783
- for (const dat of data.results) {
784
- const f = this.features.find((f2) => f2.id == dat.id);
785
- if (!f) throw "feature not found: " + f.id;
786
- f.items = dat.items;
787
- this.prep_featuredata(f);
788
- }
789
- this.draw_matrix();
790
- this.make_legend();
791
- this.wait_div.style("display", "none");
792
- });
793
- }
794
- update_singlefeature(f) {
795
- this.get_features([f]).catch((err) => {
796
- if (typeof err == "string") {
797
- this.error(err);
798
- } else {
799
- this.error(err.message);
800
- if (err.stack) console.log(err.stack);
801
- }
802
- });
803
- }
804
- addnewfeature_update(f) {
805
- this.features.push(f);
806
- this.validate_feature(f).then(() => {
807
- return this.get_features([f]);
808
- }).catch((err) => {
809
- this.error(typeof err == "string" ? err : err.message);
810
- if (err.stack) console.log(err.stack);
811
- });
812
- }
813
- prep_featuredata(f) {
814
- if (f.isgenevalue) {
815
- f.scale.maxv = 0;
816
- f.scale.minv = 0;
817
- for (const i of f.items) {
818
- f.scale.maxv = Math.max(f.scale.maxv, i.value);
819
- }
820
- return;
821
- }
822
- if (f.iscnv) {
823
- const gain = [], loss = [];
824
- for (const i of f.items) {
825
- if (i.value > 0) {
826
- gain.push(i.value);
827
- } else {
828
- loss.push(-i.value);
829
- }
830
- }
831
- const gmax = getMax_byiqr(gain, 0);
832
- const lmax = getMax_byiqr(loss, 0);
833
- f.maxabslogratio = Math.max(gmax, lmax);
834
- if (f.maxabslogratio > this.max_cnv) this.max_cnv = f.maxabslogratio;
835
- return;
836
- }
837
- if (f.isloh) {
838
- const values = f.items.map((i) => i.segmean);
839
- f.minvalue = 0;
840
- f.maxvalue = Math.max(...values);
841
- if (f.maxvalue > this.max_loh) this.max_loh = f.maxvalue;
842
- return;
843
- }
844
- if (f.isvcf) {
845
- return;
846
- }
847
- if (f.isitd) {
848
- return;
849
- }
850
- if (f.issvfusion) {
851
- return;
852
- }
853
- if (f.issvcnv || f.ismutation) {
854
- const cnvgain = [], cnvloss = [];
855
- let lohmax = 0;
856
- for (const i of f.items) {
857
- if (i.dt == dtcnv) {
858
- if (i.value > 0) {
859
- cnvgain.push(i.value);
860
- } else {
861
- cnvloss.push(-i.value);
862
- }
863
- } else if (i.dt == dtloh) {
864
- lohmax = Math.max(i.segmean, lohmax);
865
- }
866
- }
867
- if (cnvgain.length + cnvloss.length > 0) {
868
- const gmax = getMax_byiqr(cnvgain, 0);
869
- const lmax = getMax_byiqr(cnvloss, 0);
870
- f.cnv.maxabslogratio = Math.max(gmax, lmax);
871
- if (f.cnv.maxabslogratio > this.max_cnv) {
872
- this.max_cnv = f.cnv.maxabslogratio;
873
- this.min_cnv = -f.cnv.maxabslogratio;
874
- this.cnv_colorloss = f.cnv.colorloss;
875
- this.cnv_colorgain = f.cnv.colorgain;
876
- }
877
- }
878
- if (lohmax) {
879
- f.loh.minvalue = 0;
880
- f.loh.maxvalue = lohmax;
881
- if (f.loh.maxvalue > this.max_loh) this.max_loh = f.loh.maxvalue;
882
- this.loh_color = f.loh.color;
883
- }
884
- return;
885
- }
886
- if (f.issampleattribute) {
887
- for (const i of f.items) {
888
- if (!f.values[i.value]) {
889
- f.values[i.value] = {
890
- name: i.value,
891
- color: f.assignmissingcolor(i.value)
892
- };
893
- }
894
- }
895
- return;
896
- }
897
- throw "unknown feature type in preparing feature data";
898
- }
899
- make_legend() {
900
- for (const f of this.features) {
901
- const h = f.legendholder;
902
- h.selectAll("*").remove();
903
- if (f.isgenevalue) {
904
- h.append("span").text(f.scale.minv.toFixed(3));
905
- h.append("div").style("margin", "2px 10px").style("display", "inline-block").style("width", "100px").style("height", "15px").style("background", "linear-gradient( to right, white, " + f.color + ")");
906
- h.append("span").text(f.scale.maxv.toFixed(3));
907
- continue;
908
- }
909
- if (f.iscnv) {
910
- h.append("span").html(
911
- 'Gain <span style="background:' + f.colorgain + ';color:white;padding:1px 5px">' + f.maxabslogratio.toFixed(3) + '</span> &nbsp; Loss <span style="background:' + f.colorloss + ';color:white;padding:1px 5px">-' + f.maxabslogratio.toFixed(3) + "</span>"
912
- );
913
- continue;
914
- }
915
- if (f.isloh) {
916
- h.append("span").text(f.minvalue.toFixed(3));
917
- h.append("div").style("margin", "2px 10px").style("display", "inline-block").style("width", "100px").style("height", "15px").style("background", "linear-gradient( to right, white, " + f.color + ")");
918
- h.append("span").text(f.maxvalue.toFixed(3));
919
- continue;
920
- }
921
- if (f.isvcf) {
922
- const classes = /* @__PURE__ */ new Set();
923
- for (const m of f.items) {
924
- if (m.class) {
925
- classes.add(m.class);
926
- } else {
927
- }
928
- }
929
- for (const c of classes) {
930
- const cell = h.append("div").style("display", "inline-block").style("margin-right", "10px");
931
- cell.append("span").style("background", mclass[c].color).style("margin-right", "2px").html("&nbsp;&nbsp;&nbsp;");
932
- cell.append("span").text(mclass[c].label).style("color", mclass[c].color);
933
- }
934
- continue;
935
- }
936
- if (f.isitd) {
937
- continue;
938
- }
939
- if (f.issvfusion) {
940
- continue;
941
- }
942
- if (f.issvcnv || f.ismutation) {
943
- const vcfclass2count = /* @__PURE__ */ new Map();
944
- let itdcount = 0;
945
- let svcount = 0;
946
- let fusioncount = 0;
947
- for (const i of f.items) {
948
- if (i.dt == dtsnvindel) {
949
- if (i.class && i.sampledata) {
950
- if (!vcfclass2count.has(i.class)) {
951
- vcfclass2count.set(i.class, 0);
952
- }
953
- vcfclass2count.set(i.class, vcfclass2count.get(i.class) + i.sampledata.length);
954
- } else {
955
- }
956
- } else if (i.dt == dtitd) {
957
- itdcount++;
958
- } else if (i.dt == dtsv) {
959
- svcount++;
960
- } else if (i.dt == dtfusionrna) {
961
- fusioncount++;
962
- }
963
- }
964
- if (vcfclass2count.size + itdcount + svcount + fusioncount > 0) {
965
- const row = h.append("div").style("margin-bottom", "5px").style("white-space", "nowrap");
966
- for (const [classname, count] of vcfclass2count) {
967
- const c = mclass[classname];
968
- const cell = row.append("div").style("display", "inline-block").style("margin-right", "20px");
969
- cell.append("span").attr("class", "sja_mcdot").style("background", c.color).text(count);
970
- cell.append("span").text(c.label).style("color", c.color);
971
- }
972
- if (itdcount) {
973
- const cell = row.append("div").style("display", "inline-block").style("margin-right", "20px");
974
- cell.append("span").attr("class", "sja_mcdot").style("background", f.itd.color).text(itdcount);
975
- cell.append("span").text("ITD");
976
- }
977
- if (svcount) {
978
- const cell = row.append("div").style("display", "inline-block").style("margin-right", "20px");
979
- cell.append("span").attr("class", "sja_mcdot").style("background", f.sv.color).text(svcount);
980
- cell.append("span").text("SV");
981
- }
982
- if (fusioncount) {
983
- const cell = row.append("div").style("display", "inline-block").style("margin-right", "20px");
984
- cell.append("span").attr("class", "sja_mcdot").style("background", f.fusion.color).text(fusioncount);
985
- cell.append("span").text("Fusion");
986
- }
987
- }
988
- continue;
989
- }
990
- if (f.issampleattribute) {
991
- const value2count = /* @__PURE__ */ new Map();
992
- for (const sample of this.samples) {
993
- const anno = f.items.find((i) => i.sample == sample.name);
994
- if (anno) {
995
- value2count.set(anno.value, (value2count.get(anno.value) || 0) + 1);
996
- }
997
- }
998
- for (const [value, count] of value2count) {
999
- const cell = h.append("div").style("display", "inline-block").style("margin-right", "20px");
1000
- cell.append("span").attr("class", "sja_mcdot").style("background", f.values[value].color).text(count);
1001
- cell.append("span").text(f.values[value].name);
1002
- }
1003
- continue;
1004
- }
1005
- throw "unknown feature type in making legend";
1006
- }
1007
- this.makeGlobalCnvLohLegend();
1008
- }
1009
- makeGlobalCnvLohLegend() {
1010
- const legend_data = [
1011
- { type: "cnv", legend_label: "CNV log2(ratio): " },
1012
- { type: "loh", legend_label: "LOH seg.mean: " }
1013
- ];
1014
- const min_cnv_orig = parseFloat(this.min_cnv.toFixed(3));
1015
- const max_cnv_orig = parseFloat(this.max_cnv.toFixed(3));
1016
- const min_loh_orig = parseFloat(this.min_loh.toFixed(3));
1017
- const max_loh_orig = parseFloat(this.max_loh.toFixed(3));
1018
- let changed_flag = false;
1019
- legend_data.forEach((data) => {
1020
- let min_cutoff = data.type == "cnv" ? this.min_cnv : this.min_loh;
1021
- let max_cutoff = data.type == "cnv" ? this.max_cnv : this.max_loh;
1022
- const td = data.type == "cnv" ? this.legendtable.cnv_td : this.legendtable.loh_td;
1023
- const row = td.append("div").style("margin-bottom", "5px");
1024
- row.append("span").text(data.legend_label);
1025
- const lower_range_txt = row.append("span").text(min_cutoff.toFixed(3));
1026
- const lower_range_input = row.append("input").attr("type", "text").attr("size", 8).style("display", "none").property("value", min_cutoff.toFixed(3));
1027
- if (data.type == "cnv") {
1028
- row.append("div").style("margin", "4px 0 1px 10px").style("display", "inline-block").style("width", "50px").style("height", "15px").style("background", "linear-gradient( to right," + this.cnv_colorloss + ",white)");
1029
- }
1030
- row.append("div").style("margin", "4px 10px 1px 10px").style("margin-left", data.type == "cnv" ? "0" : "10px").style("display", "inline-block").style("width", data.type == "cnv" ? "50px" : "100px").style("height", "15px").style(
1031
- "background",
1032
- "linear-gradient( to right, white, " + (data.type == "cnv" ? this.cnv_colorgain : this.loh_color) + ")"
1033
- );
1034
- const upper_range_txt = row.append("span").text(max_cutoff.toFixed(3));
1035
- const upper_range_input = row.append("input").attr("type", "text").attr("size", 8).style("display", "none").property("value", max_cutoff.toFixed(3));
1036
- const edit_btn = row.append("button").style("margin", "2px 5px").style("padding", "3px 10px").text("Edit").on("click", () => {
1037
- lower_range_txt.style("display", "none");
1038
- upper_range_txt.style("display", "none");
1039
- lower_range_input.style("display", "inline-block");
1040
- upper_range_input.style("display", "inline-block");
1041
- edit_btn.style("display", "none");
1042
- submit_btn.style("display", "inline-block");
1043
- });
1044
- const submit_btn = row.append("button").style("display", "none").style("margin", "2px 5px").style("padding", "3px 10px").text("Submit").on("click", () => {
1045
- if (data.type == "cnv") {
1046
- this.min_cnv = min_cutoff = lower_range_input.property("value");
1047
- this.max_cnv = max_cutoff = upper_range_input.property("value");
1048
- if (this.min_cnv != min_cnv_orig || this.max_cnv != max_cnv_orig) changed_flag = true;
1049
- } else {
1050
- this.min_loh = min_cutoff = parseFloat(lower_range_input.property("value"));
1051
- this.max_loh = max_cutoff = parseFloat(upper_range_input.property("value"));
1052
- if (this.min_loh != min_loh_orig || this.max_loh != max_loh_orig) changed_flag = true;
1053
- }
1054
- lower_range_txt.style("display", "inline-block").text(parseFloat(min_cutoff).toFixed(3));
1055
- upper_range_txt.style("display", "inline-block").text(parseFloat(max_cutoff).toFixed(3));
1056
- lower_range_input.style("display", "none");
1057
- upper_range_input.style("display", "none");
1058
- edit_btn.style("display", "inline-block");
1059
- submit_btn.style("display", "none");
1060
- reset_btn.style("display", changed_flag ? "inline-block" : "none");
1061
- this.draw_matrix();
1062
- });
1063
- const reset_btn = row.append("button").style("display", "none").style("margin", "2px 5px").style("padding", "3px 10px").text("Reset").on("click", () => {
1064
- if (data.type == "cnv") {
1065
- this.min_cnv = min_cutoff = min_cnv_orig;
1066
- this.max_cnv = max_cutoff = max_cnv_orig;
1067
- } else {
1068
- this.min_loh = min_cutoff = min_loh_orig;
1069
- this.max_loh = max_cutoff = max_loh_orig;
1070
- }
1071
- lower_range_txt.text(parseFloat(min_cutoff).toFixed(3));
1072
- upper_range_txt.text(parseFloat(max_cutoff).toFixed(3));
1073
- lower_range_input.property("value", parseFloat(min_cutoff).toFixed(3));
1074
- upper_range_input.property("value", parseFloat(max_cutoff).toFixed(3));
1075
- reset_btn.style("display", "none");
1076
- changed_flag = false;
1077
- this.draw_matrix();
1078
- });
1079
- reset_btn.style("display", "none");
1080
- });
1081
- }
1082
- gatherSamplesFromFeatureData() {
1083
- const name2sample = /* @__PURE__ */ new Map();
1084
- for (const feature of this.features) {
1085
- if (feature.donotaddsample) {
1086
- continue;
1087
- }
1088
- if (feature.isgenevalue || feature.iscnv || feature.isloh || feature.isitd || feature.issvfusion || feature.issvcnv) {
1089
- for (const item of feature.items) {
1090
- if (!name2sample.has(item.sample)) {
1091
- name2sample.set(item.sample, {});
1092
- }
1093
- }
1094
- } else if (feature.isvcf) {
1095
- for (const m of feature.items) {
1096
- if (m.dt == dtsnvindel) {
1097
- if (!m.sampledata) continue;
1098
- for (const s of m.sampledata) {
1099
- if (!name2sample.has(s.sampleobj.name)) {
1100
- name2sample.set(s.sampleobj.name, {});
1101
- }
1102
- }
1103
- } else {
1104
- console.error("unsupported dt from isvcf: " + m.dt);
1105
- }
1106
- }
1107
- } else if (feature.ismutation) {
1108
- for (const m of feature.items) {
1109
- if (m.dt == dtsnvindel) {
1110
- if (!m.sampledata) continue;
1111
- for (const s of m.sampledata) {
1112
- if (!name2sample.has(s.sampleobj.name)) {
1113
- name2sample.set(s.sampleobj.name, {});
1114
- }
1115
- }
1116
- } else {
1117
- if (!m.sample) continue;
1118
- if (!name2sample.has(m.sample)) {
1119
- name2sample.set(m.sample, {});
1120
- }
1121
- }
1122
- }
1123
- } else if (feature.issampleattribute) {
1124
- for (const i of feature.items) {
1125
- if (!name2sample.has(i.sample)) {
1126
- name2sample.set(i.sample, {});
1127
- }
1128
- }
1129
- } else {
1130
- console.error("unknown feature type from this.data");
1131
- }
1132
- }
1133
- const uniformheight = Math.min(18, Math.max(1, Math.ceil(800 / name2sample.size)));
1134
- this.samples = [];
1135
- for (const [n, sample] of name2sample) {
1136
- if (!this.features_on_rows) sample.height = uniformheight;
1137
- else sample.width = uniformheight;
1138
- sample.name = n;
1139
- this.samples.push(sample);
1140
- }
1141
- }
1142
- /*********** __draw *****/
1143
- draw_matrix() {
1144
- this.svg.selectAll("*").remove();
1145
- const svgg = this.svg.append("g");
1146
- this.gatherSamplesFromFeatureData();
1147
- this.sortsamplesbyfeatures();
1148
- const rows_lst = this.features_on_rows ? this.features : this.samples;
1149
- const cols_lst = this.features_on_rows ? this.samples : this.features;
1150
- let y = 0, samplenamemaxwidth = 0;
1151
- for (const r of rows_lst) {
1152
- r.g = svgg.append("g").attr("transform", "translate(0," + y + ")");
1153
- y += r.height + this.rowspace;
1154
- if (r.height >= minheight2showname) {
1155
- r.g.append("text").attr("font-family", font).attr("font-size", Math.min(16, r.height)).attr("text-anchor", "end").attr("dominant-baseline", "central").attr("x", -this.rowlabspace - this.rowlabticksize).attr("y", r.height / 2).text(this.features_on_rows ? r.label + (r.count ? " (" + r.count + ")" : "") : r.name).each(function() {
1156
- samplenamemaxwidth = Math.max(samplenamemaxwidth, this.getBBox().width);
1157
- }).attr("class", "sja_clbtext").on("mouseover", () => {
1158
- this.features_on_rows ? this.showTip_feature(r) : this.showTip_sample(r);
1159
- }).on("mouseout", () => {
1160
- this.tip.hide();
1161
- }).on("click", () => {
1162
- if (this.features_on_rows) this.showMenu_feature(r);
1163
- });
1164
- r.g.append("line").attr("x1", -this.rowlabticksize).attr("y1", r.height / 2).attr("y2", r.height / 2).attr("stroke", "black").attr("shape-rendering", "crispEdges");
1165
- }
1166
- }
1167
- let x = 0, featurenamemaxwidth = 0;
1168
- for (const c of cols_lst) {
1169
- const g = svgg.append("g").attr("transform", "translate(" + (x + c.width / 2) + ",-" + (this.collabspace + this.collabticksize) + ")");
1170
- x += c.width + this.colspace;
1171
- const label = g.append("text").attr("font-family", font).attr("font-size", Math.min(16, c.width - 2)).attr("dominant-baseline", "central").attr("transform", "rotate(-90)").text(this.features_on_rows ? c.name : c.label + (c.count ? " (" + c.count + ")" : "")).each(function() {
1172
- featurenamemaxwidth = Math.max(featurenamemaxwidth, this.getBBox().width);
1173
- }).on("mouseover", () => {
1174
- this.features_on_rows ? this.showTip_sample(c) : this.showTip_feature(c);
1175
- }).on("mouseout", () => {
1176
- this.tip.hide();
1177
- }).on("click", () => {
1178
- if (!this.features_on_rows) this.showMenu_feature(c);
1179
- });
1180
- if (c.isgenevalue) {
1181
- label.attr("fill", c.color);
1182
- }
1183
- g.append("line").attr("y1", this.collabspace).attr("y2", this.collabspace + this.collabticksize).attr("stroke", "black").attr("shape-rendering", "crispEdges");
1184
- }
1185
- for (const r of rows_lst) {
1186
- let x2 = 0;
1187
- for (const c of cols_lst) {
1188
- const sample = this.features_on_rows ? c : r;
1189
- const feature = this.features_on_rows ? r : c;
1190
- const cell = r.g.append("g").attr("transform", "translate(" + x2 + ",0)");
1191
- x2 += c.width + this.colspace;
1192
- if (feature.isgenevalue) {
1193
- this.drawCell_isgenevalue(sample, feature, cell);
1194
- } else if (feature.iscnv) {
1195
- this.drawCell_iscnv(sample, feature, cell);
1196
- } else if (feature.isloh) {
1197
- this.drawCell_isloh(sample, feature, cell);
1198
- } else if (feature.isvcf) {
1199
- this.drawCell_isvcf(sample, feature, cell);
1200
- } else if (feature.isitd) {
1201
- this.drawCell_isitd(sample, feature, cell);
1202
- } else if (feature.issvfusion) {
1203
- this.drawCell_issvfusion(sample, feature, cell);
1204
- } else if (feature.issvcnv || feature.ismutation) {
1205
- this.drawCell_ismutation(sample, feature, cell);
1206
- } else if (feature.issampleattribute) {
1207
- this.drawCell_issampleattribute(sample, feature, cell);
1208
- } else {
1209
- console.error("unknown feature type when drawing cell");
1210
- }
1211
- }
1212
- }
1213
- svgg.attr(
1214
- "transform",
1215
- "translate(" + (samplenamemaxwidth + this.rowlabspace + this.rowlabticksize) + "," + (featurenamemaxwidth + this.collabspace + this.collabticksize) + ")"
1216
- );
1217
- this.svg.attr(
1218
- "width",
1219
- samplenamemaxwidth + this.rowlabspace + this.rowlabticksize + cols_lst.reduce((i, j) => i + j.width, 0) + cols_lst.length * this.colspace
1220
- ).attr(
1221
- "height",
1222
- featurenamemaxwidth + this.collabspace + this.collabticksize + rows_lst.reduce((i, j) => i + j.height, 0) + rows_lst.length * this.rowspace
1223
- );
1224
- }
1225
- drawCell_isgenevalue(sample, feature, g) {
1226
- const height = this.features_on_rows ? feature.height : sample.height;
1227
- const width = this.features_on_rows ? sample.width : feature.width;
1228
- const item = feature.items.find((i) => i.sample == sample.name);
1229
- if (!item) {
1230
- this.drawEmptycell(sample, feature, g);
1231
- return;
1232
- }
1233
- const rect = g.append("rect").attr("width", width).attr("height", height).attr("fill", feature.color).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1234
- event2.target.setAttribute("stroke-opacity", 1);
1235
- this.showTip_cell(sample, feature);
1236
- }).on("mouseout", (event2) => {
1237
- event2.target.setAttribute("stroke-opacity", 0);
1238
- this.tip.hide();
1239
- }).on("click", () => {
1240
- this.click_cell(sample, feature);
1241
- });
1242
- if (item.value < feature.scale.maxv) {
1243
- rect.attr("fill-opacity", item.value / feature.scale.maxv);
1244
- }
1245
- }
1246
- drawCell_iscnv(sample, feature, g) {
1247
- const height = this.features_on_rows ? feature.height : sample.height;
1248
- const width = this.features_on_rows ? sample.width : feature.width;
1249
- const items = feature.items.filter((i) => i.sample == sample.name);
1250
- if (items.length == 0) {
1251
- this.drawEmptycell(sample, feature, g);
1252
- return;
1253
- }
1254
- for (const item of items) {
1255
- const x1 = feature.coordscale(Math.max(feature.start, item.start));
1256
- const x2 = feature.coordscale(Math.min(feature.stop, item.stop));
1257
- const maxabslogratio = this.max_cnv;
1258
- g.append("rect").attr("x", x1).attr("width", Math.max(1, x2 - x1)).attr("height", sample.height).attr("fill", item.value > 0 ? feature.colorgain : feature.colorloss).attr("fill-opacity", Math.abs(item.value / maxabslogratio)).attr("shape-rendering", "crispEdges");
1259
- }
1260
- g.append("rect").attr("fill", "white").attr("fill-opacity", 0).attr("width", width).attr("height", height).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1261
- event2.target.setAttribute("stroke-opacity", 1);
1262
- this.showTip_cell(sample, feature);
1263
- }).on("mouseout", (event2) => {
1264
- event2.target.setAttribute("stroke-opacity", 0);
1265
- this.tip.hide();
1266
- }).on("click", () => {
1267
- this.click_cell(sample, feature);
1268
- });
1269
- }
1270
- drawCell_isloh(sample, feature, g) {
1271
- const height = this.features_on_rows ? feature.height : sample.height;
1272
- const width = this.features_on_rows ? sample.width : feature.width;
1273
- const items = feature.items.filter((i) => i.sample == sample.name);
1274
- if (items.length == 0) {
1275
- this.drawEmptycell(sample, feature, g);
1276
- return;
1277
- }
1278
- for (const item of items) {
1279
- const x1 = feature.coordscale(Math.max(feature.start, item.start));
1280
- const x2 = feature.coordscale(Math.min(feature.stop, item.stop));
1281
- const loh_range = this.max_loh - this.min_loh;
1282
- g.append("rect").attr("x", this.features_on_rows ? 0 : x1).attr("y", this.features_on_rows ? x1 : 0).attr("width", this.features_on_rows ? width : Math.max(1, x2 - x1)).attr("height", this.features_on_rows ? Math.max(1, x2 - x1) : height).attr("fill", feature.color).attr("fill-opacity", (item.segmean - this.min_loh) / loh_range).attr("shape-rendering", "crispEdges");
1283
- }
1284
- g.append("rect").attr("fill", "white").attr("fill-opacity", 0).attr("width", width).attr("height", height).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1285
- event2.target.setAttribute("stroke-opacity", 1);
1286
- this.showTip_cell(sample, feature);
1287
- }).on("mouseout", (event2) => {
1288
- event2.target.setAttribute("stroke-opacity", 0);
1289
- this.tip.hide();
1290
- }).on("click", () => {
1291
- this.click_cell(sample, feature);
1292
- });
1293
- }
1294
- drawCell_isvcf(sample, feature, g) {
1295
- const height = this.features_on_rows ? feature.height : sample.height;
1296
- const width = this.features_on_rows ? sample.width : feature.width;
1297
- const mlst = getitemforsample_vcf(feature, sample);
1298
- if (mlst.length == 0) {
1299
- this.drawEmptycell(sample, feature, g);
1300
- return;
1301
- }
1302
- const class2count = /* @__PURE__ */ new Map();
1303
- for (const m of mlst) {
1304
- if (!class2count.has(m.class)) {
1305
- class2count.set(m.class, 0);
1306
- }
1307
- class2count.set(m.class, class2count.get(m.class) + 1);
1308
- }
1309
- let start = 0;
1310
- for (const [cname, count] of class2count) {
1311
- const span = count / mlst.length * this.features_on_rows ? height : width;
1312
- g.append("rect").attr("x", this.features_on_rows ? 0 : start).attr("y", this.features_on_rows ? start : 0).attr("width", this.features_on_rows ? width : span).attr("height", this.features_on_rows ? span : height).attr("fill", mclass[cname].color).attr("shape-rendering", "crispEdges");
1313
- start += span;
1314
- }
1315
- g.append("rect").attr("fill", "white").attr("fill-opacity", 0).attr("width", width).attr("height", height).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1316
- event2.target.setAttribute("stroke-opacity", 1);
1317
- this.showTip_cell(sample, feature);
1318
- }).on("mouseout", (event2) => {
1319
- event2.target.setAttribute("stroke-opacity", 0);
1320
- this.tip.hide();
1321
- }).on("click", () => {
1322
- this.click_cell(sample, feature);
1323
- });
1324
- }
1325
- drawCell_isitd(sample, feature, g) {
1326
- const height = this.features_on_rows ? feature.height : sample.height;
1327
- const width = this.features_on_rows ? sample.width : feature.width;
1328
- const item = feature.items.find((i) => i.sample == sample.name);
1329
- if (!item) {
1330
- this.drawEmptycell(sample, feature, g);
1331
- return;
1332
- }
1333
- g.append("rect").attr("width", width).attr("height", height).attr("fill", feature.color).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1334
- event2.target.setAttribute("stroke-opacity", 1);
1335
- this.showTip_cell(sample, feature);
1336
- }).on("mouseout", (event2) => {
1337
- event2.target.setAttribute("stroke-opacity", 0);
1338
- this.tip.hide();
1339
- }).on("click", () => {
1340
- this.click_cell(sample, feature);
1341
- });
1342
- }
1343
- drawCell_issampleattribute(sample, feature, g) {
1344
- const height = this.features_on_rows ? feature.height : sample.height;
1345
- const width = this.features_on_rows ? sample.width : feature.width;
1346
- const item = feature.items.find((i) => i.sample == sample.name);
1347
- if (!item) {
1348
- this.drawEmptycell(sample, feature, g);
1349
- return;
1350
- }
1351
- g.append("rect").attr("width", width).attr("height", height).attr("fill", feature.values[item.value].color).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1352
- event2.target.setAttribute("stroke-opacity", 1);
1353
- this.showTip_cell(sample, feature);
1354
- }).on("mouseout", (event2) => {
1355
- event2.target.setAttribute("stroke-opacity", 0);
1356
- this.tip.hide();
1357
- }).on("click", () => {
1358
- this.click_cell(sample, feature);
1359
- });
1360
- }
1361
- drawCell_issvfusion(sample, feature, g) {
1362
- const height = this.features_on_rows ? feature.height : sample.height;
1363
- const width = this.features_on_rows ? sample.width : feature.width;
1364
- const item = feature.items.find((i) => i.sample == sample.name);
1365
- if (!item) {
1366
- this.drawEmptycell(sample, feature, g);
1367
- return;
1368
- }
1369
- g.append("rect").attr("width", width).attr("height", height).attr("fill", feature.color).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1370
- event2.target.setAttribute("stroke-opacity", 1);
1371
- this.showTip_cell(sample, feature);
1372
- }).on("mouseout", (event2) => {
1373
- event2.target.setAttribute("stroke-opacity", 0);
1374
- this.tip.hide();
1375
- }).on("click", () => {
1376
- this.click_cell(sample, feature);
1377
- });
1378
- }
1379
- drawCell_ismutation(sample, feature, g) {
1380
- const [cnv, loh, itd, sv, fusion, snvindel] = getitemforsample_compound(feature, sample);
1381
- const height = this.features_on_rows ? feature.height : sample.height;
1382
- const width = this.features_on_rows ? sample.width : feature.width;
1383
- if (cnv.length + loh.length + itd.length + sv.length + fusion.length + snvindel.length == 0) {
1384
- this.drawEmptycell(sample, feature, g);
1385
- return;
1386
- }
1387
- let is_symbolic = false;
1388
- if (this.ismutation_allsymbolic) {
1389
- is_symbolic = true;
1390
- } else if (this.ismutation_allnotsymbolic) {
1391
- } else {
1392
- if (height <= 4) {
1393
- is_symbolic = true;
1394
- }
1395
- }
1396
- if (is_symbolic) {
1397
- this.drawCell_ismutation_symbolic(sample, feature, g, cnv, loh, itd, sv, fusion, snvindel);
1398
- } else {
1399
- if (loh.length) {
1400
- for (const item of loh) {
1401
- const x1 = feature.coordscale(Math.max(feature.start, item.start));
1402
- const x2 = feature.coordscale(Math.min(feature.stop, item.stop));
1403
- const loh_range = this.max_loh - this.min_loh;
1404
- g.append("rect").attr("x", this.features_on_rows ? 0 : x1).attr("y", this.features_on_rows ? x1 : 0).attr("width", this.features_on_rows ? width : Math.max(1, x2 - x1)).attr("height", this.features_on_rows ? Math.max(1, x2 - x1) : height).attr("fill", feature.loh.color).attr("fill-opacity", (item.segmean - this.min_loh) / loh_range).attr("shape-rendering", "crispEdges");
1405
- }
1406
- }
1407
- if (cnv.length) {
1408
- for (const item of cnv) {
1409
- const x1 = feature.coordscale(Math.max(feature.start, item.start));
1410
- const x2 = feature.coordscale(Math.min(feature.stop, item.stop));
1411
- const maxabslogratio = item.value > 0 ? this.max_cnv : this.min_cnv;
1412
- g.append("rect").attr("x", this.features_on_rows ? 0 : x1).attr("y", this.features_on_rows ? x1 : 0).attr("width", this.features_on_rows ? width : Math.max(1, x2 - x1)).attr("height", this.features_on_rows ? Math.max(1, x2 - x1) : height).attr("fill", item.value > 0 ? feature.cnv.colorgain : feature.cnv.colorloss).attr("fill-opacity", Math.abs(item.value / maxabslogratio)).attr("shape-rendering", "crispEdges");
1413
- }
1414
- }
1415
- if (itd.length) {
1416
- for (const item of itd) {
1417
- const x1 = feature.coordscale(Math.max(feature.start, item.start));
1418
- const x2 = feature.coordscale(Math.min(feature.stop, item.stop));
1419
- g.append("rect").attr("x", this.features_on_rows ? 0 : x1).attr("y", this.features_on_rows ? x1 : 0).attr("width", this.features_on_rows ? width : Math.max(1, x2 - x1)).attr("height", this.features_on_rows ? Math.max(1, x2 - x1) : height).attr("fill", feature.itd.color).attr("shape-rendering", "crispEdges");
1420
- }
1421
- }
1422
- if (sv.length) {
1423
- g.append("circle").attr("cx", width / 2).attr("cy", height / 2).attr("r", Math.min(width, height) / 2).attr("stroke", feature.sv.color).attr("fill", "none");
1424
- }
1425
- if (fusion.length) {
1426
- g.append("circle").attr("cx", width / 2).attr("cy", height / 2).attr("r", Math.min(width, height) / 2).attr("stroke", feature.fusion.color).attr("fill", "none");
1427
- }
1428
- if (snvindel.length) {
1429
- const m = snvindel[0];
1430
- const g2 = g.append("g").attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");
1431
- const color = mclass[m.m.class].color;
1432
- const w = Math.min(width, height) / 2;
1433
- g2.append("line").attr("x1", -w).attr("x2", w).attr("y1", -w).attr("y2", w).attr("stroke", "white").attr("stroke-width", 3);
1434
- g2.append("line").attr("x1", -w).attr("x2", w).attr("y1", w).attr("y2", -w).attr("stroke", "white").attr("stroke-width", 3);
1435
- g2.append("line").attr("x1", -w).attr("x2", w).attr("y1", -w).attr("y2", w).attr("stroke", color);
1436
- g2.append("line").attr("x1", -w).attr("x2", w).attr("y1", w).attr("y2", -w).attr("stroke", color);
1437
- }
1438
- }
1439
- g.append("rect").attr("width", width).attr("height", height).attr("fill", "white").attr("fill-opacity", 0).attr("stroke", "#ccc").attr("stroke-opacity", 0).attr("shape-rendering", "crispEdges").on("mouseover", (event2) => {
1440
- event2.target.setAttribute("stroke-opacity", 1);
1441
- this.showTip_cell(sample, feature);
1442
- }).on("mouseout", (event2) => {
1443
- event2.target.setAttribute("stroke-opacity", 0);
1444
- this.tip.hide();
1445
- }).on("click", () => {
1446
- this.click_cell(sample, feature);
1447
- });
1448
- }
1449
- drawCell_ismutation_symbolic(sample, feature, g, cnv, loh, itd, sv, fusion, snvindel) {
1450
- const height = this.features_on_rows ? feature.height : sample.height;
1451
- const width = this.features_on_rows ? sample.width : feature.width;
1452
- const loh_range = this.max_loh - this.min_loh;
1453
- const lst = [];
1454
- if (cnv.length) {
1455
- for (const i of cnv) {
1456
- const maxabslogratio = i.value > 0 ? this.max_cnv : this.min_cnv;
1457
- let k;
1458
- if (i.value > 0) {
1459
- k = { color: feature.cnv.colorgain };
1460
- } else {
1461
- k = { color: feature.cnv.colorloss };
1462
- }
1463
- k.opacity = Math.abs(i.value / maxabslogratio);
1464
- lst.push(k);
1465
- }
1466
- }
1467
- if (loh.length) {
1468
- for (const i of loh) {
1469
- lst.push({
1470
- color: feature.loh.color,
1471
- opacity: (i.segmean - this.min_loh) / loh_range
1472
- });
1473
- }
1474
- }
1475
- if (itd.length) {
1476
- for (const i of itd) {
1477
- lst.push({ color: feature.itd.color });
1478
- }
1479
- }
1480
- if (sv.length) {
1481
- for (const i of sv) {
1482
- lst.push({ color: feature.sv.color });
1483
- }
1484
- }
1485
- if (fusion.length) {
1486
- for (const i of fusion) {
1487
- lst.push({ color: feature.fusion.color });
1488
- }
1489
- }
1490
- if (snvindel.length) {
1491
- for (const i of snvindel) {
1492
- lst.push({ color: mclass[i.m.class].color });
1493
- }
1494
- }
1495
- const f_len = this.features_on_rows ? height / lst.length : width / lst.length;
1496
- let f_start = 0;
1497
- for (const i of lst) {
1498
- const r = g.append("rect").attr("x", this.features_on_rows ? 0 : f_start).attr("y", this.features_on_rows ? f_start : 0).attr("width", this.features_on_rows ? width : f_len).attr("height", this.features_on_rows ? f_len : height).attr("fill", i.color).attr("shape-rendering", "crispEdges");
1499
- if (i.opacity) r.attr("opacity", i.opacity);
1500
- f_start += f_len;
1501
- }
1502
- }
1503
- // __newattr draw cell for new feature
1504
- /*********** __draw ends *****/
1505
- async click_cell(sample, feature) {
1506
- try {
1507
- let svcnvtk;
1508
- if (this.iscustom) {
1509
- svcnvtk = {
1510
- iscustom: true,
1511
- type: tkt.mdssvcnv,
1512
- singlesample: {
1513
- name: sample.name
1514
- }
1515
- };
1516
- for (const k in this.querykey2tracks) {
1517
- const t = this.querykey2tracks[k];
1518
- if (t.type == tkt.mdssvcnv) {
1519
- svcnvtk.name = t.name || "Custom tk";
1520
- svcnvtk.file = t.file;
1521
- svcnvtk.url = t.url;
1522
- svcnvtk.indexURL = t.indexURL;
1523
- } else if (t.type == tkt.mdsvcf) {
1524
- svcnvtk.checkvcf = {
1525
- file: t.file,
1526
- url: t.url,
1527
- indexURL: t.indexURL
1528
- };
1529
- } else if (t.type == tkt.mdsexpression) {
1530
- svcnvtk.checkexpressionrank = {
1531
- file: t.file,
1532
- url: t.url,
1533
- indexURL: t.indexURL
1534
- };
1535
- }
1536
- }
1537
- } else {
1538
- if (!this.mds) throw "not custom but .mds{} missing";
1539
- for (const querykey in this.mds.queries) {
1540
- const tk = this.mds.queries[querykey];
1541
- if (tk.type == tkt.mdssvcnv) {
1542
- svcnvtk = {
1543
- mds: this.mds,
1544
- querykey,
1545
- singlesample: {
1546
- name: sample.name
1547
- }
1548
- };
1549
- for (const k in tk) svcnvtk[k] = tk[k];
1550
- break;
1551
- }
1552
- }
1553
- }
1554
- if (!svcnvtk) throw "cannot find a svcnv tk";
1555
- svcnvtk.bplengthUpperLimit = 0;
1556
- const pane = newpane({ x: 100, y: 100 });
1557
- const blockarg = {
1558
- jwt: this.jwt,
1559
- hostURL: this.hostURL,
1560
- nobox: 1,
1561
- genome: this.genome,
1562
- holder: pane.body,
1563
- chr: feature.chr,
1564
- start: feature.start,
1565
- stop: feature.stop,
1566
- tklst: []
1567
- };
1568
- first_genetrack_tolist(this.genome, blockarg.tklst);
1569
- blockarg.tklst.push(svcnvtk);
1570
- if (!this.iscustom) {
1571
- if (!this.dslabel) throw "not custom but dslabel missing";
1572
- const par = {
1573
- genome: this.genome.name,
1574
- dslabel: this.dslabel,
1575
- querykey: svcnvtk.querykey,
1576
- gettrack4singlesample: sample.name
1577
- };
1578
- const data = await dofetch("/mdssvcnv", par);
1579
- if (data.error) throw "Error checking for assay track: " + data.error;
1580
- if (data.tracks) {
1581
- for (const t of data.tracks) blockarg.tklst.push(t);
1582
- }
1583
- }
1584
- const _ = await import("./block-B7WMYLPO.js");
1585
- new _.Block(blockarg);
1586
- } catch (e) {
1587
- window.alert(e.message || e);
1588
- if (e.stack) console.log(e.stack);
1589
- }
1590
- }
1591
- /********** __menu and tooltip **********/
1592
- showTip_feature(f) {
1593
- this.tip.clear();
1594
- this.tipContent_feature(f, this.tip.d);
1595
- this.tip.showunder(event.target);
1596
- }
1597
- showMenu_feature(f) {
1598
- this.menu.showunder(event.target).clear();
1599
- this.tipContent_feature(f, this.menu.d);
1600
- this.menu.d.append("div").attr("class", "sja_menuoption").text("Remove this feature").on("click", () => {
1601
- this.menu.hide();
1602
- f.legend_tr.remove();
1603
- this.features.splice(
1604
- this.features.findIndex((i) => i.id == f.id),
1605
- 1
1606
- );
1607
- this.draw_matrix();
1608
- });
1609
- if (f.isgenevalue) return showMenu_isgenevalue(this, f);
1610
- if (f.iscnv) return showMenu_iscnv(this, f, f);
1611
- if (f.isloh) return showMenu_isloh(this, f, f);
1612
- if (f.ismutation) return showMenu_ismutation(this, f);
1613
- if (f.isitd) {
1614
- return;
1615
- }
1616
- if (f.issvfusion) {
1617
- return;
1618
- }
1619
- if (f.issvcnv) {
1620
- return;
1621
- }
1622
- if (f.issampleattribute) {
1623
- return;
1624
- }
1625
- }
1626
- tipContent_feature(f, holder) {
1627
- holder.append("div").text(f.label).style("opacity", 0.5).style("font-size", ".7em").style("margin", "10px");
1628
- if (f.isgenevalue || f.iscnv || f.isloh || f.isitd || f.issvfusion) {
1629
- holder.append("div").html(f.chr + ":" + f.start + "-" + f.stop + " &nbsp; " + bplen(f.stop - f.start)).style("font-size", ".7em").style("opacity", 0.5).style("margin", "0px 10px 10px 10px");
1630
- } else if (f.issvcnv || f.ismutation) {
1631
- if (!f.genename) {
1632
- holder.append("div").html(f.chr + ":" + f.start + "-" + f.stop + " &nbsp; " + bplen(f.stop - f.start)).style("font-size", ".7em").style("opacity", 0.5).style("margin", "0px 10px 10px 10px");
1633
- }
1634
- } else if (f.issampleattribute) {
1635
- holder.append("div").text(f.label);
1636
- }
1637
- if (f.isgenevalue) {
1638
- holder.append("div").text("Min: " + f.scale.minv + ", max: " + f.scale.maxv).style("font-size", ".7em").style("opacity", 0.5).style("margin", "0px 10px 10px 10px");
1639
- }
1640
- }
1641
- showTip_sample(sample) {
1642
- this.tip.clear().d.append("div").text(sample.name).style("padding", "10px").style("font-size", ".7em");
1643
- const lst = [];
1644
- for (const f of this.features) {
1645
- if (lst.length > 10) {
1646
- lst.push({ k: "more", v: "..." });
1647
- break;
1648
- }
1649
- if (f.isgenevalue) {
1650
- const v = f.items.find((i) => i.sample == sample.name);
1651
- lst.push({ k: f.label, v: v ? v.value : saynovalue });
1652
- continue;
1653
- }
1654
- if (f.iscnv) {
1655
- const items = f.items.filter((i) => i.sample == sample.name);
1656
- let text;
1657
- if (items.length == 0) {
1658
- text = saynovalue;
1659
- } else {
1660
- const lst2 = items.map((i) => {
1661
- return "<div>" + i.chr + ":" + i.start + "-" + i.stop + ' <span style="font-size:.7em">' + bplen(i.stop - i.start) + '</span> <span style="font-size:.8em;background:' + (i.value > 0 ? f.colorgain : f.colorloss) + ';color:white;padding:1px 5px">' + i.value + "</span></div>";
1662
- });
1663
- text = lst2.join("");
1664
- }
1665
- lst.push({ k: f.label, v: text });
1666
- continue;
1667
- }
1668
- if (f.isloh) {
1669
- const items = f.items.filter((i) => i.sample == sample.name);
1670
- let text;
1671
- if (items.length == 0) {
1672
- text = saynovalue;
1673
- } else {
1674
- const lst2 = items.map((i) => {
1675
- return "<div>" + i.chr + ":" + i.start + "-" + i.stop + ' <span style="font-size:.7em">' + bplen(i.stop - i.start) + '</span> <span style="font-size:.8em;background:' + f.color + ';color:white;padding:1px 5px">' + i.segmean + "</span></div>";
1676
- });
1677
- text = lst2.join("");
1678
- }
1679
- lst.push({ k: f.label, v: text });
1680
- continue;
1681
- }
1682
- if (f.isvcf) {
1683
- const mlst = getitemforsample_vcf(f, sample);
1684
- let text;
1685
- if (mlst.length == 0) {
1686
- text = saynovalue;
1687
- } else {
1688
- text = mlst.map((m) => {
1689
- return '<div><span style="color:' + mclass[m.class].color + '">' + m.mname + '</span> <span style="font-size:.7em;opacity:.5">' + mclass[m.class].label + "</span></div>";
1690
- }).join("");
1691
- }
1692
- lst.push({ k: f.label, v: text });
1693
- continue;
1694
- }
1695
- if (f.isitd) {
1696
- const items = f.items.filter((i) => i.sample == sample.name);
1697
- let text;
1698
- if (items.length == 0) {
1699
- text = saynovalue;
1700
- } else {
1701
- text = '<div style="background:' + f.color + ';width:20px">&nbsp;</div>';
1702
- }
1703
- lst.push({ k: f.label, v: text });
1704
- continue;
1705
- }
1706
- if (f.issvfusion) {
1707
- const items = f.items.filter((i) => i.sample == sample.name);
1708
- let text;
1709
- if (items.length == 0) {
1710
- text = saynovalue;
1711
- } else {
1712
- text = '<div style="background:' + f.color + ';width:20px">&nbsp;</div>';
1713
- }
1714
- lst.push({ k: f.label, v: text });
1715
- continue;
1716
- }
1717
- if (f.issvcnv) {
1718
- continue;
1719
- }
1720
- if (f.ismutation) {
1721
- continue;
1722
- }
1723
- if (f.issampleattribute) {
1724
- const item = f.items.find((i) => i.sample == sample.name);
1725
- if (item) {
1726
- lst.push({ k: f.label, v: item.value });
1727
- }
1728
- continue;
1729
- }
1730
- console.error("sample tooltip: Unknown feature type");
1731
- }
1732
- make_table_2col(this.tip.d, lst);
1733
- this.tip.show(event.clientX, event.clientY);
1734
- }
1735
- showTip_cell(sample, f) {
1736
- const lst = [{ k: "sample", v: sample.name }];
1737
- if (f.isgenevalue) {
1738
- const v = f.items.find((i) => i.sample == sample.name);
1739
- lst.push({ k: f.label, v: v ? v.value : saynovalue });
1740
- } else if (f.iscnv) {
1741
- const items = f.items.filter((i) => i.sample == sample.name);
1742
- let text;
1743
- if (items.length == 0) {
1744
- text = saynovalue;
1745
- } else {
1746
- const lst2 = items.map((i) => {
1747
- return "<div>" + i.chr + ":" + i.start + "-" + i.stop + ' <span style="font-size:.7em">' + bplen(i.stop - i.start) + '</span> <span style="font-size:.8em;background:' + (i.value > 0 ? f.colorgain : f.colorloss) + ';color:white;padding:1px 5px">' + i.value + "</span></div>";
1748
- });
1749
- text = lst2.join("");
1750
- }
1751
- lst.push({ k: f.label, v: text });
1752
- } else if (f.isloh) {
1753
- const items = f.items.filter((i) => i.sample == sample.name);
1754
- let text;
1755
- if (items.length == 0) {
1756
- text = saynovalue;
1757
- } else {
1758
- const lst2 = items.map((i) => {
1759
- return "<div>" + i.chr + ":" + i.start + "-" + i.stop + ' <span style="font-size:.7em">' + bplen(i.stop - i.start) + '</span> <span style="font-size:.8em;background:' + f.color + ';color:white;padding:1px 5px">' + i.segmean + "</span></div>";
1760
- });
1761
- text = lst2.join("");
1762
- }
1763
- lst.push({ k: f.label, v: text });
1764
- } else if (f.isvcf) {
1765
- const mlst = getitemforsample_vcf(f, sample);
1766
- let text;
1767
- if (mlst.length == 0) {
1768
- text = saynovalue;
1769
- } else {
1770
- text = mlst.map((m) => {
1771
- return '<div><span style="color:' + mclass[m.class].color + '">' + m.mname + '</span> <span style="font-size:.7em;opacity:.5">' + mclass[m.class].label + "</span></div>";
1772
- }).join("");
1773
- }
1774
- lst.push({ k: f.label, v: text });
1775
- } else if (f.isitd) {
1776
- const items = f.items.filter((i) => i.sample == sample.name);
1777
- let text;
1778
- if (items.length == 0) {
1779
- text = saynovalue;
1780
- } else {
1781
- const lst2 = items.map((i) => {
1782
- return "<div>" + i.chr + ":" + i.start + "-" + i.stop + " </div>";
1783
- });
1784
- text = lst2.join("");
1785
- }
1786
- lst.push({ k: f.label, v: text });
1787
- } else if (f.issvfusion) {
1788
- const items = f.items.filter((i) => i.sample == sample.name);
1789
- let text;
1790
- if (items.length == 0) {
1791
- text = saynovalue;
1792
- } else {
1793
- const lst2 = items.map((i) => {
1794
- return "<div>" + i.chrA + ":" + i.posA + " - " + i.chrB + ":" + i.posB + " </div>";
1795
- });
1796
- text = lst2.join("");
1797
- }
1798
- lst.push({ k: f.label, v: text });
1799
- } else if (f.issvcnv || f.ismutation) {
1800
- const [cnv, loh, itd, sv, fusion, snvindel] = getitemforsample_compound(f, sample);
1801
- if (cnv.length) {
1802
- lst.push({
1803
- k: (f.genename || f.label) + " CNV",
1804
- v: cnv.map((i) => {
1805
- return '<div><span style="background:' + (i.value > 0 ? f.cnv.colorgain : f.cnv.colorloss) + ';color:white;padding:0px 3px">' + i.value + '</span> <span style="font-size:.8em">' + i.chr + ":" + i.start + "-" + i.stop + " &nbsp;&nbsp;" + bplen(i.stop - i.start) + "</span></div>";
1806
- }).join("")
1807
- });
1808
- }
1809
- if (loh.length) {
1810
- lst.push({
1811
- k: (f.genename || f.label) + " LOH",
1812
- v: loh.map((i) => {
1813
- return '<div><span style="background:' + f.loh.color + ';color:white;padding:0px 3px">' + i.segmean + '</span> <span style="font-size:.8em">' + i.chr + ":" + i.start + "-" + i.stop + " &nbsp;&nbsp;" + bplen(i.stop - i.start) + "</span></div>";
1814
- }).join("")
1815
- });
1816
- }
1817
- if (itd.length) {
1818
- lst.push({
1819
- k: (f.genename || f.label) + " ITD",
1820
- v: itd.map((i) => {
1821
- return '<div style="font-size:.8em">' + i.chr + ":" + i.start + "-" + i.stop + "</div>";
1822
- }).join("")
1823
- });
1824
- }
1825
- if (sv.length) {
1826
- lst.push({
1827
- k: (f.genename || f.label) + " SV",
1828
- v: sv.map((i) => {
1829
- return "<div>" + i.chrA + ":" + i.posA + "," + i.strandA + " &gt; " + i.chrB + ":" + i.posB + "," + i.strandB + "</div>";
1830
- }).join("")
1831
- });
1832
- }
1833
- if (fusion.length) {
1834
- lst.push({
1835
- k: (f.genename || f.label) + " fusion",
1836
- v: fusion.map((i) => {
1837
- return "<div>" + i.chrA + ":" + i.posA + "," + i.strandA + " &gt; " + i.chrB + ":" + i.posB + "," + i.strandB + "</div>";
1838
- }).join("")
1839
- });
1840
- }
1841
- if (snvindel.length) {
1842
- lst.push({
1843
- k: (f.genename || f.label) + " SNV/indel",
1844
- v: snvindel.map((m) => {
1845
- const c = mclass[m.m.class];
1846
- return '<div><span style="color:' + c.color + '">' + (m.m.mname || "") + '</span> <span style="font-size:.7em;opacity:.5">' + c.label + "</span></div>";
1847
- }).join("")
1848
- });
1849
- }
1850
- } else if (f.issampleattribute) {
1851
- const item = f.items.find((i) => i.sample == sample.name);
1852
- if (item) {
1853
- lst.push({
1854
- k: f.label,
1855
- v: item.value
1856
- });
1857
- }
1858
- } else {
1859
- console.error("cell tooltip: unknown feature type");
1860
- }
1861
- this.tip.clear();
1862
- make_table_2col(this.tip.d, lst);
1863
- this.tip.show(event.clientX, event.clientY);
1864
- }
1865
- /********** __menu ends **********/
1866
- sortsamplesbyfeatures() {
1867
- const sortbygenevalue = this.features.find((f) => f.isgenevalue && f.sort);
1868
- if (sortbygenevalue && sortbygenevalue.items) {
1869
- const sample2value = /* @__PURE__ */ new Map();
1870
- for (const i of sortbygenevalue.items) {
1871
- sample2value.set(i.sample, i.value);
1872
- }
1873
- this.samples.sort((i, j) => {
1874
- const vi = sample2value.has(i.name) ? sample2value.get(i.name) : sortbygenevalue.missingvalue;
1875
- const vj = sample2value.has(j.name) ? sample2value.get(j.name) : sortbygenevalue.missingvalue;
1876
- return vj - vi;
1877
- });
1878
- }
1879
- }
1880
- may_init_customvcf(tk) {
1881
- if (tk.info) return;
1882
- const arg = ["genome=" + this.genome.name];
1883
- if (tk.file) {
1884
- arg.push("file=" + tk.file);
1885
- } else {
1886
- arg.push("url=" + tk.url);
1887
- if (tk.indexURL) arg.push("indexURL=" + tk.indexURL);
1888
- }
1889
- return dofetch2("vcfheader?" + arg.join("&")).then((data) => {
1890
- const [info, format, samples, errs] = vcfparsemeta(data.metastr.split("\n"));
1891
- if (errs) throw "Error parsing VCF meta lines: " + errs.join("; ");
1892
- tk.info = info;
1893
- tk.format = format;
1894
- tk.samples = samples;
1895
- tk.nochr = data.nochr;
1896
- });
1897
- }
1898
- drawEmptycell(sample, feature, g) {
1899
- const height = this.features_on_rows ? feature.height : sample.height;
1900
- const width = this.features_on_rows ? sample.width : feature.width;
1901
- if (height < 5) return;
1902
- g.append("line").attr("x2", width).attr("y2", height).attr("stroke", "#ededed");
1903
- }
1904
- // end of class
1905
- };
1906
- function feature2arg(f) {
1907
- if (f.isgenevalue) {
1908
- return {
1909
- id: f.id,
1910
- isgenevalue: 1,
1911
- querykey: f.querykey,
1912
- genename: f.genename,
1913
- chr: f.chr,
1914
- start: f.start,
1915
- stop: f.stop
1916
- };
1917
- }
1918
- if (f.iscnv) {
1919
- return {
1920
- id: f.id,
1921
- iscnv: 1,
1922
- querykey: f.querykey,
1923
- chr: f.chr,
1924
- start: f.start,
1925
- stop: f.stop,
1926
- valuecutoff: f.valuecutoff,
1927
- focalsizelimit: f.focalsizelimit
1928
- };
1929
- }
1930
- if (f.isloh) {
1931
- return {
1932
- id: f.id,
1933
- isloh: 1,
1934
- querykey: f.querykey,
1935
- chr: f.chr,
1936
- start: f.start,
1937
- stop: f.stop,
1938
- valuecutoff: f.valuecutoff,
1939
- focalsizelimit: f.focalsizelimit
1940
- };
1941
- }
1942
- if (f.isvcf) {
1943
- return {
1944
- id: f.id,
1945
- isvcf: 1,
1946
- querykey: f.querykey,
1947
- chr: f.chr,
1948
- start: f.start,
1949
- stop: f.stop,
1950
- snvindel: {
1951
- excludeclasses: f.snvindel.excludeclasses
1952
- }
1953
- };
1954
- }
1955
- if (f.isitd) {
1956
- return {
1957
- id: f.id,
1958
- isitd: 1,
1959
- querykey: f.querykey,
1960
- chr: f.chr,
1961
- start: f.start,
1962
- stop: f.stop
1963
- };
1964
- }
1965
- if (f.issvfusion) {
1966
- return {
1967
- id: f.id,
1968
- issvfusion: 1,
1969
- querykey: f.querykey,
1970
- chr: f.chr,
1971
- start: f.start,
1972
- stop: f.stop
1973
- };
1974
- }
1975
- if (f.issvcnv || f.ismutation) {
1976
- const arg = {
1977
- id: f.id,
1978
- chr: f.chr,
1979
- start: f.start,
1980
- stop: f.stop,
1981
- cnv: {
1982
- hidden: f.cnv.hidden,
1983
- valuecutoff: f.cnv.valuecutoff,
1984
- focalsizelimit: f.cnv.focalsizelimit
1985
- },
1986
- loh: {
1987
- hidden: f.loh.hidden,
1988
- valuecutoff: f.loh.valuecutoff,
1989
- focalsizelimit: f.loh.focalsizelimit
1990
- },
1991
- itd: {
1992
- hidden: f.itd.hidden
1993
- },
1994
- sv: {
1995
- hidden: f.sv.hidden
1996
- },
1997
- fusion: {
1998
- hidden: f.fusion.hidden
1999
- },
2000
- snvindel: {
2001
- excludeclasses: f.snvindel.excludeclasses
2002
- }
2003
- };
2004
- if (f.issvcnv) {
2005
- arg.issvcnv = 1;
2006
- arg.querykey = f.querykey;
2007
- } else {
2008
- arg.ismutation = 1;
2009
- arg.querykeylst = f.querykeylst;
2010
- }
2011
- return arg;
2012
- }
2013
- if (f.issampleattribute) {
2014
- return {
2015
- id: f.id,
2016
- issampleattribute: 1,
2017
- key: f.key
2018
- };
2019
- }
2020
- throw "unknown feature type in making request parameter";
2021
- }
2022
- function getitemforsample_vcf(feature, sample) {
2023
- const mlst = [];
2024
- for (const m of feature.items) {
2025
- if (m.dt == dtsnvindel) {
2026
- if (m.sampledata.findIndex((i) => i.sampleobj.name == sample.name) != -1) {
2027
- mlst.push(m);
2028
- }
2029
- } else {
2030
- console.error("getitemforsample_vcf: unknown dt");
2031
- }
2032
- }
2033
- return mlst;
2034
- }
2035
- function getitemforsample_compound(feature, sample) {
2036
- const cnv = [], loh = [], itd = [], sv = [], fusion = [], snvindel = [];
2037
- for (const item of feature.items) {
2038
- if (item.dt == dtsnvindel) {
2039
- if (!item.sampledata) continue;
2040
- const m_sample = item.sampledata.find((s) => s.sampleobj.name == sample.name);
2041
- if (!m_sample) continue;
2042
- snvindel.push({
2043
- m: item,
2044
- m_sample
2045
- });
2046
- continue;
2047
- }
2048
- if (item.sample != sample.name) continue;
2049
- if (item.dt == dtcnv) {
2050
- cnv.push(item);
2051
- } else if (item.dt == dtloh) {
2052
- loh.push(item);
2053
- } else if (item.dt == dtitd) {
2054
- itd.push(item);
2055
- } else if (item.dt == dtsv) {
2056
- sv.push(item);
2057
- } else if (item.dt == dtfusionrna) {
2058
- fusion.push(item);
2059
- } else {
2060
- console.error("unknown dt: " + item.dt);
2061
- }
2062
- }
2063
- return [cnv, loh, itd, sv, fusion, snvindel];
2064
- }
2065
- function initfeature_polymutation(f) {
2066
- if (!f.width) f.width = 20;
2067
- if (!f.cnv) f.cnv = {};
2068
- if (!f.cnv.valuecutoff) f.cnv.valuecutoff = 0.2;
2069
- if (!Number.isInteger(f.cnv.focalsizelimit)) f.cnv.focalsizelimit = 2e6;
2070
- if (!f.cnv.colorgain) f.cnv.colorgain = default_cnvgaincolor;
2071
- if (!f.cnv.colorloss) f.cnv.colorloss = default_cnvlosscolor;
2072
- if (!f.loh) f.loh = {};
2073
- if (!f.loh.valuecutoff) f.loh.valuecutoff = 0.1;
2074
- if (!Number.isInteger(f.loh.focalsizelimit)) f.loh.focalsizelimit = 2e6;
2075
- if (!f.loh.color) f.loh.color = default_lohcolor;
2076
- if (!f.itd) f.itd = {};
2077
- if (!f.itd.color) f.itd.color = mclass[mclassitd].color;
2078
- if (!f.sv) f.sv = {};
2079
- if (!f.sv.color) f.sv.color = default_svcolor;
2080
- if (!f.fusion) f.fusion = {};
2081
- if (!f.fusion.color) f.fusion.color = default_svcolor;
2082
- if (!f.snvindel) f.snvindel = {};
2083
- if (!f.snvindel.excludeclasses) f.snvindel.excludeclasses = {};
2084
- }
2085
- function init_controlui(o) {
2086
- const buttonrow = o.holder.append("div").style("margin-bottom", "5px");
2087
- const folderdiv = o.holder.append("div").style("margin-bottom", "20px");
2088
- buttonrow.append("span").style("margin-right", "20px").style("font-size", ".8em").text("LEGEND").attr("class", "sja_clbtext").on("click", () => {
2089
- if (o.legendtable.style("display") == "none") {
2090
- appear(o.legendtable);
2091
- } else {
2092
- disappear(o.legendtable);
2093
- }
2094
- });
2095
- o.legendtable = folderdiv.append("table").style("border-top", "solid 1px #ededed").style("border-bottom", "solid 1px #ededed").style("border-spacing", "10px").style("display", "none");
2096
- buttonrow.append("span").style("margin-right", "20px").style("font-size", ".8em").text("CONFIG").attr("class", "sja_clbtext").on("click", () => {
2097
- if (generalconfig.style("display") == "none") {
2098
- appear(generalconfig);
2099
- } else {
2100
- disappear(generalconfig);
2101
- }
2102
- });
2103
- const generalconfig = folderdiv.append("div").style("border-top", "solid 1px #ededed").style("border-bottom", "solid 1px #ededed").style("display", "none");
2104
- const row = generalconfig.append("div").style("margin", "5px");
2105
- row.append("div").style("vertical-align", "top").style("display", "inline-block").html("Show features as &nbsp;&nbsp;");
2106
- const opts_div = row.append("div").style("display", "inline-block");
2107
- const mutation_opts = [
2108
- { value: "symbol", text: "CNV on genomic location, others as symbol" },
2109
- { value: "proportion", text: "All features as porportion" }
2110
- ];
2111
- mutation_opts.forEach((opt) => {
2112
- const opt_div = opts_div.append("div");
2113
- opt_div.append("input").attr("type", "radio").attr("id", opt.value).attr("name", "mutaion_display").attr("value", opt.value).property(
2114
- "checked",
2115
- opt.value == "symbol" && o.ismutation_allsymbolic === void 0 && o.ismutation_allnotsymbolic === void 0 ? 1 : opt.value == "symbol" && o.ismutation_allnotsymbolic ? 1 : opt.value == "proportion" && o.ismutation_allsymbolic ? 1 : 0
2116
- ).on("change", function() {
2117
- if (opt.value == "symbol" && o.ismutation_allnotsymbolic) return;
2118
- else if (opt.value == "proportion" && o.ismutation_allsymbolic) return;
2119
- else if (opt.value == "symbol") {
2120
- delete o.ismutation_allsymbolic;
2121
- o.ismutation_allnotsymbolic = true;
2122
- } else if (opt.value == "proportion") {
2123
- o.ismutation_allsymbolic = true;
2124
- delete o.ismutation_allnotsymbolic;
2125
- } else {
2126
- return;
2127
- }
2128
- o.draw_matrix();
2129
- });
2130
- opt_div.append("label").attr("for", opt.value).text(opt.text);
2131
- });
2132
- const row2 = generalconfig.append("div").style("margin", "5px");
2133
- row2.append("div").style("vertical-align", "top").style("display", "inline-block").html("Layout of Matrix &nbsp;&nbsp;");
2134
- const opts_div2 = row2.append("div").style("display", "inline-block");
2135
- const layout_opts = [
2136
- { value: "gene_on_row", text: "Genes as Rows" },
2137
- { value: "sam_on_row", text: "Samples as Rows" }
2138
- ];
2139
- layout_opts.forEach((opt) => {
2140
- const opt_div = opts_div2.append("div");
2141
- opt_div.append("input").attr("type", "radio").attr("id", opt.value).attr("name", "layout").attr("value", opt.value).property(
2142
- "checked",
2143
- opt.value == "gene_on_row" && o.features_on_rows ? 1 : opt.value == "sam_on_row" && !o.features_on_rows ? 1 : 0
2144
- ).on("change", function() {
2145
- if (opt.value == "gene_on_row" && o.features_on_rows) return;
2146
- else if (opt.value == "sam_on_row" && !o.features_on_rows) return;
2147
- else if (opt.value == "gene_on_row") {
2148
- o.features_on_rows = true;
2149
- if (o.ori_feature_width) o.features.forEach((f) => f.height = o.ori_feature_width);
2150
- } else {
2151
- o.features_on_rows = false;
2152
- if (o.ori_feature_height) o.features.forEach((f) => f.width = o.ori_feature_height);
2153
- }
2154
- o.draw_matrix();
2155
- });
2156
- opt_div.append("label").attr("for", opt.value).text(opt.text);
2157
- });
2158
- buttonrow.append("span").style("margin-right", "20px").style("font-size", ".8em").text("DATA").attr("class", "sja_clbtext").on("click", () => {
2159
- printData(o);
2160
- });
2161
- may_add_kmplotbutton(o, buttonrow);
2162
- }
2163
- function printData(o) {
2164
- const lst = ["sample feature varianttype variant"];
2165
- for (const s of o.samples) {
2166
- for (const f of o.features) {
2167
- for (const i of f.items) {
2168
- if (i.sample && i.sample == s.name || i.sampledata && i.sampledata.findIndex((i2) => i2.sampleobj.name == s.name) != -1) {
2169
- lst.push(s.name + " " + f.label + " " + dt2label[i.dt] + " " + item2string(i));
2170
- }
2171
- }
2172
- }
2173
- }
2174
- export_data("Matrix data", [{ text: lst.join("\n") }]);
2175
- }
2176
- function item2string(i) {
2177
- if (i.dt == dtsnvindel)
2178
- return i.mname + " " + mclass[i.class].label + " " + i.chr + "." + i.pos + "." + i.ref + "." + i.alt;
2179
- if (i.dt == dtfusionrna || i.dt == dtsv)
2180
- return i.chrA + "." + i.posA + "." + (i.strandA || "") + " > " + i.chrB + "." + i.posB + "." + (i.strandB || "");
2181
- if (i.dt == dtcnv) return i.chr + ":" + i.start + "-" + i.stop + ", log2(ratio): " + i.value;
2182
- if (i.dt == dtloh) return i.chr + ":" + i.start + "-" + i.stop + ", log2(ratio): " + i.segmean;
2183
- if (i.dt == dtitd) return i.chr + ":" + i.start + "-" + i.stop;
2184
- return "";
2185
- }
2186
- export {
2187
- Samplematrix
2188
- };
2189
- //# sourceMappingURL=samplematrix-L37O664Y.js.map