@sjcrh/proteinpaint-client 2.190.2 → 2.191.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (874) hide show
  1. package/dist/2dmaf-3D2KTSAN.js +1373 -0
  2. package/dist/AIProjectAdmin-IGPLMREH.js +829 -0
  3. package/dist/AppHeader-WT5AXGLC.js +835 -0
  4. package/dist/BoxPlot-AUFITBDB.js +1217 -0
  5. package/dist/CorrelationVolcano-4AZ6Y42O.js +619 -0
  6. package/dist/DE-MWYRMM47.js +95 -0
  7. package/dist/DEinput-F3JFK4HF.js +301 -0
  8. package/dist/DifferentialAnalysis-ZAVYUYOL.js +245 -0
  9. package/dist/Disco-Q3O3A2CU.js +3237 -0
  10. package/dist/Disco.UI-QIKPQKTY.js +245 -0
  11. package/dist/DmrPlot-D7TPJXWH.js +642 -0
  12. package/dist/GB-K57ZGFLA.js +1130 -0
  13. package/dist/GeneExpInput-7UYFJHSX.js +366 -0
  14. package/dist/HicApp-HPIHJDLQ.js +2250 -0
  15. package/dist/NumBinaryEditor-ENHACYTK.js +270 -0
  16. package/dist/NumBinaryEditor.unit.spec-TNIRFCTU.js +286 -0
  17. package/dist/NumContEditor-Y4CDFJM2.js +107 -0
  18. package/dist/NumContEditor.unit.spec-KES6AJHN.js +169 -0
  19. package/dist/NumCustomBinEditor-TRXZ52MH.js +38 -0
  20. package/dist/NumCustomBinEditor.unit.spec-2V5X5YK4.js +284 -0
  21. package/dist/NumDiscreteEditor-RXXL3AQ4.js +179 -0
  22. package/dist/NumDiscreteEditor.unit.spec-EAFEI66P.js +202 -0
  23. package/dist/NumRegularBinEditor-KHIFP2L7.js +38 -0
  24. package/dist/NumRegularBinEditor.unit.spec-ADRNCEAV.js +227 -0
  25. package/dist/NumSplineEditor-33SUCGNJ.js +197 -0
  26. package/dist/NumSplineEditor.unit.spec-7KTMNABP.js +199 -0
  27. package/dist/NumericDensity-PWWJBZUA.js +38 -0
  28. package/dist/NumericDensity.unit.spec-V5C43FCP.js +221 -0
  29. package/dist/NumericHandler-A6QSQAPT.js +39 -0
  30. package/dist/NumericHandler.unit.spec-SRFEDFCC.js +219 -0
  31. package/dist/ProteomeInput-BOI2634T.js +396 -0
  32. package/dist/RunChart2-DJNWYZ5C.js +758 -0
  33. package/dist/SC-ADKHO4MP.js +936 -0
  34. package/dist/Volcano-4GJU2666.js +1379 -0
  35. package/dist/WSIViewer-JQKGSN3D.js +48475 -0
  36. package/dist/WsiSamplesPlot-PSVYIYI7.js +165 -0
  37. package/dist/adSandbox-AFYF5ULQ.js +38 -0
  38. package/dist/app-5KDQSFDE.js +49 -0
  39. package/dist/app-PZ5KGBCR.js +37 -0
  40. package/dist/app.js +13 -13
  41. package/dist/bam-AYX4HVPY.js +860 -0
  42. package/dist/barchart-2BMDZGPJ.js +47 -0
  43. package/dist/barchart.data-I33D7SQC.js +22 -0
  44. package/dist/barchart.events-Z5AL6NU6.js +47 -0
  45. package/dist/barchart.integration.spec-JG7OWI6G.js +1974 -0
  46. package/dist/barchart.integration.spec-JG7OWI6G.js.map +7 -0
  47. package/dist/barchart2-KFMUPMVS.js +311 -0
  48. package/dist/block-7UW7QCRX.js +6202 -0
  49. package/dist/block.init-CZWCEEID.js +38 -0
  50. package/dist/block.mds.expressionrank-2JJYKI2C.js +359 -0
  51. package/dist/block.mds.geneboxplot-NU45ZP4J.js +828 -0
  52. package/dist/block.mds.junction-UVSKHUFR.js +1545 -0
  53. package/dist/block.mds.svcnv-6JXI63CC.js +6801 -0
  54. package/dist/block.svg-KAMDKUQX.js +164 -0
  55. package/dist/block.tk.aicheck-WEKHCRXC.js +283 -0
  56. package/dist/block.tk.ase-MGDGSUQN.js +365 -0
  57. package/dist/block.tk.bam-MB2DAFD7.js +1906 -0
  58. package/dist/block.tk.bedgraphdot-VUSURZ6N.js +384 -0
  59. package/dist/block.tk.bigwig.ui-WQTN44VK.js +212 -0
  60. package/dist/block.tk.hicstraw-T2JXNKWD.js +823 -0
  61. package/dist/block.tk.junction-2JXABLIG.js +2364 -0
  62. package/dist/block.tk.junction.textmatrixui-EEB3JUNU.js +199 -0
  63. package/dist/block.tk.ld-JZBL73US.js +99 -0
  64. package/dist/block.tk.menu-VQEPTCE6.js +1029 -0
  65. package/dist/block.tk.pgv-PYOPQDYL.js +944 -0
  66. package/dist/brainImaging-SYJZZN3K.js +423 -0
  67. package/dist/chunk-26XX7RVV.js +129 -0
  68. package/dist/chunk-2QWELHBX.js +54 -0
  69. package/dist/chunk-3MGF2FZ2.js +1179 -0
  70. package/dist/chunk-3S7ZWGND.js +95 -0
  71. package/dist/chunk-4VCBJC3B.js +203 -0
  72. package/dist/chunk-53WLN75I.js +50 -0
  73. package/dist/chunk-5GOZWJ7S.js +263 -0
  74. package/dist/chunk-5WKIMNGG.js +148 -0
  75. package/dist/chunk-5WM3CC5O.js +117 -0
  76. package/dist/chunk-6FF5VLGO.js +20745 -0
  77. package/dist/chunk-6FF5VLGO.js.map +7 -0
  78. package/dist/chunk-6FOKZFIT.js +613 -0
  79. package/dist/chunk-6FOKZFIT.js.map +7 -0
  80. package/dist/chunk-6GI6MDYV.js +1210 -0
  81. package/dist/chunk-6XOZ4DWL.js +222 -0
  82. package/dist/chunk-6XOZ4DWL.js.map +7 -0
  83. package/dist/chunk-7BOPMRFX.js +482 -0
  84. package/dist/chunk-7C76SLOH.js +1275 -0
  85. package/dist/chunk-7C76SLOH.js.map +7 -0
  86. package/dist/chunk-BYOIIMNZ.js +2327 -0
  87. package/dist/chunk-CGRYUKXD.js +443 -0
  88. package/dist/chunk-CK47VCG5.js +5010 -0
  89. package/dist/chunk-CRUBP5PT.js +446 -0
  90. package/dist/chunk-CW2Q5EA7.js +283 -0
  91. package/dist/chunk-E7UJR2YK.js +158 -0
  92. package/dist/chunk-ENZZUMVY.js +215 -0
  93. package/dist/chunk-FRGACC2C.js +182 -0
  94. package/dist/chunk-FZ63VOSX.js +226 -0
  95. package/dist/chunk-GGRR4NXW.js +1102 -0
  96. package/dist/chunk-H5BIGL3W.js +1815 -0
  97. package/dist/chunk-H5BIGL3W.js.map +7 -0
  98. package/dist/chunk-I2LTCBTM.js +2824 -0
  99. package/dist/chunk-IYOGX7A4.js +158 -0
  100. package/dist/chunk-IYOGX7A4.js.map +7 -0
  101. package/dist/chunk-J5SV3MFB.js +217 -0
  102. package/dist/chunk-J7X5JRRI.js +276 -0
  103. package/dist/chunk-JDPU6NES.js +100 -0
  104. package/dist/chunk-JEZIKGZI.js +386 -0
  105. package/dist/chunk-JPH5EVVW.js +514 -0
  106. package/dist/chunk-JTMU3F2Q.js +184 -0
  107. package/dist/chunk-JTMU3F2Q.js.map +7 -0
  108. package/dist/chunk-KQYXXICJ.js +1332 -0
  109. package/dist/chunk-L72Y4QA2.js +102 -0
  110. package/dist/chunk-LK3BBGUJ.js +2681 -0
  111. package/dist/chunk-LYPDXJPX.js +6364 -0
  112. package/dist/chunk-MEY5OBDJ.js +170 -0
  113. package/dist/chunk-MW3PIRGF.js +229 -0
  114. package/dist/chunk-NNMOXQTU.js +102 -0
  115. package/dist/chunk-NV6JVKDN.js +291 -0
  116. package/dist/chunk-OMBRJBQV.js +1943 -0
  117. package/dist/chunk-PEBOVJSD.js +142 -0
  118. package/dist/chunk-PJXF4IRZ.js +95 -0
  119. package/dist/chunk-PKCYPYWW.js +4272 -0
  120. package/dist/chunk-QIY7HLC5.js +815 -0
  121. package/dist/chunk-QMI2X23H.js +339 -0
  122. package/dist/chunk-QOE7MB4X.js +454 -0
  123. package/dist/chunk-QSMU6K5D.js +34 -0
  124. package/dist/chunk-RBIBHQTL.js +54 -0
  125. package/dist/chunk-RG5ABFA2.js +368 -0
  126. package/dist/chunk-RRJGFE2S.js +407 -0
  127. package/dist/chunk-RTTPFI7N.js +14 -0
  128. package/dist/chunk-T2CG7BVN.js +205 -0
  129. package/dist/chunk-TVADJLMF.js +317 -0
  130. package/dist/chunk-TVADJLMF.js.map +7 -0
  131. package/dist/chunk-U3DKYKV7.js +293 -0
  132. package/dist/chunk-UQHM3F6B.js +37 -0
  133. package/dist/chunk-VXKO2ONI.js +534 -0
  134. package/dist/chunk-W3MCIBAP.js +272 -0
  135. package/dist/chunk-WH236OZ6.js +736 -0
  136. package/dist/chunk-WMELUFVS.js +254 -0
  137. package/dist/chunk-WS3NUPNV.js +119 -0
  138. package/dist/chunk-XIQNS2HN.js +824 -0
  139. package/dist/chunk-YKPLUIWP.js +2786 -0
  140. package/dist/chunk-YRQ5V7DQ.js +302 -0
  141. package/dist/chunk-ZK226W6V.js +194 -0
  142. package/dist/chunk-ZTOABVVA.js +55 -0
  143. package/dist/chunk-ZUTPAYSS.js +477 -0
  144. package/dist/condition-SZZS77TK.js +332 -0
  145. package/dist/controls-ZBDTHWOT.js +41 -0
  146. package/dist/controls.config-MTBN2XPW.js +39 -0
  147. package/dist/correlation-DHEH5FT4.js +99 -0
  148. package/dist/cuminc-TM3SMOJ2.js +1149 -0
  149. package/dist/cuminc.integration.spec-NEBXRMKB.js +678 -0
  150. package/dist/customdata.inputui-5ZEKFWYV.js +289 -0
  151. package/dist/dataDownload-XZ4AC6QY.js +330 -0
  152. package/dist/dataDownload.integration.spec-O4YQKAOJ.js +193 -0
  153. package/dist/databrowser.ui-V4HQMZ4X.js +433 -0
  154. package/dist/dictionary-RAHC3OA7.js +111 -0
  155. package/dist/dnaMethylation-ZUHHG7Q2.js +38 -0
  156. package/dist/dnaMethylation.integration.spec-JZ6ZSF5L.js +203 -0
  157. package/dist/dofetch-77N4NDDM.js +51 -0
  158. package/dist/e2pca-K7IFKNTZ.js +350 -0
  159. package/dist/ep-4OIFIMZH.js +1256 -0
  160. package/dist/expclust.gdc.spec-OJD7ENKA.js +307 -0
  161. package/dist/facet-SZAF3QW6.js +521 -0
  162. package/dist/forms2-TBRF2RI5.js +534 -0
  163. package/dist/gb-I5J74SHP.js +88 -0
  164. package/dist/geneExpClustering-OSS4OCN6.js +249 -0
  165. package/dist/geneExpression-IHVMJGOG.js +38 -0
  166. package/dist/geneExpression-WKYVSE45.js +313 -0
  167. package/dist/geneExpression.unit.spec-QP6CLYHP.js +102 -0
  168. package/dist/geneORA-65PHOTHN.js +278 -0
  169. package/dist/geneRanking-XCU3NX4J.js +551 -0
  170. package/dist/geneVariant-CZM3XP7X.js +39 -0
  171. package/dist/geneVariant-IMDFPV2L.js +41 -0
  172. package/dist/geneVariant.integration.spec-FOONVTYD.js +198 -0
  173. package/dist/genefusion.ui-UZM2YGIR.js +309 -0
  174. package/dist/geneset-IGG77MNZ.js +208 -0
  175. package/dist/genomeBrowser.spec-CN2XNZQF.js +281 -0
  176. package/dist/grin2-367QGSOU.js +1560 -0
  177. package/dist/grin2-S46IRWIP.js +821 -0
  178. package/dist/grin2-S46IRWIP.js.map +7 -0
  179. package/dist/gsea-RJ767G5U.js +47 -0
  180. package/dist/hierCluster-3D425AUU.js +63 -0
  181. package/dist/hierCluster-GIIB6OEC.js +59 -0
  182. package/dist/hierCluster.config-ENEOWYOS.js +40 -0
  183. package/dist/hierCluster.integration.spec-IOA3PVAN.js +395 -0
  184. package/dist/hierCluster.interactivity-VITUF5RM.js +54 -0
  185. package/dist/hierCluster.renderers-G3274UYA.js +21 -0
  186. package/dist/imagePlot-7VH7VFWD.js +163 -0
  187. package/dist/importPlot-OKOYX2NU.js +8 -0
  188. package/dist/isoformExpression-4SJQZFLP.js +40 -0
  189. package/dist/isoformExpression.unit.spec-3MQQZEPZ.js +208 -0
  190. package/dist/launch.adhoc-MQKVVUV7.js +42 -0
  191. package/dist/leftlabel.sample-JPE6CXZU.js +260 -0
  192. package/dist/lollipop-DMM3QYKI.js +171 -0
  193. package/dist/maf-TQKKVLNR.js +452 -0
  194. package/dist/maftimeline-BXBAXKAI.js +593 -0
  195. package/dist/matrix-AWVEEUKZ.js +58 -0
  196. package/dist/matrix-N3YUJXLP.js +63 -0
  197. package/dist/matrix.cells-E3LEVA7U.js +28 -0
  198. package/dist/matrix.config-QPNAC2EY.js +41 -0
  199. package/dist/matrix.data-FIQGPFTI.js +25 -0
  200. package/dist/matrix.groups-BGMZZ6CM.js +27 -0
  201. package/dist/matrix.integration.spec-OA3FJ2PN.js +3072 -0
  202. package/dist/matrix.interactivity-LKLF5ZQN.js +42 -0
  203. package/dist/matrix.layout-ORYBQUKT.js +44 -0
  204. package/dist/matrix.legend-RJAFOZHQ.js +22 -0
  205. package/dist/matrix.renderers-TLZSYHZR.js +38 -0
  206. package/dist/matrix.serieses-GJWHSBG4.js +21 -0
  207. package/dist/matrix.sort-KIJENIT2.js +27 -0
  208. package/dist/matrix.sort.unit.spec-DRFCEZGX.js +472 -0
  209. package/dist/matrix.sorterUi.unit.spec-QQH3ITTW.js +342 -0
  210. package/dist/mavb-ZK5UKXEO.js +732 -0
  211. package/dist/mds.fimo-MHPHQB4X.js +518 -0
  212. package/dist/mds.samplescatterplot-LRL5SXJ5.js +1550 -0
  213. package/dist/mds.survivalplot-R5N6OHZ2.js +483 -0
  214. package/dist/numericDictTermCluster-OMXIURRD.js +72 -0
  215. package/dist/oncomatrix-FA3ELKNE.js +295 -0
  216. package/dist/oncomatrix.spec-3K7ONINO.js +448 -0
  217. package/dist/plot.2dvaf-P6CRZWB7.js +377 -0
  218. package/dist/plot.app-XOQVTISH.js +41 -0
  219. package/dist/plot.barplot-YDT4K3YZ.js +102 -0
  220. package/dist/plot.boxplot-GHEVLVJU.js +152 -0
  221. package/dist/plot.brainImaging-NENXKZEP.js +51 -0
  222. package/dist/plot.disco-3B7LZ2XE.js +102 -0
  223. package/dist/plot.dzi-F7NW65WQ.js +33 -0
  224. package/dist/plot.ssgq-BAUIBB3D.js +139 -0
  225. package/dist/plot.vaf2cov-XBLM7B4M.js +259 -0
  226. package/dist/plot.wsi-YWILGUDN.js +36 -0
  227. package/dist/polar2-WABGZYEV.js +226 -0
  228. package/dist/polar2-WABGZYEV.js.map +7 -0
  229. package/dist/profileForms-LYWVFIVQ.js +441 -0
  230. package/dist/profilePlot-TSXR4EGL.js +54 -0
  231. package/dist/proteinView-ATZI5LXA.js +1320 -0
  232. package/dist/proteinView-ATZI5LXA.js.map +7 -0
  233. package/dist/qualitative-VNY32ONL.js +43 -0
  234. package/dist/radar2-YVHLSCAM.js +321 -0
  235. package/dist/radarFacility2-K4OA7FYK.js +329 -0
  236. package/dist/regression-KKC7Y57Y.js +56 -0
  237. package/dist/regression.inputs-UR2VLW5P.js +48 -0
  238. package/dist/regression.inputs.term-QECG7D3W.js +48 -0
  239. package/dist/regression.inputs.values.table-UANMD46V.js +45 -0
  240. package/dist/regression.integration.spec-UCUHBCZY.js +784 -0
  241. package/dist/regression.results-TNVEGETD.js +40 -0
  242. package/dist/regression.spec-3NSFMTI7.js +708 -0
  243. package/dist/report-2FNKLTYA.js +222 -0
  244. package/dist/sampleScatter.spec-5SC2AJHW.js +202 -0
  245. package/dist/sampleView-SU7VZCJH.js +48 -0
  246. package/dist/samplelst-JGSTML6J.js +111 -0
  247. package/dist/samplematrix-FO4GGDRT.js +2198 -0
  248. package/dist/sc-LDUHVPII.js +86 -0
  249. package/dist/scatter-QAEMBYHW.js +854 -0
  250. package/dist/scatter.integration.spec-FTD4PDMI.js +1196 -0
  251. package/dist/selectGenomeWithTklst-G3XUX3KK.js +134 -0
  252. package/dist/singleCellCellType-QKA4QCLC.js +38 -0
  253. package/dist/singleCellCellType.unit.spec-KIPKWJLB.js +160 -0
  254. package/dist/singleCellGeneExpression-O2QVJOG4.js +38 -0
  255. package/dist/singleCellGeneExpression.unit.spec-6ATWTQTO.js +153 -0
  256. package/dist/singleCellPlot-HZOSW3FB.js +54 -0
  257. package/dist/singlecell-3OX4TSQ4.js +86 -0
  258. package/dist/singlecell-EUUIY2JJ.js +1572 -0
  259. package/dist/snp-UVKGSROJ.js +38 -0
  260. package/dist/snp.unit.spec-YHIZ5ZJW.js +176 -0
  261. package/dist/snplocus-FANKGKI4.js +208 -0
  262. package/dist/spliceevent.a53ss.diagram-QQXYYX7J.js +151 -0
  263. package/dist/spliceevent.exonskip.diagram-R265JOH6.js +277 -0
  264. package/dist/spliceevent.noeventdiagram-UMAQOCVY.js +460 -0
  265. package/dist/ssGSEA-F4BZ3NYO.js +38 -0
  266. package/dist/ssGSEA.unit.spec-OQQGQYPJ.js +88 -0
  267. package/dist/summarizeCnvGeneexp-LX22NXFF.js +163 -0
  268. package/dist/summarizeGeneexpSurvival-N7LXAK2G.js +108 -0
  269. package/dist/summarizeMutationCnv-QC3EARCV.js +164 -0
  270. package/dist/summarizeMutationDiagnosis-H6KJWLLC.js +40 -0
  271. package/dist/summarizeMutationSurvival-JAFSWJVZ.js +99 -0
  272. package/dist/summary-D5MSBQIS.js +49 -0
  273. package/dist/summary.integration.spec-KJPNP7X2.js +414 -0
  274. package/dist/summaryInput-47JBGPNE.js +235 -0
  275. package/dist/sunburst-PUZYZZGK.js +284 -0
  276. package/dist/survival-LGJBYXFR.js +58 -0
  277. package/dist/survival-SMOKVDGO.js +46 -0
  278. package/dist/survival.integration.spec-ORC3LCVK.js +821 -0
  279. package/dist/svgraph-GWDKHIDQ.js +1387 -0
  280. package/dist/svmr-RRA6OUVP.js +3842 -0
  281. package/dist/table-AC2DX55F.js +200 -0
  282. package/dist/termCollection-4OVZAKYZ.js +179 -0
  283. package/dist/termCollection-MPFFNNMF.js +38 -0
  284. package/dist/termCollection.unit.spec-S4QSTY4S.js +208 -0
  285. package/dist/tk-PFWI2HAC.js +46 -0
  286. package/dist/tp.ui-TKAJ7DRO.js +1459 -0
  287. package/dist/tvs.dt-6NDINORK.js +39 -0
  288. package/dist/tvs.dtcnv.categorical-2RHUN643.js +40 -0
  289. package/dist/tvs.dtcnv.continuous-GIPVPDBD.js +72 -0
  290. package/dist/tvs.dtfusion-ZLXTZ7SA.js +40 -0
  291. package/dist/tvs.dtsnvindel-CRS5CL42.js +40 -0
  292. package/dist/tvs.dtsv-SG45TZWQ.js +40 -0
  293. package/dist/tvs.samplelst-NQ5BKEGM.js +104 -0
  294. package/dist/tvs.termCollection-HOVUO7ZH.js +159 -0
  295. package/dist/violin-FGGULOXU.js +46 -0
  296. package/dist/violin.integration.spec-T5Y6URJK.js +1425 -0
  297. package/dist/violin.interactivity-6RGFTQDW.js +38 -0
  298. package/dist/violin.renderer-63UTDZVK.js +40 -0
  299. package/dist/vocabulary-YQXR4H5J.js +41 -0
  300. package/package.json +2 -2
  301. package/dist/2dmaf-ZCIOFNSJ.js +0 -1373
  302. package/dist/AIProjectAdmin-Z7EA2Y74.js +0 -829
  303. package/dist/AppHeader-4AZ76NN3.js +0 -835
  304. package/dist/BoxPlot-BFVBNQNR.js +0 -1217
  305. package/dist/CorrelationVolcano-L5VSJWJF.js +0 -619
  306. package/dist/DE-7TPZWAKI.js +0 -95
  307. package/dist/DEinput-WQJEXWGY.js +0 -301
  308. package/dist/DifferentialAnalysis-FPG7RDNN.js +0 -245
  309. package/dist/Disco-WP2BBL5V.js +0 -3237
  310. package/dist/Disco.UI-ZYSUA57E.js +0 -245
  311. package/dist/DmrPlot-V3E7JMPN.js +0 -642
  312. package/dist/GB-BKLVGYWP.js +0 -1130
  313. package/dist/GeneExpInput-7V72SRDT.js +0 -366
  314. package/dist/HicApp-IT5YNABL.js +0 -2250
  315. package/dist/NumBinaryEditor-7E37MVQO.js +0 -270
  316. package/dist/NumBinaryEditor.unit.spec-C3WVAXMY.js +0 -286
  317. package/dist/NumContEditor-FEVZJUB4.js +0 -107
  318. package/dist/NumContEditor.unit.spec-4IGP657P.js +0 -169
  319. package/dist/NumCustomBinEditor-QC4D63Y5.js +0 -38
  320. package/dist/NumCustomBinEditor.unit.spec-USLECMWI.js +0 -284
  321. package/dist/NumDiscreteEditor-PRAI76XQ.js +0 -179
  322. package/dist/NumDiscreteEditor.unit.spec-IWL3OCTC.js +0 -202
  323. package/dist/NumRegularBinEditor-ESL2HAD7.js +0 -38
  324. package/dist/NumRegularBinEditor.unit.spec-7LLZAW4Z.js +0 -227
  325. package/dist/NumSplineEditor-JZOROO36.js +0 -197
  326. package/dist/NumSplineEditor.unit.spec-3SHSXTC7.js +0 -199
  327. package/dist/NumericDensity-SGYRBDCQ.js +0 -38
  328. package/dist/NumericDensity.unit.spec-Y6JMH6IR.js +0 -221
  329. package/dist/NumericHandler-YG7AMINA.js +0 -39
  330. package/dist/NumericHandler.unit.spec-CABSMERN.js +0 -219
  331. package/dist/ProteomeInput-2WPCK72Z.js +0 -396
  332. package/dist/RunChart2-PJWMDWJR.js +0 -758
  333. package/dist/SC-WVVUFPNU.js +0 -936
  334. package/dist/Volcano-7JI4LUSF.js +0 -1379
  335. package/dist/WSIViewer-GDSOEEA6.js +0 -48475
  336. package/dist/WsiSamplesPlot-Z5C3NPF7.js +0 -165
  337. package/dist/adSandbox-KQKENDNQ.js +0 -38
  338. package/dist/alphaGenome-PN2SEPCK.js +0 -175
  339. package/dist/alphaGenome-PN2SEPCK.js.map +0 -7
  340. package/dist/app-4OEY56FN.js +0 -49
  341. package/dist/app-TGMYXJ4E.js +0 -37
  342. package/dist/bam-3IMX42G5.js +0 -860
  343. package/dist/barchart-44HOJWVS.js +0 -47
  344. package/dist/barchart.data-CHNR4XL2.js +0 -22
  345. package/dist/barchart.events-XW5OZ5MR.js +0 -47
  346. package/dist/barchart.integration.spec-M5PACARH.js +0 -1923
  347. package/dist/barchart.integration.spec-M5PACARH.js.map +0 -7
  348. package/dist/barchart2-4NU7NWJZ.js +0 -311
  349. package/dist/block-OYSZ2JXC.js +0 -6202
  350. package/dist/block.init-WSIQLW7A.js +0 -38
  351. package/dist/block.mds.expressionrank-2KWOWDW4.js +0 -359
  352. package/dist/block.mds.geneboxplot-6ZAD6A5K.js +0 -828
  353. package/dist/block.mds.junction-VQDLHFNG.js +0 -1545
  354. package/dist/block.mds.svcnv-7OIRG7DQ.js +0 -6801
  355. package/dist/block.svg-HXAIFHXM.js +0 -164
  356. package/dist/block.tk.aicheck-GTGHCUEN.js +0 -283
  357. package/dist/block.tk.ase-TAEE2ZHN.js +0 -365
  358. package/dist/block.tk.bam-6A26AZ7S.js +0 -1906
  359. package/dist/block.tk.bedgraphdot-6MYIVRBC.js +0 -384
  360. package/dist/block.tk.bigwig.ui-GJ7JXRH3.js +0 -212
  361. package/dist/block.tk.hicstraw-3TCDZ2GM.js +0 -823
  362. package/dist/block.tk.junction-WDBIP7DK.js +0 -2364
  363. package/dist/block.tk.junction.textmatrixui-QOV3U7AN.js +0 -199
  364. package/dist/block.tk.ld-GCPH66C3.js +0 -99
  365. package/dist/block.tk.menu-YDAIYUGC.js +0 -1029
  366. package/dist/block.tk.pgv-RWOZAUGA.js +0 -944
  367. package/dist/brainImaging-ZAFU6U2Y.js +0 -423
  368. package/dist/chunk-34SAHEQU.js +0 -291
  369. package/dist/chunk-3I7TUGLD.js +0 -226
  370. package/dist/chunk-3JL2HBGE.js +0 -2824
  371. package/dist/chunk-5GMXV4VC.js +0 -5010
  372. package/dist/chunk-5ITQVR2P.js +0 -102
  373. package/dist/chunk-5TKVUSMQ.js +0 -217
  374. package/dist/chunk-5YF3LGLX.js +0 -2327
  375. package/dist/chunk-76PGYH5J.js +0 -203
  376. package/dist/chunk-7JXLWRVZ.js +0 -2681
  377. package/dist/chunk-7YWFO7CJ.js +0 -6364
  378. package/dist/chunk-B3M3AZPL.js +0 -215
  379. package/dist/chunk-BLKF2SE6.js +0 -37
  380. package/dist/chunk-CA2AOIHR.js +0 -142
  381. package/dist/chunk-DBFPAZG3.js +0 -1943
  382. package/dist/chunk-DCJUDSRM.js +0 -446
  383. package/dist/chunk-DNM2DKYE.js +0 -1332
  384. package/dist/chunk-DVH6K2NP.js +0 -14
  385. package/dist/chunk-DYVY7D67.js +0 -263
  386. package/dist/chunk-G6WVVRDA.js +0 -339
  387. package/dist/chunk-GERVYIL4.js +0 -1210
  388. package/dist/chunk-GKBMGKYN.js +0 -117
  389. package/dist/chunk-GRNZWYOJ.js +0 -815
  390. package/dist/chunk-GS7SQKJT.js +0 -102
  391. package/dist/chunk-H5NNQO2V.js +0 -55
  392. package/dist/chunk-HONXMORI.js +0 -368
  393. package/dist/chunk-HURY7IJE.js +0 -4272
  394. package/dist/chunk-I2RRWDYV.js +0 -514
  395. package/dist/chunk-IFA3COXY.js +0 -185
  396. package/dist/chunk-IFA3COXY.js.map +0 -7
  397. package/dist/chunk-IOQV2VX3.js +0 -2786
  398. package/dist/chunk-IWMWT7O7.js +0 -276
  399. package/dist/chunk-JSEMZPAO.js +0 -34
  400. package/dist/chunk-K7UIR22L.js +0 -229
  401. package/dist/chunk-L75HW457.js +0 -824
  402. package/dist/chunk-LO6OYUDE.js +0 -158
  403. package/dist/chunk-LO6OYUDE.js.map +0 -7
  404. package/dist/chunk-LRZ463XM.js +0 -612
  405. package/dist/chunk-LRZ463XM.js.map +0 -7
  406. package/dist/chunk-MQQRTH4U.js +0 -302
  407. package/dist/chunk-NPEQHLVG.js +0 -158
  408. package/dist/chunk-NPTHYZY4.js +0 -205
  409. package/dist/chunk-NZDQV7ZO.js +0 -50
  410. package/dist/chunk-O7Z7SQCS.js +0 -534
  411. package/dist/chunk-OSWTQVAX.js +0 -477
  412. package/dist/chunk-OY4NTIUQ.js +0 -1272
  413. package/dist/chunk-OY4NTIUQ.js.map +0 -7
  414. package/dist/chunk-PSQETQZZ.js +0 -182
  415. package/dist/chunk-QWOZ2QDM.js +0 -386
  416. package/dist/chunk-QZVCFDJ7.js +0 -736
  417. package/dist/chunk-R4BCNWKE.js +0 -54
  418. package/dist/chunk-S6H6OUOA.js +0 -283
  419. package/dist/chunk-S6OIEQXG.js +0 -443
  420. package/dist/chunk-SDMZUHN7.js +0 -482
  421. package/dist/chunk-SKZ37PND.js +0 -129
  422. package/dist/chunk-STQU7XZV.js +0 -1814
  423. package/dist/chunk-STQU7XZV.js.map +0 -7
  424. package/dist/chunk-SY63VCQB.js +0 -95
  425. package/dist/chunk-TEQ2PC7Z.js +0 -100
  426. package/dist/chunk-TRY57CMI.js +0 -148
  427. package/dist/chunk-TXJTOTIQ.js +0 -1102
  428. package/dist/chunk-UK3PTE3P.js +0 -20752
  429. package/dist/chunk-UK3PTE3P.js.map +0 -7
  430. package/dist/chunk-UT2PKKQ4.js +0 -254
  431. package/dist/chunk-VDPQ2ZV2.js +0 -95
  432. package/dist/chunk-VJH3NP42.js +0 -54
  433. package/dist/chunk-W3LVNVG3.js +0 -272
  434. package/dist/chunk-WC62ZAWT.js +0 -293
  435. package/dist/chunk-WKMZ4ZQ3.js +0 -407
  436. package/dist/chunk-X27TRPIZ.js +0 -119
  437. package/dist/chunk-XIIAQQ4T.js +0 -1179
  438. package/dist/chunk-XOCO3LVN.js +0 -317
  439. package/dist/chunk-XOCO3LVN.js.map +0 -7
  440. package/dist/chunk-XUFWJJM5.js +0 -454
  441. package/dist/chunk-Y2Z4XDHA.js +0 -170
  442. package/dist/chunk-YFKJ2TMX.js +0 -194
  443. package/dist/chunk-YPVFTNLG.js +0 -228
  444. package/dist/chunk-YPVFTNLG.js.map +0 -7
  445. package/dist/condition-XKEW2LCM.js +0 -332
  446. package/dist/controls-4RFWTHFH.js +0 -41
  447. package/dist/controls.config-VHH2IGCI.js +0 -39
  448. package/dist/correlation-HGAMIIPH.js +0 -99
  449. package/dist/cuminc-EHW6IH6V.js +0 -1149
  450. package/dist/cuminc.integration.spec-B3EOIE4K.js +0 -678
  451. package/dist/customdata.inputui-IPJHL7BX.js +0 -289
  452. package/dist/dataDownload-GYFEC6XG.js +0 -330
  453. package/dist/dataDownload.integration.spec-V7WQ6AMV.js +0 -193
  454. package/dist/databrowser.ui-TFAJVFFF.js +0 -433
  455. package/dist/dictionary-2ZSMOJCN.js +0 -111
  456. package/dist/dnaMethylation-RHNO5DAC.js +0 -38
  457. package/dist/dnaMethylation.integration.spec-ET7OLMNC.js +0 -203
  458. package/dist/dofetch-UGCQ3OVW.js +0 -51
  459. package/dist/e2pca-SLRCDKF5.js +0 -350
  460. package/dist/ep-FOFTKVBH.js +0 -1256
  461. package/dist/expclust.gdc.spec-FNOOSLCC.js +0 -307
  462. package/dist/facet-UO5A7AGS.js +0 -521
  463. package/dist/forms2-SFV4HHBA.js +0 -534
  464. package/dist/gb-3KR6MAGB.js +0 -88
  465. package/dist/geneExpClustering-BCDXKSNU.js +0 -249
  466. package/dist/geneExpression-5UPKETEZ.js +0 -313
  467. package/dist/geneExpression-CXQ5HFEP.js +0 -38
  468. package/dist/geneExpression.unit.spec-7FVVD4UF.js +0 -102
  469. package/dist/geneORA-UC45CL2U.js +0 -278
  470. package/dist/geneRanking-OOQWVUIG.js +0 -551
  471. package/dist/geneVariant-BQFB7LKZ.js +0 -39
  472. package/dist/geneVariant-BYN7EWTT.js +0 -41
  473. package/dist/geneVariant.integration.spec-OESHXKBV.js +0 -198
  474. package/dist/genefusion.ui-TOSPIGTE.js +0 -309
  475. package/dist/geneset-57DECCND.js +0 -208
  476. package/dist/genomeBrowser.spec-CQP5JG35.js +0 -281
  477. package/dist/grin2-3RDGRV4Z.js +0 -846
  478. package/dist/grin2-3RDGRV4Z.js.map +0 -7
  479. package/dist/grin2-G4MBI5UC.js +0 -1560
  480. package/dist/gsea-VYAXSBM4.js +0 -47
  481. package/dist/hierCluster-4QKMY7GP.js +0 -59
  482. package/dist/hierCluster-GFPFVB3Q.js +0 -63
  483. package/dist/hierCluster.config-3A24DEKA.js +0 -40
  484. package/dist/hierCluster.integration.spec-6NTJYVN4.js +0 -395
  485. package/dist/hierCluster.interactivity-B2T6WS5R.js +0 -54
  486. package/dist/hierCluster.renderers-R3RLK6BI.js +0 -21
  487. package/dist/imagePlot-YZBZRENG.js +0 -163
  488. package/dist/importPlot-LIXKD3WJ.js +0 -8
  489. package/dist/isoformExpression-ZZ5DL6AE.js +0 -40
  490. package/dist/isoformExpression.unit.spec-IH4247TT.js +0 -208
  491. package/dist/launch.adhoc-3YWVAF7R.js +0 -42
  492. package/dist/leftlabel.sample-XFM45ZKO.js +0 -260
  493. package/dist/lollipop-7K5R5KHB.js +0 -171
  494. package/dist/maf-SQVJHNUY.js +0 -452
  495. package/dist/maftimeline-RCPASNN2.js +0 -593
  496. package/dist/matrix-KHTDB56P.js +0 -63
  497. package/dist/matrix-YTHWIMBP.js +0 -58
  498. package/dist/matrix.cells-KNDVYI2S.js +0 -28
  499. package/dist/matrix.config-6BHBCTXE.js +0 -41
  500. package/dist/matrix.data-VWJQ7N4L.js +0 -25
  501. package/dist/matrix.groups-5AUHEO52.js +0 -27
  502. package/dist/matrix.integration.spec-Q2BXNCUO.js +0 -3072
  503. package/dist/matrix.interactivity-FEEWY34M.js +0 -42
  504. package/dist/matrix.layout-FWWM6QQO.js +0 -44
  505. package/dist/matrix.legend-QT3PMREX.js +0 -22
  506. package/dist/matrix.renderers-M6MJO5IU.js +0 -38
  507. package/dist/matrix.serieses-NTKMKT22.js +0 -21
  508. package/dist/matrix.sort-TTHPJ4XC.js +0 -27
  509. package/dist/matrix.sort.unit.spec-XZI2KPNC.js +0 -472
  510. package/dist/matrix.sorterUi.unit.spec-6FVHTGSN.js +0 -342
  511. package/dist/mavb-FZDN27QY.js +0 -732
  512. package/dist/mds.fimo-SSFKQ3BH.js +0 -518
  513. package/dist/mds.samplescatterplot-BMTTX3TB.js +0 -1550
  514. package/dist/mds.survivalplot-PL75RDYI.js +0 -483
  515. package/dist/numericDictTermCluster-NJUXCQYH.js +0 -72
  516. package/dist/oncomatrix-BZDCCEWH.js +0 -295
  517. package/dist/oncomatrix.spec-5A4A4JLV.js +0 -448
  518. package/dist/plot.2dvaf-AC7LW56S.js +0 -377
  519. package/dist/plot.app-DOOWDQ3U.js +0 -41
  520. package/dist/plot.barplot-RNJWREG5.js +0 -102
  521. package/dist/plot.boxplot-CRAEUBQF.js +0 -152
  522. package/dist/plot.brainImaging-ZESEULN6.js +0 -51
  523. package/dist/plot.disco-B4KBP6RK.js +0 -102
  524. package/dist/plot.dzi-2UMRV6IF.js +0 -33
  525. package/dist/plot.ssgq-FVZ27Z2K.js +0 -139
  526. package/dist/plot.vaf2cov-3OXCIEAX.js +0 -259
  527. package/dist/plot.wsi-UKTLZSYW.js +0 -36
  528. package/dist/polar2-D6T34ONJ.js +0 -226
  529. package/dist/polar2-D6T34ONJ.js.map +0 -7
  530. package/dist/profileForms-SBNPRIFT.js +0 -441
  531. package/dist/profilePlot-PPI4IDP4.js +0 -54
  532. package/dist/proteinView-URQEZSH5.js +0 -1320
  533. package/dist/proteinView-URQEZSH5.js.map +0 -7
  534. package/dist/qualitative-4O6KAGEA.js +0 -43
  535. package/dist/radar2-ICKCJY4T.js +0 -321
  536. package/dist/radarFacility2-HEBBSM3T.js +0 -329
  537. package/dist/regression-YFQJE2EP.js +0 -56
  538. package/dist/regression.inputs-A2JVBVZ7.js +0 -48
  539. package/dist/regression.inputs.term-CTVNS5MO.js +0 -48
  540. package/dist/regression.inputs.values.table-X7SI6EDO.js +0 -45
  541. package/dist/regression.integration.spec-NRDEVBWS.js +0 -784
  542. package/dist/regression.results-XVB6CIGW.js +0 -40
  543. package/dist/regression.spec-TNB5HBY5.js +0 -708
  544. package/dist/report-5VDIBC2W.js +0 -222
  545. package/dist/sampleScatter.spec-XDW7SCYA.js +0 -202
  546. package/dist/sampleView-FLUSGZCM.js +0 -48
  547. package/dist/samplelst-4WPG5UBN.js +0 -111
  548. package/dist/samplematrix-YJGMSXUJ.js +0 -2198
  549. package/dist/sc-DHU5KSEJ.js +0 -86
  550. package/dist/scatter-UZMWX3DU.js +0 -854
  551. package/dist/scatter.integration.spec-YX5OC3L2.js +0 -1196
  552. package/dist/selectGenomeWithTklst-BVBMVRMQ.js +0 -134
  553. package/dist/singleCellCellType-DADK5UKZ.js +0 -38
  554. package/dist/singleCellCellType.unit.spec-X25RMBJ3.js +0 -160
  555. package/dist/singleCellGeneExpression-3UEZWI4E.js +0 -38
  556. package/dist/singleCellGeneExpression.unit.spec-5GU3JWE6.js +0 -153
  557. package/dist/singleCellPlot-TFRZG73T.js +0 -54
  558. package/dist/singlecell-HQH6EWJO.js +0 -1572
  559. package/dist/singlecell-KR6JYFAY.js +0 -86
  560. package/dist/snp-ACIZ7D5X.js +0 -38
  561. package/dist/snp.unit.spec-653HGJBM.js +0 -176
  562. package/dist/snplocus-AH6KJCVN.js +0 -208
  563. package/dist/spliceevent.a53ss.diagram-MKJLJDOG.js +0 -151
  564. package/dist/spliceevent.exonskip.diagram-PSEVCDH4.js +0 -277
  565. package/dist/spliceevent.noeventdiagram-T2LHGFN7.js +0 -460
  566. package/dist/ssGSEA-QFMYBITZ.js +0 -38
  567. package/dist/ssGSEA.unit.spec-SQW7KFWE.js +0 -88
  568. package/dist/summarizeCnvGeneexp-EVRTBY3L.js +0 -163
  569. package/dist/summarizeGeneexpSurvival-O3MGRS6K.js +0 -108
  570. package/dist/summarizeMutationCnv-RZ2DZ2XO.js +0 -164
  571. package/dist/summarizeMutationDiagnosis-V2DISQTC.js +0 -40
  572. package/dist/summarizeMutationSurvival-FTTWJBUG.js +0 -99
  573. package/dist/summary-QKBTZINC.js +0 -49
  574. package/dist/summary.integration.spec-54HA7BC2.js +0 -414
  575. package/dist/summaryInput-4RLZT6RW.js +0 -235
  576. package/dist/sunburst-SMKD45XD.js +0 -284
  577. package/dist/survival-BAW5ME6J.js +0 -46
  578. package/dist/survival-YQNA3WP7.js +0 -58
  579. package/dist/survival.integration.spec-2AHXNMH2.js +0 -821
  580. package/dist/svgraph-5Z7VAIVR.js +0 -1387
  581. package/dist/svmr-PHD76RV4.js +0 -3842
  582. package/dist/table-GMRAOIWZ.js +0 -200
  583. package/dist/termCollection-MEBY34TJ.js +0 -179
  584. package/dist/termCollection-QLKTRXUR.js +0 -38
  585. package/dist/termCollection.unit.spec-6B53SW2Q.js +0 -208
  586. package/dist/tk-X46SEOL7.js +0 -46
  587. package/dist/tp.ui-XV7CL7CA.js +0 -1459
  588. package/dist/tvs.dt-U6SIZTXW.js +0 -39
  589. package/dist/tvs.dtcnv.categorical-6YGEKMHW.js +0 -40
  590. package/dist/tvs.dtcnv.continuous-CQFEENBO.js +0 -72
  591. package/dist/tvs.dtfusion-NOBT2JPI.js +0 -40
  592. package/dist/tvs.dtsnvindel-6GTCSVAV.js +0 -40
  593. package/dist/tvs.dtsv-PMI4YVI5.js +0 -40
  594. package/dist/tvs.samplelst-HVNYKHXG.js +0 -104
  595. package/dist/tvs.termCollection-EWGTT75Z.js +0 -159
  596. package/dist/violin-MKWRB25Z.js +0 -46
  597. package/dist/violin.integration.spec-CNWJ43SD.js +0 -1425
  598. package/dist/violin.interactivity-UXOMTGSD.js +0 -38
  599. package/dist/violin.renderer-67Q6YGYQ.js +0 -40
  600. package/dist/vocabulary-AKXE7SNU.js +0 -41
  601. /package/dist/{2dmaf-ZCIOFNSJ.js.map → 2dmaf-3D2KTSAN.js.map} +0 -0
  602. /package/dist/{AIProjectAdmin-Z7EA2Y74.js.map → AIProjectAdmin-IGPLMREH.js.map} +0 -0
  603. /package/dist/{AppHeader-4AZ76NN3.js.map → AppHeader-WT5AXGLC.js.map} +0 -0
  604. /package/dist/{BoxPlot-BFVBNQNR.js.map → BoxPlot-AUFITBDB.js.map} +0 -0
  605. /package/dist/{CorrelationVolcano-L5VSJWJF.js.map → CorrelationVolcano-4AZ6Y42O.js.map} +0 -0
  606. /package/dist/{DE-7TPZWAKI.js.map → DE-MWYRMM47.js.map} +0 -0
  607. /package/dist/{DEinput-WQJEXWGY.js.map → DEinput-F3JFK4HF.js.map} +0 -0
  608. /package/dist/{DifferentialAnalysis-FPG7RDNN.js.map → DifferentialAnalysis-ZAVYUYOL.js.map} +0 -0
  609. /package/dist/{Disco-WP2BBL5V.js.map → Disco-Q3O3A2CU.js.map} +0 -0
  610. /package/dist/{Disco.UI-ZYSUA57E.js.map → Disco.UI-QIKPQKTY.js.map} +0 -0
  611. /package/dist/{DmrPlot-V3E7JMPN.js.map → DmrPlot-D7TPJXWH.js.map} +0 -0
  612. /package/dist/{GB-BKLVGYWP.js.map → GB-K57ZGFLA.js.map} +0 -0
  613. /package/dist/{GeneExpInput-7V72SRDT.js.map → GeneExpInput-7UYFJHSX.js.map} +0 -0
  614. /package/dist/{HicApp-IT5YNABL.js.map → HicApp-HPIHJDLQ.js.map} +0 -0
  615. /package/dist/{NumBinaryEditor-7E37MVQO.js.map → NumBinaryEditor-ENHACYTK.js.map} +0 -0
  616. /package/dist/{NumBinaryEditor.unit.spec-C3WVAXMY.js.map → NumBinaryEditor.unit.spec-TNIRFCTU.js.map} +0 -0
  617. /package/dist/{NumContEditor-FEVZJUB4.js.map → NumContEditor-Y4CDFJM2.js.map} +0 -0
  618. /package/dist/{NumContEditor.unit.spec-4IGP657P.js.map → NumContEditor.unit.spec-KES6AJHN.js.map} +0 -0
  619. /package/dist/{NumCustomBinEditor-QC4D63Y5.js.map → NumCustomBinEditor-TRXZ52MH.js.map} +0 -0
  620. /package/dist/{NumCustomBinEditor.unit.spec-USLECMWI.js.map → NumCustomBinEditor.unit.spec-2V5X5YK4.js.map} +0 -0
  621. /package/dist/{NumDiscreteEditor-PRAI76XQ.js.map → NumDiscreteEditor-RXXL3AQ4.js.map} +0 -0
  622. /package/dist/{NumDiscreteEditor.unit.spec-IWL3OCTC.js.map → NumDiscreteEditor.unit.spec-EAFEI66P.js.map} +0 -0
  623. /package/dist/{NumRegularBinEditor-ESL2HAD7.js.map → NumRegularBinEditor-KHIFP2L7.js.map} +0 -0
  624. /package/dist/{NumRegularBinEditor.unit.spec-7LLZAW4Z.js.map → NumRegularBinEditor.unit.spec-ADRNCEAV.js.map} +0 -0
  625. /package/dist/{NumSplineEditor-JZOROO36.js.map → NumSplineEditor-33SUCGNJ.js.map} +0 -0
  626. /package/dist/{NumSplineEditor.unit.spec-3SHSXTC7.js.map → NumSplineEditor.unit.spec-7KTMNABP.js.map} +0 -0
  627. /package/dist/{NumericDensity-SGYRBDCQ.js.map → NumericDensity-PWWJBZUA.js.map} +0 -0
  628. /package/dist/{NumericDensity.unit.spec-Y6JMH6IR.js.map → NumericDensity.unit.spec-V5C43FCP.js.map} +0 -0
  629. /package/dist/{NumericHandler-YG7AMINA.js.map → NumericHandler-A6QSQAPT.js.map} +0 -0
  630. /package/dist/{NumericHandler.unit.spec-CABSMERN.js.map → NumericHandler.unit.spec-SRFEDFCC.js.map} +0 -0
  631. /package/dist/{ProteomeInput-2WPCK72Z.js.map → ProteomeInput-BOI2634T.js.map} +0 -0
  632. /package/dist/{RunChart2-PJWMDWJR.js.map → RunChart2-DJNWYZ5C.js.map} +0 -0
  633. /package/dist/{SC-WVVUFPNU.js.map → SC-ADKHO4MP.js.map} +0 -0
  634. /package/dist/{Volcano-7JI4LUSF.js.map → Volcano-4GJU2666.js.map} +0 -0
  635. /package/dist/{WSIViewer-GDSOEEA6.js.map → WSIViewer-JQKGSN3D.js.map} +0 -0
  636. /package/dist/{WsiSamplesPlot-Z5C3NPF7.js.map → WsiSamplesPlot-PSVYIYI7.js.map} +0 -0
  637. /package/dist/{adSandbox-KQKENDNQ.js.map → adSandbox-AFYF5ULQ.js.map} +0 -0
  638. /package/dist/{app-4OEY56FN.js.map → app-5KDQSFDE.js.map} +0 -0
  639. /package/dist/{app-TGMYXJ4E.js.map → app-PZ5KGBCR.js.map} +0 -0
  640. /package/dist/{bam-3IMX42G5.js.map → bam-AYX4HVPY.js.map} +0 -0
  641. /package/dist/{barchart-44HOJWVS.js.map → barchart-2BMDZGPJ.js.map} +0 -0
  642. /package/dist/{barchart.data-CHNR4XL2.js.map → barchart.data-I33D7SQC.js.map} +0 -0
  643. /package/dist/{barchart.events-XW5OZ5MR.js.map → barchart.events-Z5AL6NU6.js.map} +0 -0
  644. /package/dist/{barchart2-4NU7NWJZ.js.map → barchart2-KFMUPMVS.js.map} +0 -0
  645. /package/dist/{block-OYSZ2JXC.js.map → block-7UW7QCRX.js.map} +0 -0
  646. /package/dist/{block.init-WSIQLW7A.js.map → block.init-CZWCEEID.js.map} +0 -0
  647. /package/dist/{block.mds.expressionrank-2KWOWDW4.js.map → block.mds.expressionrank-2JJYKI2C.js.map} +0 -0
  648. /package/dist/{block.mds.geneboxplot-6ZAD6A5K.js.map → block.mds.geneboxplot-NU45ZP4J.js.map} +0 -0
  649. /package/dist/{block.mds.junction-VQDLHFNG.js.map → block.mds.junction-UVSKHUFR.js.map} +0 -0
  650. /package/dist/{block.mds.svcnv-7OIRG7DQ.js.map → block.mds.svcnv-6JXI63CC.js.map} +0 -0
  651. /package/dist/{block.svg-HXAIFHXM.js.map → block.svg-KAMDKUQX.js.map} +0 -0
  652. /package/dist/{block.tk.aicheck-GTGHCUEN.js.map → block.tk.aicheck-WEKHCRXC.js.map} +0 -0
  653. /package/dist/{block.tk.ase-TAEE2ZHN.js.map → block.tk.ase-MGDGSUQN.js.map} +0 -0
  654. /package/dist/{block.tk.bam-6A26AZ7S.js.map → block.tk.bam-MB2DAFD7.js.map} +0 -0
  655. /package/dist/{block.tk.bedgraphdot-6MYIVRBC.js.map → block.tk.bedgraphdot-VUSURZ6N.js.map} +0 -0
  656. /package/dist/{block.tk.bigwig.ui-GJ7JXRH3.js.map → block.tk.bigwig.ui-WQTN44VK.js.map} +0 -0
  657. /package/dist/{block.tk.hicstraw-3TCDZ2GM.js.map → block.tk.hicstraw-T2JXNKWD.js.map} +0 -0
  658. /package/dist/{block.tk.junction-WDBIP7DK.js.map → block.tk.junction-2JXABLIG.js.map} +0 -0
  659. /package/dist/{block.tk.junction.textmatrixui-QOV3U7AN.js.map → block.tk.junction.textmatrixui-EEB3JUNU.js.map} +0 -0
  660. /package/dist/{block.tk.ld-GCPH66C3.js.map → block.tk.ld-JZBL73US.js.map} +0 -0
  661. /package/dist/{block.tk.menu-YDAIYUGC.js.map → block.tk.menu-VQEPTCE6.js.map} +0 -0
  662. /package/dist/{block.tk.pgv-RWOZAUGA.js.map → block.tk.pgv-PYOPQDYL.js.map} +0 -0
  663. /package/dist/{brainImaging-ZAFU6U2Y.js.map → brainImaging-SYJZZN3K.js.map} +0 -0
  664. /package/dist/{chunk-SKZ37PND.js.map → chunk-26XX7RVV.js.map} +0 -0
  665. /package/dist/{chunk-R4BCNWKE.js.map → chunk-2QWELHBX.js.map} +0 -0
  666. /package/dist/{chunk-XIIAQQ4T.js.map → chunk-3MGF2FZ2.js.map} +0 -0
  667. /package/dist/{chunk-VDPQ2ZV2.js.map → chunk-3S7ZWGND.js.map} +0 -0
  668. /package/dist/{chunk-76PGYH5J.js.map → chunk-4VCBJC3B.js.map} +0 -0
  669. /package/dist/{chunk-NZDQV7ZO.js.map → chunk-53WLN75I.js.map} +0 -0
  670. /package/dist/{chunk-DYVY7D67.js.map → chunk-5GOZWJ7S.js.map} +0 -0
  671. /package/dist/{chunk-TRY57CMI.js.map → chunk-5WKIMNGG.js.map} +0 -0
  672. /package/dist/{chunk-GKBMGKYN.js.map → chunk-5WM3CC5O.js.map} +0 -0
  673. /package/dist/{chunk-GERVYIL4.js.map → chunk-6GI6MDYV.js.map} +0 -0
  674. /package/dist/{chunk-SDMZUHN7.js.map → chunk-7BOPMRFX.js.map} +0 -0
  675. /package/dist/{chunk-5YF3LGLX.js.map → chunk-BYOIIMNZ.js.map} +0 -0
  676. /package/dist/{chunk-S6OIEQXG.js.map → chunk-CGRYUKXD.js.map} +0 -0
  677. /package/dist/{chunk-5GMXV4VC.js.map → chunk-CK47VCG5.js.map} +0 -0
  678. /package/dist/{chunk-DCJUDSRM.js.map → chunk-CRUBP5PT.js.map} +0 -0
  679. /package/dist/{chunk-S6H6OUOA.js.map → chunk-CW2Q5EA7.js.map} +0 -0
  680. /package/dist/{chunk-NPEQHLVG.js.map → chunk-E7UJR2YK.js.map} +0 -0
  681. /package/dist/{chunk-B3M3AZPL.js.map → chunk-ENZZUMVY.js.map} +0 -0
  682. /package/dist/{chunk-PSQETQZZ.js.map → chunk-FRGACC2C.js.map} +0 -0
  683. /package/dist/{chunk-3I7TUGLD.js.map → chunk-FZ63VOSX.js.map} +0 -0
  684. /package/dist/{chunk-TXJTOTIQ.js.map → chunk-GGRR4NXW.js.map} +0 -0
  685. /package/dist/{chunk-3JL2HBGE.js.map → chunk-I2LTCBTM.js.map} +0 -0
  686. /package/dist/{chunk-5TKVUSMQ.js.map → chunk-J5SV3MFB.js.map} +0 -0
  687. /package/dist/{chunk-IWMWT7O7.js.map → chunk-J7X5JRRI.js.map} +0 -0
  688. /package/dist/{chunk-TEQ2PC7Z.js.map → chunk-JDPU6NES.js.map} +0 -0
  689. /package/dist/{chunk-QWOZ2QDM.js.map → chunk-JEZIKGZI.js.map} +0 -0
  690. /package/dist/{chunk-I2RRWDYV.js.map → chunk-JPH5EVVW.js.map} +0 -0
  691. /package/dist/{chunk-DNM2DKYE.js.map → chunk-KQYXXICJ.js.map} +0 -0
  692. /package/dist/{chunk-5ITQVR2P.js.map → chunk-L72Y4QA2.js.map} +0 -0
  693. /package/dist/{chunk-7JXLWRVZ.js.map → chunk-LK3BBGUJ.js.map} +0 -0
  694. /package/dist/{chunk-7YWFO7CJ.js.map → chunk-LYPDXJPX.js.map} +0 -0
  695. /package/dist/{chunk-Y2Z4XDHA.js.map → chunk-MEY5OBDJ.js.map} +0 -0
  696. /package/dist/{chunk-K7UIR22L.js.map → chunk-MW3PIRGF.js.map} +0 -0
  697. /package/dist/{chunk-GS7SQKJT.js.map → chunk-NNMOXQTU.js.map} +0 -0
  698. /package/dist/{chunk-34SAHEQU.js.map → chunk-NV6JVKDN.js.map} +0 -0
  699. /package/dist/{chunk-DBFPAZG3.js.map → chunk-OMBRJBQV.js.map} +0 -0
  700. /package/dist/{chunk-CA2AOIHR.js.map → chunk-PEBOVJSD.js.map} +0 -0
  701. /package/dist/{chunk-SY63VCQB.js.map → chunk-PJXF4IRZ.js.map} +0 -0
  702. /package/dist/{chunk-HURY7IJE.js.map → chunk-PKCYPYWW.js.map} +0 -0
  703. /package/dist/{chunk-GRNZWYOJ.js.map → chunk-QIY7HLC5.js.map} +0 -0
  704. /package/dist/{chunk-G6WVVRDA.js.map → chunk-QMI2X23H.js.map} +0 -0
  705. /package/dist/{chunk-XUFWJJM5.js.map → chunk-QOE7MB4X.js.map} +0 -0
  706. /package/dist/{chunk-JSEMZPAO.js.map → chunk-QSMU6K5D.js.map} +0 -0
  707. /package/dist/{chunk-VJH3NP42.js.map → chunk-RBIBHQTL.js.map} +0 -0
  708. /package/dist/{chunk-HONXMORI.js.map → chunk-RG5ABFA2.js.map} +0 -0
  709. /package/dist/{chunk-WKMZ4ZQ3.js.map → chunk-RRJGFE2S.js.map} +0 -0
  710. /package/dist/{chunk-DVH6K2NP.js.map → chunk-RTTPFI7N.js.map} +0 -0
  711. /package/dist/{chunk-NPTHYZY4.js.map → chunk-T2CG7BVN.js.map} +0 -0
  712. /package/dist/{chunk-WC62ZAWT.js.map → chunk-U3DKYKV7.js.map} +0 -0
  713. /package/dist/{chunk-BLKF2SE6.js.map → chunk-UQHM3F6B.js.map} +0 -0
  714. /package/dist/{chunk-O7Z7SQCS.js.map → chunk-VXKO2ONI.js.map} +0 -0
  715. /package/dist/{chunk-W3LVNVG3.js.map → chunk-W3MCIBAP.js.map} +0 -0
  716. /package/dist/{chunk-QZVCFDJ7.js.map → chunk-WH236OZ6.js.map} +0 -0
  717. /package/dist/{chunk-UT2PKKQ4.js.map → chunk-WMELUFVS.js.map} +0 -0
  718. /package/dist/{chunk-X27TRPIZ.js.map → chunk-WS3NUPNV.js.map} +0 -0
  719. /package/dist/{chunk-L75HW457.js.map → chunk-XIQNS2HN.js.map} +0 -0
  720. /package/dist/{chunk-IOQV2VX3.js.map → chunk-YKPLUIWP.js.map} +0 -0
  721. /package/dist/{chunk-MQQRTH4U.js.map → chunk-YRQ5V7DQ.js.map} +0 -0
  722. /package/dist/{chunk-YFKJ2TMX.js.map → chunk-ZK226W6V.js.map} +0 -0
  723. /package/dist/{chunk-H5NNQO2V.js.map → chunk-ZTOABVVA.js.map} +0 -0
  724. /package/dist/{chunk-OSWTQVAX.js.map → chunk-ZUTPAYSS.js.map} +0 -0
  725. /package/dist/{condition-XKEW2LCM.js.map → condition-SZZS77TK.js.map} +0 -0
  726. /package/dist/{controls-4RFWTHFH.js.map → controls-ZBDTHWOT.js.map} +0 -0
  727. /package/dist/{controls.config-VHH2IGCI.js.map → controls.config-MTBN2XPW.js.map} +0 -0
  728. /package/dist/{correlation-HGAMIIPH.js.map → correlation-DHEH5FT4.js.map} +0 -0
  729. /package/dist/{cuminc-EHW6IH6V.js.map → cuminc-TM3SMOJ2.js.map} +0 -0
  730. /package/dist/{cuminc.integration.spec-B3EOIE4K.js.map → cuminc.integration.spec-NEBXRMKB.js.map} +0 -0
  731. /package/dist/{customdata.inputui-IPJHL7BX.js.map → customdata.inputui-5ZEKFWYV.js.map} +0 -0
  732. /package/dist/{dataDownload-GYFEC6XG.js.map → dataDownload-XZ4AC6QY.js.map} +0 -0
  733. /package/dist/{dataDownload.integration.spec-V7WQ6AMV.js.map → dataDownload.integration.spec-O4YQKAOJ.js.map} +0 -0
  734. /package/dist/{databrowser.ui-TFAJVFFF.js.map → databrowser.ui-V4HQMZ4X.js.map} +0 -0
  735. /package/dist/{dictionary-2ZSMOJCN.js.map → dictionary-RAHC3OA7.js.map} +0 -0
  736. /package/dist/{dnaMethylation-RHNO5DAC.js.map → dnaMethylation-ZUHHG7Q2.js.map} +0 -0
  737. /package/dist/{dnaMethylation.integration.spec-ET7OLMNC.js.map → dnaMethylation.integration.spec-JZ6ZSF5L.js.map} +0 -0
  738. /package/dist/{dofetch-UGCQ3OVW.js.map → dofetch-77N4NDDM.js.map} +0 -0
  739. /package/dist/{e2pca-SLRCDKF5.js.map → e2pca-K7IFKNTZ.js.map} +0 -0
  740. /package/dist/{ep-FOFTKVBH.js.map → ep-4OIFIMZH.js.map} +0 -0
  741. /package/dist/{expclust.gdc.spec-FNOOSLCC.js.map → expclust.gdc.spec-OJD7ENKA.js.map} +0 -0
  742. /package/dist/{facet-UO5A7AGS.js.map → facet-SZAF3QW6.js.map} +0 -0
  743. /package/dist/{forms2-SFV4HHBA.js.map → forms2-TBRF2RI5.js.map} +0 -0
  744. /package/dist/{gb-3KR6MAGB.js.map → gb-I5J74SHP.js.map} +0 -0
  745. /package/dist/{geneExpClustering-BCDXKSNU.js.map → geneExpClustering-OSS4OCN6.js.map} +0 -0
  746. /package/dist/{geneExpression-CXQ5HFEP.js.map → geneExpression-IHVMJGOG.js.map} +0 -0
  747. /package/dist/{geneExpression-5UPKETEZ.js.map → geneExpression-WKYVSE45.js.map} +0 -0
  748. /package/dist/{geneExpression.unit.spec-7FVVD4UF.js.map → geneExpression.unit.spec-QP6CLYHP.js.map} +0 -0
  749. /package/dist/{geneORA-UC45CL2U.js.map → geneORA-65PHOTHN.js.map} +0 -0
  750. /package/dist/{geneRanking-OOQWVUIG.js.map → geneRanking-XCU3NX4J.js.map} +0 -0
  751. /package/dist/{geneVariant-BQFB7LKZ.js.map → geneVariant-CZM3XP7X.js.map} +0 -0
  752. /package/dist/{geneVariant-BYN7EWTT.js.map → geneVariant-IMDFPV2L.js.map} +0 -0
  753. /package/dist/{geneVariant.integration.spec-OESHXKBV.js.map → geneVariant.integration.spec-FOONVTYD.js.map} +0 -0
  754. /package/dist/{genefusion.ui-TOSPIGTE.js.map → genefusion.ui-UZM2YGIR.js.map} +0 -0
  755. /package/dist/{geneset-57DECCND.js.map → geneset-IGG77MNZ.js.map} +0 -0
  756. /package/dist/{genomeBrowser.spec-CQP5JG35.js.map → genomeBrowser.spec-CN2XNZQF.js.map} +0 -0
  757. /package/dist/{grin2-G4MBI5UC.js.map → grin2-367QGSOU.js.map} +0 -0
  758. /package/dist/{gsea-VYAXSBM4.js.map → gsea-RJ767G5U.js.map} +0 -0
  759. /package/dist/{hierCluster-4QKMY7GP.js.map → hierCluster-3D425AUU.js.map} +0 -0
  760. /package/dist/{hierCluster-GFPFVB3Q.js.map → hierCluster-GIIB6OEC.js.map} +0 -0
  761. /package/dist/{hierCluster.config-3A24DEKA.js.map → hierCluster.config-ENEOWYOS.js.map} +0 -0
  762. /package/dist/{hierCluster.integration.spec-6NTJYVN4.js.map → hierCluster.integration.spec-IOA3PVAN.js.map} +0 -0
  763. /package/dist/{hierCluster.interactivity-B2T6WS5R.js.map → hierCluster.interactivity-VITUF5RM.js.map} +0 -0
  764. /package/dist/{hierCluster.renderers-R3RLK6BI.js.map → hierCluster.renderers-G3274UYA.js.map} +0 -0
  765. /package/dist/{imagePlot-YZBZRENG.js.map → imagePlot-7VH7VFWD.js.map} +0 -0
  766. /package/dist/{importPlot-LIXKD3WJ.js.map → importPlot-OKOYX2NU.js.map} +0 -0
  767. /package/dist/{isoformExpression-ZZ5DL6AE.js.map → isoformExpression-4SJQZFLP.js.map} +0 -0
  768. /package/dist/{isoformExpression.unit.spec-IH4247TT.js.map → isoformExpression.unit.spec-3MQQZEPZ.js.map} +0 -0
  769. /package/dist/{launch.adhoc-3YWVAF7R.js.map → launch.adhoc-MQKVVUV7.js.map} +0 -0
  770. /package/dist/{leftlabel.sample-XFM45ZKO.js.map → leftlabel.sample-JPE6CXZU.js.map} +0 -0
  771. /package/dist/{lollipop-7K5R5KHB.js.map → lollipop-DMM3QYKI.js.map} +0 -0
  772. /package/dist/{maf-SQVJHNUY.js.map → maf-TQKKVLNR.js.map} +0 -0
  773. /package/dist/{maftimeline-RCPASNN2.js.map → maftimeline-BXBAXKAI.js.map} +0 -0
  774. /package/dist/{matrix-KHTDB56P.js.map → matrix-AWVEEUKZ.js.map} +0 -0
  775. /package/dist/{matrix-YTHWIMBP.js.map → matrix-N3YUJXLP.js.map} +0 -0
  776. /package/dist/{matrix.cells-KNDVYI2S.js.map → matrix.cells-E3LEVA7U.js.map} +0 -0
  777. /package/dist/{matrix.config-6BHBCTXE.js.map → matrix.config-QPNAC2EY.js.map} +0 -0
  778. /package/dist/{matrix.data-VWJQ7N4L.js.map → matrix.data-FIQGPFTI.js.map} +0 -0
  779. /package/dist/{matrix.groups-5AUHEO52.js.map → matrix.groups-BGMZZ6CM.js.map} +0 -0
  780. /package/dist/{matrix.integration.spec-Q2BXNCUO.js.map → matrix.integration.spec-OA3FJ2PN.js.map} +0 -0
  781. /package/dist/{matrix.interactivity-FEEWY34M.js.map → matrix.interactivity-LKLF5ZQN.js.map} +0 -0
  782. /package/dist/{matrix.layout-FWWM6QQO.js.map → matrix.layout-ORYBQUKT.js.map} +0 -0
  783. /package/dist/{matrix.legend-QT3PMREX.js.map → matrix.legend-RJAFOZHQ.js.map} +0 -0
  784. /package/dist/{matrix.renderers-M6MJO5IU.js.map → matrix.renderers-TLZSYHZR.js.map} +0 -0
  785. /package/dist/{matrix.serieses-NTKMKT22.js.map → matrix.serieses-GJWHSBG4.js.map} +0 -0
  786. /package/dist/{matrix.sort-TTHPJ4XC.js.map → matrix.sort-KIJENIT2.js.map} +0 -0
  787. /package/dist/{matrix.sort.unit.spec-XZI2KPNC.js.map → matrix.sort.unit.spec-DRFCEZGX.js.map} +0 -0
  788. /package/dist/{matrix.sorterUi.unit.spec-6FVHTGSN.js.map → matrix.sorterUi.unit.spec-QQH3ITTW.js.map} +0 -0
  789. /package/dist/{mavb-FZDN27QY.js.map → mavb-ZK5UKXEO.js.map} +0 -0
  790. /package/dist/{mds.fimo-SSFKQ3BH.js.map → mds.fimo-MHPHQB4X.js.map} +0 -0
  791. /package/dist/{mds.samplescatterplot-BMTTX3TB.js.map → mds.samplescatterplot-LRL5SXJ5.js.map} +0 -0
  792. /package/dist/{mds.survivalplot-PL75RDYI.js.map → mds.survivalplot-R5N6OHZ2.js.map} +0 -0
  793. /package/dist/{numericDictTermCluster-NJUXCQYH.js.map → numericDictTermCluster-OMXIURRD.js.map} +0 -0
  794. /package/dist/{oncomatrix-BZDCCEWH.js.map → oncomatrix-FA3ELKNE.js.map} +0 -0
  795. /package/dist/{oncomatrix.spec-5A4A4JLV.js.map → oncomatrix.spec-3K7ONINO.js.map} +0 -0
  796. /package/dist/{plot.2dvaf-AC7LW56S.js.map → plot.2dvaf-P6CRZWB7.js.map} +0 -0
  797. /package/dist/{plot.app-DOOWDQ3U.js.map → plot.app-XOQVTISH.js.map} +0 -0
  798. /package/dist/{plot.barplot-RNJWREG5.js.map → plot.barplot-YDT4K3YZ.js.map} +0 -0
  799. /package/dist/{plot.boxplot-CRAEUBQF.js.map → plot.boxplot-GHEVLVJU.js.map} +0 -0
  800. /package/dist/{plot.brainImaging-ZESEULN6.js.map → plot.brainImaging-NENXKZEP.js.map} +0 -0
  801. /package/dist/{plot.disco-B4KBP6RK.js.map → plot.disco-3B7LZ2XE.js.map} +0 -0
  802. /package/dist/{plot.dzi-2UMRV6IF.js.map → plot.dzi-F7NW65WQ.js.map} +0 -0
  803. /package/dist/{plot.ssgq-FVZ27Z2K.js.map → plot.ssgq-BAUIBB3D.js.map} +0 -0
  804. /package/dist/{plot.vaf2cov-3OXCIEAX.js.map → plot.vaf2cov-XBLM7B4M.js.map} +0 -0
  805. /package/dist/{plot.wsi-UKTLZSYW.js.map → plot.wsi-YWILGUDN.js.map} +0 -0
  806. /package/dist/{profileForms-SBNPRIFT.js.map → profileForms-LYWVFIVQ.js.map} +0 -0
  807. /package/dist/{profilePlot-PPI4IDP4.js.map → profilePlot-TSXR4EGL.js.map} +0 -0
  808. /package/dist/{qualitative-4O6KAGEA.js.map → qualitative-VNY32ONL.js.map} +0 -0
  809. /package/dist/{radar2-ICKCJY4T.js.map → radar2-YVHLSCAM.js.map} +0 -0
  810. /package/dist/{radarFacility2-HEBBSM3T.js.map → radarFacility2-K4OA7FYK.js.map} +0 -0
  811. /package/dist/{regression-YFQJE2EP.js.map → regression-KKC7Y57Y.js.map} +0 -0
  812. /package/dist/{regression.inputs-A2JVBVZ7.js.map → regression.inputs-UR2VLW5P.js.map} +0 -0
  813. /package/dist/{regression.inputs.term-CTVNS5MO.js.map → regression.inputs.term-QECG7D3W.js.map} +0 -0
  814. /package/dist/{regression.inputs.values.table-X7SI6EDO.js.map → regression.inputs.values.table-UANMD46V.js.map} +0 -0
  815. /package/dist/{regression.integration.spec-NRDEVBWS.js.map → regression.integration.spec-UCUHBCZY.js.map} +0 -0
  816. /package/dist/{regression.results-XVB6CIGW.js.map → regression.results-TNVEGETD.js.map} +0 -0
  817. /package/dist/{regression.spec-TNB5HBY5.js.map → regression.spec-3NSFMTI7.js.map} +0 -0
  818. /package/dist/{report-5VDIBC2W.js.map → report-2FNKLTYA.js.map} +0 -0
  819. /package/dist/{sampleScatter.spec-XDW7SCYA.js.map → sampleScatter.spec-5SC2AJHW.js.map} +0 -0
  820. /package/dist/{sampleView-FLUSGZCM.js.map → sampleView-SU7VZCJH.js.map} +0 -0
  821. /package/dist/{samplelst-4WPG5UBN.js.map → samplelst-JGSTML6J.js.map} +0 -0
  822. /package/dist/{samplematrix-YJGMSXUJ.js.map → samplematrix-FO4GGDRT.js.map} +0 -0
  823. /package/dist/{sc-DHU5KSEJ.js.map → sc-LDUHVPII.js.map} +0 -0
  824. /package/dist/{scatter-UZMWX3DU.js.map → scatter-QAEMBYHW.js.map} +0 -0
  825. /package/dist/{scatter.integration.spec-YX5OC3L2.js.map → scatter.integration.spec-FTD4PDMI.js.map} +0 -0
  826. /package/dist/{selectGenomeWithTklst-BVBMVRMQ.js.map → selectGenomeWithTklst-G3XUX3KK.js.map} +0 -0
  827. /package/dist/{singleCellCellType-DADK5UKZ.js.map → singleCellCellType-QKA4QCLC.js.map} +0 -0
  828. /package/dist/{singleCellCellType.unit.spec-X25RMBJ3.js.map → singleCellCellType.unit.spec-KIPKWJLB.js.map} +0 -0
  829. /package/dist/{singleCellGeneExpression-3UEZWI4E.js.map → singleCellGeneExpression-O2QVJOG4.js.map} +0 -0
  830. /package/dist/{singleCellGeneExpression.unit.spec-5GU3JWE6.js.map → singleCellGeneExpression.unit.spec-6ATWTQTO.js.map} +0 -0
  831. /package/dist/{singleCellPlot-TFRZG73T.js.map → singleCellPlot-HZOSW3FB.js.map} +0 -0
  832. /package/dist/{singlecell-KR6JYFAY.js.map → singlecell-3OX4TSQ4.js.map} +0 -0
  833. /package/dist/{singlecell-HQH6EWJO.js.map → singlecell-EUUIY2JJ.js.map} +0 -0
  834. /package/dist/{snp-ACIZ7D5X.js.map → snp-UVKGSROJ.js.map} +0 -0
  835. /package/dist/{snp.unit.spec-653HGJBM.js.map → snp.unit.spec-YHIZ5ZJW.js.map} +0 -0
  836. /package/dist/{snplocus-AH6KJCVN.js.map → snplocus-FANKGKI4.js.map} +0 -0
  837. /package/dist/{spliceevent.a53ss.diagram-MKJLJDOG.js.map → spliceevent.a53ss.diagram-QQXYYX7J.js.map} +0 -0
  838. /package/dist/{spliceevent.exonskip.diagram-PSEVCDH4.js.map → spliceevent.exonskip.diagram-R265JOH6.js.map} +0 -0
  839. /package/dist/{spliceevent.noeventdiagram-T2LHGFN7.js.map → spliceevent.noeventdiagram-UMAQOCVY.js.map} +0 -0
  840. /package/dist/{ssGSEA-QFMYBITZ.js.map → ssGSEA-F4BZ3NYO.js.map} +0 -0
  841. /package/dist/{ssGSEA.unit.spec-SQW7KFWE.js.map → ssGSEA.unit.spec-OQQGQYPJ.js.map} +0 -0
  842. /package/dist/{summarizeCnvGeneexp-EVRTBY3L.js.map → summarizeCnvGeneexp-LX22NXFF.js.map} +0 -0
  843. /package/dist/{summarizeGeneexpSurvival-O3MGRS6K.js.map → summarizeGeneexpSurvival-N7LXAK2G.js.map} +0 -0
  844. /package/dist/{summarizeMutationCnv-RZ2DZ2XO.js.map → summarizeMutationCnv-QC3EARCV.js.map} +0 -0
  845. /package/dist/{summarizeMutationDiagnosis-V2DISQTC.js.map → summarizeMutationDiagnosis-H6KJWLLC.js.map} +0 -0
  846. /package/dist/{summarizeMutationSurvival-FTTWJBUG.js.map → summarizeMutationSurvival-JAFSWJVZ.js.map} +0 -0
  847. /package/dist/{summary-QKBTZINC.js.map → summary-D5MSBQIS.js.map} +0 -0
  848. /package/dist/{summary.integration.spec-54HA7BC2.js.map → summary.integration.spec-KJPNP7X2.js.map} +0 -0
  849. /package/dist/{summaryInput-4RLZT6RW.js.map → summaryInput-47JBGPNE.js.map} +0 -0
  850. /package/dist/{sunburst-SMKD45XD.js.map → sunburst-PUZYZZGK.js.map} +0 -0
  851. /package/dist/{survival-YQNA3WP7.js.map → survival-LGJBYXFR.js.map} +0 -0
  852. /package/dist/{survival-BAW5ME6J.js.map → survival-SMOKVDGO.js.map} +0 -0
  853. /package/dist/{survival.integration.spec-2AHXNMH2.js.map → survival.integration.spec-ORC3LCVK.js.map} +0 -0
  854. /package/dist/{svgraph-5Z7VAIVR.js.map → svgraph-GWDKHIDQ.js.map} +0 -0
  855. /package/dist/{svmr-PHD76RV4.js.map → svmr-RRA6OUVP.js.map} +0 -0
  856. /package/dist/{table-GMRAOIWZ.js.map → table-AC2DX55F.js.map} +0 -0
  857. /package/dist/{termCollection-MEBY34TJ.js.map → termCollection-4OVZAKYZ.js.map} +0 -0
  858. /package/dist/{termCollection-QLKTRXUR.js.map → termCollection-MPFFNNMF.js.map} +0 -0
  859. /package/dist/{termCollection.unit.spec-6B53SW2Q.js.map → termCollection.unit.spec-S4QSTY4S.js.map} +0 -0
  860. /package/dist/{tk-X46SEOL7.js.map → tk-PFWI2HAC.js.map} +0 -0
  861. /package/dist/{tp.ui-XV7CL7CA.js.map → tp.ui-TKAJ7DRO.js.map} +0 -0
  862. /package/dist/{tvs.dt-U6SIZTXW.js.map → tvs.dt-6NDINORK.js.map} +0 -0
  863. /package/dist/{tvs.dtcnv.categorical-6YGEKMHW.js.map → tvs.dtcnv.categorical-2RHUN643.js.map} +0 -0
  864. /package/dist/{tvs.dtcnv.continuous-CQFEENBO.js.map → tvs.dtcnv.continuous-GIPVPDBD.js.map} +0 -0
  865. /package/dist/{tvs.dtfusion-NOBT2JPI.js.map → tvs.dtfusion-ZLXTZ7SA.js.map} +0 -0
  866. /package/dist/{tvs.dtsnvindel-6GTCSVAV.js.map → tvs.dtsnvindel-CRS5CL42.js.map} +0 -0
  867. /package/dist/{tvs.dtsv-PMI4YVI5.js.map → tvs.dtsv-SG45TZWQ.js.map} +0 -0
  868. /package/dist/{tvs.samplelst-HVNYKHXG.js.map → tvs.samplelst-NQ5BKEGM.js.map} +0 -0
  869. /package/dist/{tvs.termCollection-EWGTT75Z.js.map → tvs.termCollection-HOVUO7ZH.js.map} +0 -0
  870. /package/dist/{violin-MKWRB25Z.js.map → violin-FGGULOXU.js.map} +0 -0
  871. /package/dist/{violin.integration.spec-CNWJ43SD.js.map → violin.integration.spec-T5Y6URJK.js.map} +0 -0
  872. /package/dist/{violin.interactivity-UXOMTGSD.js.map → violin.interactivity-6RGFTQDW.js.map} +0 -0
  873. /package/dist/{violin.renderer-67Q6YGYQ.js.map → violin.renderer-63UTDZVK.js.map} +0 -0
  874. /package/dist/{vocabulary-AKXE7SNU.js.map → vocabulary-YQXR4H5J.js.map} +0 -0
@@ -1,1943 +0,0 @@
1
- import {
2
- matrix_data_exports
3
- } from "./chunk-YFKJ2TMX.js";
4
- import {
5
- matrix_layout_exports
6
- } from "./chunk-I2RRWDYV.js";
7
- import {
8
- matrix_serieses_exports
9
- } from "./chunk-Y2Z4XDHA.js";
10
- import {
11
- matrix_legend_exports
12
- } from "./chunk-DCJUDSRM.js";
13
- import {
14
- matrix_groups_exports
15
- } from "./chunk-UT2PKKQ4.js";
16
- import {
17
- setComputedConfig
18
- } from "./chunk-34SAHEQU.js";
19
- import {
20
- setMatrixDom
21
- } from "./chunk-HUBO743S.js";
22
- import {
23
- setInteractivity
24
- } from "./chunk-7JXLWRVZ.js";
25
- import {
26
- setRenderers
27
- } from "./chunk-HONXMORI.js";
28
- import {
29
- MatrixCluster
30
- } from "./chunk-DDKS3MV3.js";
31
- import {
32
- getSorterUi
33
- } from "./chunk-PKDJVK2F.js";
34
- import {
35
- GeneSetEditUI,
36
- GeneSetEditUIwithTabs,
37
- PlotBase,
38
- TwRouter,
39
- fillTermWrapper,
40
- get$id,
41
- getCombinedTermFilter,
42
- getGEunit,
43
- initByInput,
44
- make_one_checkbox,
45
- make_radios,
46
- rebaseGroupFilter,
47
- routedTermTypes,
48
- sayerror,
49
- svgLegend,
50
- svgScroll,
51
- to_svg,
52
- zoom
53
- } from "./chunk-UK3PTE3P.js";
54
- import {
55
- Menu
56
- } from "./chunk-HYOEWQ5P.js";
57
- import {
58
- icons
59
- } from "./chunk-5X6J6UAT.js";
60
- import {
61
- copyMerge,
62
- deepEqual,
63
- getCompInit
64
- } from "./chunk-5V43Y2RC.js";
65
- import {
66
- TermTypes,
67
- isNumericTerm
68
- } from "./chunk-XOCO3LVN.js";
69
- import {
70
- dt2label,
71
- dtcnv,
72
- dtfusionrna,
73
- dtsnvindel,
74
- dtsv,
75
- mclass,
76
- morigin
77
- } from "./chunk-EBKERML3.js";
78
- import {
79
- convertUnits
80
- } from "./chunk-JNITUVXP.js";
81
- import {
82
- select_default
83
- } from "./chunk-I6Y4O3RR.js";
84
-
85
- // plots/matrix/matrix.controls.samples.ts
86
- function setSamplesBtn(self2, s) {
87
- const l = s.controlLabels;
88
- const controls = self2;
89
- const parent = self2.parent;
90
- const rows = [
91
- {
92
- label: `Maximum # ${l.Samples}`,
93
- title: `Limit the number of displayed ${l.samples}`,
94
- type: "number",
95
- chartType: "matrix",
96
- settingsKey: "maxSample",
97
- getDisplayStyle(plot) {
98
- return plot.chartType == "hierCluster" ? "none" : "table-row";
99
- }
100
- },
101
- {
102
- label: `Sort ${l.Sample} Groups`,
103
- title: `Set how to sort ${l.sample} groups`,
104
- type: "radio",
105
- chartType: "matrix",
106
- settingsKey: "sortSampleGrpsBy",
107
- options: [
108
- {
109
- label: "Predefined or Group Name",
110
- value: "name",
111
- title: `Sort by group name`
112
- },
113
- {
114
- label: `${l.Sample} Count`,
115
- value: "sampleCount",
116
- title: `Sort by the number of samples in the group`
117
- },
118
- {
119
- label: `Hits`,
120
- value: "hits",
121
- title: `Sort by the total number of variants for every ${l.sample} in the group`
122
- }
123
- ],
124
- getDisplayStyle(plot) {
125
- return plot.divideBy && !plot.hierCluster ? "table-row" : "none";
126
- }
127
- },
128
- {
129
- label: `${l.Sample} Group Label Character Limit`,
130
- title: `Truncate the ${l.sample} group label if it exceeds this maximum number of characters`,
131
- type: "number",
132
- chartType: "matrix",
133
- settingsKey: "sampleGrpLabelMaxChars",
134
- getDisplayStyle(plot) {
135
- return plot.divideBy && !plot.hierCluster ? "table-row" : "none";
136
- }
137
- },
138
- {
139
- label: `${l.Sample} Label Character Limit`,
140
- title: `Truncate the ${l.sample} label if it exceeds this maximum number of characters`,
141
- type: "number",
142
- chartType: "matrix",
143
- settingsKey: "collabelmaxchars"
144
- },
145
- {
146
- label: `Toggle sample labels`,
147
- title: `Do not automatically show sample labels based on column width`,
148
- type: "radio",
149
- chartType: "matrix",
150
- settingsKey: "sampleLabelsToggle",
151
- styles: { display: "inline-block" },
152
- options: [
153
- { label: `Based on column width`, value: "auto" },
154
- { label: "Always hide", value: "hide" }
155
- ]
156
- },
157
- {
158
- label: `Group ${l.Samples} By`,
159
- title: `Select a variable with discrete values to group ${l.samples}`,
160
- type: "term",
161
- chartType: "matrix",
162
- configKey: "divideBy",
163
- vocabApi: self2.opts.app.vocabApi,
164
- state: {
165
- vocab: self2.opts.vocab
166
- //activeCohort: appState.activeCohort
167
- },
168
- processInput: async (tw) => {
169
- if (tw?.term && isNumericTerm(tw.term)) {
170
- tw.q = { ...tw.q, mode: "discrete" };
171
- }
172
- if (tw) await fillTermWrapper(tw, self2.opts.app.vocabApi);
173
- return tw;
174
- },
175
- processConfig: (config) => {
176
- if (self2.parent.chartType == "hierCluster" && config["divideBy"]) {
177
- config.settings = {
178
- hierCluster: {
179
- yDendrogramHeight: 0,
180
- clusterSamples: false
181
- }
182
- };
183
- }
184
- if (self2.parent.config.divideBy)
185
- config.legendValueFilter = self2.parent.mayRemoveTvsEntry(self2.parent.config.divideBy);
186
- },
187
- getBodyParams: () => {
188
- const currentGeneNames = self2.parent.termOrder.filter((t) => t.tw.term.type === "geneVariant").map(
189
- (t) => t.tw.term.chr ? `${t.tw.term.chr}:${t.tw.term.start}-${t.tw.term.stop}` : t.tw.term.gene || t.tw.term.name
190
- );
191
- if (currentGeneNames.length) return { currentGeneNames };
192
- return {};
193
- }
194
- }
195
- ];
196
- rows.push({
197
- label: `Sort ${l.Sample} Priority`,
198
- title: `Set how to sort ${l.samples}`,
199
- type: "custom",
200
- // the "input" argument is created by controls
201
- init(input) {
202
- const m = parent.config.settings.matrix;
203
- if (!controls.activeTab) controls.activeTab = "basic";
204
- input.dom.inputTd.style("padding", "5px");
205
- const btnsDiv = input.dom.inputTd.append("div").style("margin-bottom", "5px");
206
- const basicBtn = btnsDiv.append("div").style("display", "inline-block").style("padding-right", "5px").style("border-right", "2px solid black").style("text-decoration", controls.activeTab == "basic" ? "underline" : "").style("cursor", "pointer").html("Basic").on("click", () => {
207
- controls.activeTab = "basic";
208
- basicBtn.style("text-decoration", "underline");
209
- advancedBtn.style("text-decoration", "");
210
- basicDiv.style("display", "");
211
- advancedDiv.style("display", "none");
212
- });
213
- const advancedBtn = btnsDiv.append("div").style("display", "inline-block").style("margin-left", "5px").style("text-decoration", controls.activeTab == "advanced" ? "underline" : "").style("cursor", "pointer").html("Advanced").on("click", () => {
214
- controls.activeTab = "advanced";
215
- basicBtn.style("text-decoration", "");
216
- advancedBtn.style("text-decoration", "underline");
217
- basicDiv.style("display", "none");
218
- advancedDiv.style("display", "");
219
- });
220
- const basicDiv = input.dom.inputTd.append("div").style("display", controls.activeTab == "basic" ? "" : "none");
221
- const ssmDiv = basicDiv.append("div");
222
- ssmDiv.append("span").html("SSM");
223
- const { inputs } = make_radios({
224
- // holder, options, callback, styles
225
- holder: ssmDiv.append("span"),
226
- options: [
227
- { label: "by consequence", value: "consequence", checked: m.sortByMutation === "consequence" },
228
- { label: "by presence", value: "presence", checked: m.sortByMutation === "presence" }
229
- ],
230
- styles: {
231
- display: "inline-block"
232
- },
233
- callback: (sortByMutation) => {
234
- const sortOptions = parent.config.settings.matrix.sortOptions;
235
- const activeOption = sortOptions.a;
236
- const mutTb = activeOption.sortPriority[0].tiebreakers[1];
237
- mutTb.disabled = !sortByMutation;
238
- mutTb.isOrdered = sortByMutation === "consequence";
239
- parent.app.dispatch({
240
- type: "plot_edit",
241
- id: parent.id,
242
- config: {
243
- settings: {
244
- matrix: {
245
- sortByMutation,
246
- // needed to show the correct status for checkbox, but actual sorting behavior
247
- sortOptions
248
- // is based on sortOptions.a[*].tiebreaker[*][disabled, isOrdered]
249
- }
250
- }
251
- }
252
- });
253
- }
254
- });
255
- inputs.style("margin", "2px 0 0 2px").style("vertical-align", "top");
256
- const cnvDiv = basicDiv.append("div").style("display", m.showMatrixCNV != "none" && !m.allMatrixCNVHidden ? "block" : "none");
257
- cnvDiv.append("span").html("CNV");
258
- const checkbox = make_one_checkbox({
259
- holder: cnvDiv.append("span"),
260
- divstyle: { display: "inline-block" },
261
- checked: m.sortByCNV,
262
- labeltext: "sort by CNV",
263
- callback: () => {
264
- const sortByCNV = checkbox.property("checked");
265
- const sortOptions = parent.config.settings.matrix.sortOptions;
266
- const activeOption = sortOptions.a;
267
- const cnvTb = activeOption.sortPriority[0].tiebreakers[2];
268
- cnvTb.disabled = !sortByCNV;
269
- cnvTb.isOrdered = sortByCNV;
270
- parent.app.dispatch({
271
- type: "plot_edit",
272
- id: parent.id,
273
- config: {
274
- settings: {
275
- matrix: {
276
- sortByCNV,
277
- // needed to show the correct status for checkbox, but actual sorting behavior
278
- sortOptions
279
- // is based on sortOptions.a[*].tiebreaker[*][disabled, isOrdered]
280
- }
281
- }
282
- }
283
- });
284
- }
285
- });
286
- const advancedDiv = input.dom.inputTd.append("div").style("display", controls.activeTab == "advanced" ? "" : "none");
287
- input.dom.row.on("mouseover", function() {
288
- this.style.backgroundColor = "#fff";
289
- this.style.textShadow = "none";
290
- });
291
- if (!controls.sorterUi) {
292
- controls.sorterUi = getSorterUi({
293
- controls,
294
- holder: advancedDiv,
295
- tip: controls.parent.app.tip
296
- });
297
- } else {
298
- controls.sorterUi.main(controls.parent.config.settings.matrix, { holder: advancedDiv });
299
- }
300
- return {
301
- main: (plot) => {
302
- const s2 = plot.settings.matrix;
303
- inputs.property("checked", (d) => d.value == s2.sortByMutation);
304
- checkbox.property("checked", s2.sortByCNV);
305
- cnvDiv.style("display", s2.showMatrixCNV != "none" && !s2.allMatrixCNVHidden ? "block" : "none");
306
- }
307
- };
308
- }
309
- });
310
- self2.opts.holder.append("button").datum({
311
- label: l.Samples || `Samples`,
312
- getCount: () => "sampleCount" in self2.overrides ? self2.overrides.sampleCount : self2.parent.sampleOrder?.length || 0,
313
- rows,
314
- customInputs: updateSamplesControls
315
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
316
- }
317
- function updateSamplesControls(self2, app, parent, table) {
318
- if (parent.chartType == "hierCluster" && parent.config.settings.hierCluster.clusterSamples) {
319
- const l = parent.config.settings.matrix.controlLabels;
320
- const sortingControl = select_default(
321
- table.selectAll("td").filter(function() {
322
- return select_default(this).text() == `Sort ${l.Sample} Priority`;
323
- }).node().closest("tr")
324
- );
325
- sortingControl.style("display", "none");
326
- }
327
- }
328
-
329
- // plots/matrix/matrix.controls.genes.ts
330
- var tip = new Menu({ padding: "" });
331
- function setGenesBtn(self2, s) {
332
- const l = s.controlLabels;
333
- const renderStyleOptions = [
334
- {
335
- label: `&nbsp;Stacked <span style="font-size:.7em;color:#555;">Show stacked rectangles in the same matrix cell to render variants for the same ${l.sample} and gene</span>`,
336
- value: "",
337
- title: `Show stacked rectangles in the same matrix cell to render variants for the same ${l.sample} and gene`
338
- },
339
- {
340
- label: `&nbsp;OncoPrint <span style="font-size:.7em;color:#555;">Show overlapping rectangles in the same matrix cell to render variants for the same ${l.sample} and gene</span>`,
341
- value: "oncoprint",
342
- title: `Show overlapping rectangles in the same matrix cell to render variants for the same ${l.sample} and gene`
343
- }
344
- ];
345
- if (s.addMutationCNVButtons && self2.parent.chartType !== "hierCluster")
346
- renderStyleOptions.unshift({
347
- label: `&nbsp;Single <span style="font-size:.7em;color:#555;">Show a single rectangle in a matrix cell to render the most severe variant (truncating > indels > missense > synonymous) for the same ${l.sample} and gene</span>`,
348
- value: "single",
349
- title: `Show a single rectangle in a matrix cell to render the most severe variant (truncating > indels > missense > synonymous) for the same ${l.sample} and gene`
350
- });
351
- self2.opts.holder.append("button").datum({
352
- label: "Genes",
353
- getCount: () => self2.parent.termOrder?.filter(
354
- (t) => t.tw.term.type == TermTypes.GENE_VARIANT || t.tw.term.type == TermTypes.GENE_EXPRESSION
355
- ).length || 0,
356
- customInputs: addGeneInputs,
357
- rows: [
358
- {
359
- label: `Display ${l.Sample} Counts for Gene`,
360
- title: `Include the ${l.sample} count in the gene label`,
361
- type: "radio",
362
- chartType: "matrix",
363
- settingsKey: "samplecount4gene",
364
- styles: { display: "inline-block" },
365
- options: [
366
- { label: "Absolute", value: "abs" },
367
- { label: `Percent`, value: "pct" },
368
- { label: `None`, value: "" }
369
- ],
370
- getDisplayStyle() {
371
- return self2.parent.termOrder?.filter((t) => t.tw.term.type == "geneVariant").length ? "table-row" : "none";
372
- }
373
- },
374
- // TODO: implement this contol option
375
- // {
376
- // label: `Exclude From ${l.Sample} Displayed Counts`,
377
- // title: `Do not include these variations/mutations when counting samples for a gene.`,
378
- // type: 'text',
379
- // chartType: 'matrix',
380
- // settingsKey: 'geneVariantCountSamplesSkipMclass',
381
- // processInput: tw => {},
382
- // },
383
- {
384
- label: "Genomic Alterations Rendering",
385
- title: `Set how to indicate a ${l.sample}'s applicable variant types in the same matrix cell`,
386
- type: "radio",
387
- chartType: "matrix",
388
- settingsKey: "cellEncoding",
389
- options: renderStyleOptions,
390
- styles: { padding: "5px 0px", margin: 0 },
391
- labelDisplay: "block",
392
- getDisplayStyle() {
393
- return self2.parent.termOrder?.filter((t) => t.tw.term.type == "geneVariant").length ? "table-row" : "none";
394
- },
395
- callback: self2.parent.geneStyleControlCallback
396
- },
397
- {
398
- label: "Sort Genes",
399
- title: "Set how to order the genes as rows",
400
- type: "radio",
401
- chartType: "matrix",
402
- settingsKey: "sortTermsBy",
403
- options: [
404
- { label: "By Input Data Order", value: "asListed" },
405
- { label: `By ${l.sample} Count`, value: "sampleCount" }
406
- ],
407
- styles: { padding: 0, "padding-right": "10px", margin: 0, display: "inline-block" },
408
- getDisplayStyle() {
409
- return self2.parent.termOrder?.filter((t) => t.tw.term.type == "geneVariant").length ? "table-row" : "none";
410
- }
411
- }
412
- ]
413
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
414
- }
415
- async function addGeneInputs(self2, app, parent, table) {
416
- if (parent.chartType == "hierCluster" && parent.config.dataType == TermTypes.GENE_EXPRESSION) {
417
- appendGeneInputs(self2, app, parent, table, "hierCluster");
418
- }
419
- if (parent.state?.termdbConfig?.allowedTermTypes?.includes(TermTypes.GENE_VARIANT) || parent.state.termdbConfig.queries.snvindel)
420
- appendGeneInputs(self2, app, parent, table);
421
- }
422
- async function appendGeneInputs(self2, app, parent, table, geneInputType) {
423
- tip.clear();
424
- if (!parent.selectedGroup) parent.selectedGroup = 0;
425
- if (parent.opts.customInputs?.genes) {
426
- for (const inputConfig of parent.opts.customInputs.genes) {
427
- inputConfig.chartType = "matrix";
428
- const holder = table.append("tr");
429
- if (inputConfig.title) holder.attr("aria-label", inputConfig.title);
430
- const input = await initByInput[inputConfig.type](
431
- Object.assign(
432
- {},
433
- {
434
- holder,
435
- app,
436
- id: parent.id,
437
- debug: self2.opts.debug,
438
- parent
439
- },
440
- inputConfig
441
- )
442
- );
443
- input.main(parent.config);
444
- }
445
- }
446
- let geneInputTr;
447
- if (geneInputType == "hierCluster" || parent.chartType !== "hierCluster") {
448
- geneInputTr = table.insert("tr", () => table.select("tr").node());
449
- } else {
450
- const secondTr = table.selectAll("tr").nodes()[1] || null;
451
- const hrTr = table.insert("tr", () => secondTr);
452
- hrTr.append("td").attr("colspan", 2).append("hr").style("border", "1px solid #ccc");
453
- geneInputTr = table.insert("tr", () => secondTr);
454
- }
455
- addGenesetInput(self2, app, parent, geneInputTr, geneInputType);
456
- }
457
- function addGenesetInput(self2, app, parent, tr, geneInputType) {
458
- const controlPanelBtn = self2.btns.filter((d) => d.label.endsWith("Genes"))?.node();
459
- const tip3 = app.tip;
460
- const tg = parent.config.termgroups;
461
- const { maxGenes, genesetEditUiVersion } = parent.settings?.matrix || parent.config?.settings?.matrix || {};
462
- let selectedGroup;
463
- const triggerGenesetEdit = (holder) => {
464
- holder.selectAll("*").remove();
465
- const geneList = selectedGroup.lst.map((item) => {
466
- return { gene: item.name };
467
- });
468
- const genesetUi = genesetEditUiVersion === "withTabs" ? GeneSetEditUIwithTabs : GeneSetEditUI;
469
- new genesetUi({
470
- holder,
471
- genome: app.opts.genome,
472
- geneList,
473
- // Remove the GFF Loads Gene Sets option from unclustered genes panel.
474
- customInputs: parent.chartType !== "hierCluster" || geneInputType == "hierCluster" ? self2.parent.opts.customInputs?.geneset : void 0,
475
- /* running hier clustering and the editing group is the group used for clustering
476
- pass this mode value to inform ui to support the optional button "top variably exp gene"
477
- this is hardcoded for the purpose of gene expression and should be improved
478
- */
479
- mode: selectedGroup.mode,
480
- minNumGenes: selectedGroup.mode == "geneExpression" ? 3 : 1,
481
- maxNumGenes: maxGenes,
482
- vocabApi: self2.opts.app.vocabApi,
483
- callback: async ({ geneList: geneList2, groupName }) => {
484
- if (!selectedGroup) throw `missing selectedGroup`;
485
- tip3.hide();
486
- const group = selectedGroup.status == "new" ? { name: groupName, lst: [] } : tg[selectedGroup.index];
487
- if (selectedGroup.status == "new") tg.push(group);
488
- const targetTermType = selectedGroup.mode == "geneExpression" ? "geneExpression" : "geneVariant";
489
- const lst = group.lst.filter((tw) => tw.term.type != targetTermType);
490
- const tws = await Promise.all(
491
- geneList2.map(async (d) => {
492
- let term;
493
- if (targetTermType == "geneExpression") {
494
- const gene = d.symbol || d.gene;
495
- const unit = getGEunit(app.vocabApi);
496
- const name = `${gene} ${unit}`;
497
- term = { gene, name, type: "geneExpression" };
498
- } else {
499
- term = {
500
- gene: d.symbol || d.gene,
501
- name: d.symbol || d.gene,
502
- type: "geneVariant"
503
- };
504
- }
505
- let tw = group.lst.find((t) => {
506
- const geneName = t.term.gene || t.term.name;
507
- const match = d.symbol ? geneName === d.symbol : d.gene ? geneName === d.gene : false;
508
- return match && t.term.type == targetTermType;
509
- });
510
- if (!tw) {
511
- tw = { term };
512
- await fillTermWrapper(tw, self2.opts.app.vocabApi);
513
- } else if (!tw.$id) {
514
- tw.$id = await get$id(self2.opts.app.vocabApi.getTwMinCopy({ term }));
515
- }
516
- return tw;
517
- })
518
- );
519
- group.lst = [...lst, ...tws];
520
- if (!group.lst.length) tg.splice(selectedGroup.index, 1);
521
- app.dispatch({
522
- type: "plot_edit",
523
- id: self2.parent.id,
524
- config: {
525
- termgroups: tg
526
- }
527
- });
528
- },
529
- backBtn: {
530
- target: "Genes Menu",
531
- callback: () => {
532
- controlPanelBtn.click();
533
- }
534
- },
535
- termsAsListed: geneInputType == "hierCluster" && !self2.parent.config.settings.hierCluster.clusterRows || geneInputType != "hierCluster" && self2.parent.config.settings.matrix.sortTermsBy == "asListed"
536
- });
537
- };
538
- const numOfEditableGrps = tg.filter((g) => g.type != "hierCluster").length;
539
- tr.append("td").attr("class", "sja-termdb-config-row-label").html(geneInputType == "hierCluster" ? "Hierarchical Clustering Gene Set" : "Genomic Alteration Gene Set");
540
- if (numOfEditableGrps > 0 || geneInputType == "hierCluster") {
541
- const td1 = tr.append("td").style("display", "block").style("padding", "5px 0px");
542
- const editGrpDiv = td1.append("div").append("label");
543
- editGrpDiv.append("button").html(
544
- numOfEditableGrps > 1 && geneInputType !== "hierCluster" ? "Edit Selected Group" : geneInputType == "hierCluster" ? "Edit Gene Set" : "Edit Current Group"
545
- ).on("click", () => {
546
- tip3.clear();
547
- setMenuBackBtn(tip3.d.append("div").style("padding", "5px"), () => controlPanelBtn.click(), `Back`);
548
- const genesetEdiUiHolder = tip3.d.append("div");
549
- triggerGenesetEdit(genesetEdiUiHolder);
550
- });
551
- if (numOfEditableGrps > 1 && geneInputType !== "hierCluster") {
552
- const { nonHierClusterGroups, groupSelect } = setTermGroupSelector(self2, editGrpDiv, tg);
553
- selectedGroup = nonHierClusterGroups.find((g) => g.selected);
554
- groupSelect.on("change", () => {
555
- selectedGroup = nonHierClusterGroups[groupSelect.property("value")];
556
- });
557
- } else {
558
- const s = parent.config.settings.hierCluster;
559
- const g = geneInputType == "hierCluster" ? tg.find((g2) => g2.type == "hierCluster") : tg.find((g2) => g2.type != "hierCluster");
560
- selectedGroup = {
561
- index: geneInputType == "hierCluster" ? tg.findIndex((g2) => g2.type == "hierCluster") : tg[0].type == g.type ? 0 : 1,
562
- name: g.name,
563
- type: g.type,
564
- lst: g.type == "hierCluster" ? g.lst.map((tw) => ({ name: tw.term.gene || tw.term.name })) : g.lst.filter((tw) => tw.term.type == TermTypes.GENE_VARIANT).map((tw) => ({ name: tw.term.name })),
565
- mode: g.type == "hierCluster" ? s.dataType : (
566
- // !!subject to change!! when group is not clustering, and ds has mutation, defaults to MUTATION_CNV_FUSION
567
- self2.parent.state.termdbConfig.queries?.snvindel ? TermTypes.GENE_VARIANT : ""
568
- ),
569
- selected: true
570
- };
571
- }
572
- }
573
- if (geneInputType == "hierCluster") {
574
- return;
575
- }
576
- const td2 = tr.append("td").style("display", "block").style("padding", "5px 0px");
577
- const createNewGrpDiv = td2.append("div").append("label");
578
- const createBtn = createNewGrpDiv.append("button").html("Create New Group").property("disabled", true).on("click", () => {
579
- tip3.clear();
580
- setMenuBackBtn(tip3.d.append("div"), () => controlPanelBtn.click(), "Back");
581
- const name = nameInput.property("value");
582
- selectedGroup = {
583
- index: tg.length,
584
- name,
585
- label: name,
586
- lst: [],
587
- status: "new",
588
- mode: parent.state.termdbConfig.queries?.snvindel ? TermTypes.GENE_VARIANT : ""
589
- };
590
- triggerGenesetEdit(tip3.d.append("div"));
591
- });
592
- const nameInput = createNewGrpDiv.append("input").style("margin", "2px 5px").style("width", "210px").attr("placeholder", "Group Name").on("input", () => {
593
- createBtn.property("disabled", !nameInput.property("value"));
594
- }).on("keyup", (event) => {
595
- if (event.key == "Enter" && !createBtn.property("disabled")) {
596
- createBtn.node().click();
597
- }
598
- });
599
- }
600
- function setMenuBackBtn(holder, callback, label) {
601
- holder.attr("tabindex", 0).style("padding", "5px").style("text-decoration", "underline").style("cursor", "pointer").style("margin-bottom", "12px").html(`&#171; ${label}`).on("click", callback).on("keyup", (event) => {
602
- if (event.key == "Enter") event.target.click();
603
- });
604
- }
605
- function setTermGroupSelector(self2, holder, tg) {
606
- const firstGrpWithGeneTw = tg.find(
607
- (g) => g.lst.find((tw) => tw.term.type == TermTypes.GENE_VARIANT && g.type !== "hierCluster")
608
- );
609
- const groups = tg.map((g, index) => {
610
- return {
611
- index,
612
- name: g.name,
613
- type: g.type,
614
- lst: g.lst.filter((tw) => tw.term.type == TermTypes.GENE_VARIANT).map((tw) => ({ name: tw.term.name })),
615
- mode: self2.parent.state.termdbConfig.queries?.snvindel ? TermTypes.GENE_VARIANT : "",
616
- selected: g === firstGrpWithGeneTw
617
- };
618
- });
619
- const nonHierClusterGroups = groups.filter((g) => g.type != "hierCluster");
620
- const groupSelect = holder.append("select").style("width", "218px").style("margin", "2px 5px");
621
- for (const [i, group] of nonHierClusterGroups.entries()) {
622
- if (group.label) continue;
623
- if (group.name) group.label = group.name;
624
- else group.label = `Unlabeled group #${i + 1}`;
625
- }
626
- groupSelect.selectAll("option").data(nonHierClusterGroups).enter().append("option").property("selected", (grp) => grp.selected).attr("value", (d, i) => i).html((grp) => grp.label);
627
- return { nonHierClusterGroups, groupSelect };
628
- }
629
-
630
- // plots/matrix/matrix.controls.variables.ts
631
- var tip2 = new Menu({ padding: "" });
632
- function setVariablesBtn(self2, s) {
633
- self2.opts.holder.append("button").datum({
634
- label: s.controlLabels.Terms || `Variables`,
635
- //getCount: () => self.parent.termOrder.filter(t => t.tw.term.type != 'geneVariant').length.length,
636
- rows: [
637
- {
638
- label: `Row Group Label Max Length`,
639
- title: `Truncate the row group label if it exceeds this maximum number of characters`,
640
- type: "number",
641
- chartType: "matrix",
642
- settingsKey: "termGrpLabelMaxChars"
643
- },
644
- {
645
- label: `Row Label Max Length`,
646
- title: `Truncate the row label if it exceeds this maximum number of characters`,
647
- type: "number",
648
- chartType: "matrix",
649
- settingsKey: "rowlabelmaxchars"
650
- }
651
- ],
652
- customInputs: appendDictInputs
653
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
654
- }
655
- function appendDictInputs(self2, app, parent) {
656
- tip2.clear();
657
- if (!parent.selectedGroup) parent.selectedGroup = parent.chartType == "hierCluster" ? 1 : 0;
658
- app.tip.d.append("hr");
659
- addDictMenu(self2, app, parent, app.tip.d.append("div"));
660
- }
661
- async function addDictMenu(self2, app, parent, holder = void 0) {
662
- const termdb = await import("./app-TGMYXJ4E.js");
663
- termdb.appInit({
664
- holder: holder || app.tip.d,
665
- vocabApi: self2.parent.app.vocabApi,
666
- focus: "off",
667
- state: {
668
- vocab: self2.parent.state.vocab,
669
- activeCohort: self2.parent.activeCohort,
670
- nav: {
671
- header_mode: "search_only"
672
- },
673
- tree: {
674
- usecase: { target: "matrix", detail: "termgroups" }
675
- }
676
- },
677
- tree: {
678
- submit_lst: (termlst) => {
679
- submitLst(self2, termlst);
680
- app.tip.hide();
681
- }
682
- },
683
- search: {
684
- focus: "off"
685
- }
686
- });
687
- }
688
- async function submitLst(self2, termlst) {
689
- const newterms = await Promise.all(
690
- termlst.map(async (_term) => {
691
- const term = structuredClone(_term);
692
- const tw = "id" in term ? { id: term.id, term } : { term };
693
- await fillTermWrapper(tw, self2.opts.app.vocabApi);
694
- return tw;
695
- })
696
- );
697
- const termgroups = structuredClone(self2.parent.config.termgroups);
698
- const i = termgroups.findIndex((g) => g.name == "Variables");
699
- if (i !== -1) {
700
- const grp = termgroups[i];
701
- grp.lst.push(...newterms);
702
- self2.parent.app.dispatch({
703
- type: "plot_nestedEdits",
704
- id: self2.parent.id,
705
- edits: [
706
- {
707
- nestedKeys: ["termgroups", i, "lst"],
708
- value: grp.lst
709
- }
710
- ]
711
- });
712
- } else {
713
- const grp = { name: "Variables", lst: newterms };
714
- termgroups.push(grp);
715
- self2.parent.app.dispatch({
716
- type: "plot_edit",
717
- id: self2.parent.id,
718
- config: { termgroups }
719
- });
720
- }
721
- }
722
-
723
- // plots/matrix/matrix.controls.dimensions.ts
724
- function setDimensionsBtn(self2, s) {
725
- const l = s.controlLabels;
726
- self2.opts.holder.append("button").datum({
727
- label: "Cell Layout",
728
- tables: [
729
- {
730
- rows: [
731
- {
732
- label: "Grid",
733
- title: "Show grid lines, which creates borders around each matrix cells. Note that grid lines are hidden when the auto-computed width <= 2, or when either the column and row spacing is set to 0.",
734
- type: "checkbox",
735
- boxLabel: "show",
736
- // v===true means property('checked') and convert to recognized 'rect' value for dispatch
737
- // otherwise, compared value to 'rect' to set the current value of the checkbox
738
- // note: the non-boolean showGrid values allow keeping the hidden value='pattern' option for benchmark tests
739
- processInput: (v) => v === true ? "rect" : v === "rect",
740
- chartType: "matrix",
741
- settingsKey: "showGrid",
742
- colspan: 2,
743
- align: "center"
744
- // for testing/benchmarking
745
- // type: 'radio',
746
- // options: [
747
- // {
748
- // label: 'hide',
749
- // value: ''
750
- // },
751
- // {
752
- // label: 'lines',
753
- // value: 'pattern' // needs debugging for when s.rowh or d.colw does not apply to all rows
754
- // },
755
- // {
756
- // label: 'rect',
757
- // value: 'rect'
758
- // }
759
- // ]
760
- },
761
- {
762
- label: "Outline Color",
763
- title: "Set a border color for the whole matrix",
764
- type: "color",
765
- chartType: "matrix",
766
- settingsKey: "outlineStroke",
767
- colspan: 2,
768
- align: "center"
769
- //getDisplayStyle: plot => self.parent.settings.matrix.showGrid ? '' : 'none'
770
- },
771
- {
772
- label: "Beam Color",
773
- title: "Set a color for the beam highlighter",
774
- type: "color",
775
- chartType: "matrix",
776
- settingsKey: "beamStroke",
777
- colspan: 2,
778
- align: "center"
779
- //getDisplayStyle: plot => self.parent.settings.matrix.showGrid ? '' : 'none'
780
- },
781
- {
782
- label: "Grid Line Color",
783
- title: "Set the grid color, equivalent to applying the same border color for each matrix cell",
784
- type: "color",
785
- chartType: "matrix",
786
- settingsKey: "gridStroke",
787
- colspan: 2,
788
- align: "center"
789
- //getDisplayStyle: plot => self.parent.settings.matrix.showGrid ? '' : 'none'
790
- },
791
- {
792
- label: "Background Color",
793
- title: `Set the background color when there are no alterations or annotation data for a ${l.sample}`,
794
- type: "color",
795
- chartType: "matrix",
796
- settingsKey: "cellbg",
797
- colspan: 2,
798
- align: "center"
799
- },
800
- {
801
- label: `Use Canvas If # ${l.sample} Exceeds`,
802
- title: `Switch from SVG to canvas rendering when the number of ${l.samples} exceeds this number`,
803
- type: "number",
804
- chartType: "matrix",
805
- settingsKey: "svgCanvasSwitch",
806
- colspan: 2,
807
- align: "center",
808
- width: 60,
809
- min: 0,
810
- max: 1e4,
811
- step: 1
812
- },
813
- {
814
- label: "Canvas Min. Pixel Width",
815
- title: "Set a minimum pixel width for a matrix cell when using canvas, may affect the perceived sharpness of the canvas image",
816
- type: "checkbox",
817
- boxLabel: "apply",
818
- chartType: "matrix",
819
- settingsKey: "useMinPixelWidth",
820
- colspan: 2,
821
- align: "center",
822
- getDisplayStyle: () => self2.parent.settings.matrix.useCanvas ? "" : "none"
823
- }
824
- ]
825
- },
826
- {
827
- header: ["Cells", "Columns", "Rows"],
828
- rows: [
829
- {
830
- label: "Row Height",
831
- title: "Set the height of a matrix row",
832
- type: "number",
833
- width: 50,
834
- align: "center",
835
- chartType: "matrix",
836
- inputs: [{ label: "N/A" }, { settingsKey: "rowh", min: 8, max: 30, step: 1 }],
837
- getDisplayStyle(plot) {
838
- return plot.chartType == "hierCluster" ? "none" : "table-row";
839
- }
840
- },
841
- {
842
- label: "Min Col. Width",
843
- title: "Set the minimum width of the auto-computed matrix column width",
844
- type: "number",
845
- width: 50,
846
- align: "center",
847
- chartType: "matrix",
848
- inputs: [{ settingsKey: "colwMin", min: 0.1, max: 16, step: 0.2 }, { label: "N/A" }]
849
- },
850
- {
851
- label: "Max Col. Width",
852
- title: "Set the maximum width of the auto-computed matrix column width",
853
- type: "number",
854
- width: 50,
855
- align: "center",
856
- chartType: "matrix",
857
- inputs: [{ settingsKey: "colwMax", min: 1, max: 24, step: 0.2 }, { label: "N/A" }]
858
- },
859
- {
860
- label: "Spacing",
861
- title: "Set the column spacing. Note that this will be set to 0 when the auto-computed width < 2.",
862
- type: "number",
863
- width: 50,
864
- align: "center",
865
- chartType: "matrix",
866
- inputs: [
867
- { settingsKey: "colspace", min: 0, max: 20, step: 1 },
868
- { settingsKey: "rowspace", min: 0, max: 20, step: 1 }
869
- ],
870
- getDisplayStyle(plot) {
871
- return plot.chartType == "hierCluster" ? "none" : "table-row";
872
- }
873
- },
874
- {
875
- label: "Group spacing",
876
- title: "Set the spacing between column and row groups.",
877
- type: "number",
878
- width: 50,
879
- align: "center",
880
- chartType: "matrix",
881
- inputs: [
882
- self2.parent.chartType == "hierCluster" ? { label: "N/A" } : { settingsKey: "colgspace", min: 0, max: 20, step: 1 },
883
- { settingsKey: "rowgspace", min: 0, max: 20, step: 1 }
884
- ]
885
- }
886
- ]
887
- },
888
- {
889
- header: ["Labels", "Columns", "Rows"],
890
- rows: [
891
- {
892
- label: "Offset",
893
- title: "Set the gap between the label text and matrix edge",
894
- type: "number",
895
- width: 50,
896
- align: "center",
897
- chartType: "matrix",
898
- inputs: [
899
- { settingsKey: "collabelgap", min: 0, max: 20, step: 1 },
900
- { settingsKey: "rowlabelgap", min: 0, max: 20, step: 1 }
901
- ]
902
- },
903
- {
904
- label: "Spacing",
905
- title: "Set the gap between labels",
906
- type: "number",
907
- width: 50,
908
- align: "center",
909
- chartType: "matrix",
910
- inputs: [
911
- { settingsKey: "collabelpad", min: 0, max: 20, step: 1 },
912
- { settingsKey: "rowlabelpad", min: 0, max: 20, step: 1 }
913
- ]
914
- },
915
- {
916
- label: "Min font size",
917
- title: "Set the minimum auto-computed font size for labels. Note that labels will be hidden if the auto-computed values falls below this minimum.",
918
- type: "number",
919
- width: 50,
920
- align: "center",
921
- colspan: 2,
922
- chartType: "matrix",
923
- settingsKey: "minLabelFontSize",
924
- min: 0,
925
- max: 24,
926
- step: 0.1
927
- },
928
- {
929
- label: "Max font size",
930
- title: "Set the maximum auto-computed font size for labels",
931
- type: "number",
932
- width: 50,
933
- align: "center",
934
- colspan: 2,
935
- chartType: "matrix",
936
- settingsKey: "maxLabelFontSize",
937
- min: 0,
938
- max: 24,
939
- step: 0.1
940
- },
941
- {
942
- label: "Group label<br/>position",
943
- title: "Set which side of the matrix to display group labels",
944
- type: "radio",
945
- width: 50,
946
- chartType: "matrix",
947
- labelDisplay: "block",
948
- getDisplayStyle(plot) {
949
- return plot.chartType == "hierCluster" ? "none" : "table-row";
950
- },
951
- inputs: [
952
- {
953
- settingsKey: "collabelpos",
954
- // switched since settings.collabelpos refers to the individual column label, not group
955
- options: [
956
- { label: "Top", value: "bottom", title: `Display ${l.sample} group labels at the bottom` },
957
- { label: "Bottom", value: "top", title: `Display ${l.sample} group labels on top` }
958
- ]
959
- },
960
- {
961
- settingsKey: "rowlabelpos",
962
- // switched since settings.rowlabelpos refers to the individual column label, not group
963
- options: [
964
- {
965
- label: "Left",
966
- value: "right",
967
- title: `Display gene or variable group labels on the left side`
968
- },
969
- {
970
- label: "Right",
971
- value: "left",
972
- title: `Display gene or variable group labels on the right side`
973
- }
974
- ]
975
- }
976
- ]
977
- }
978
- ]
979
- }
980
- ]
981
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
982
- }
983
-
984
- // plots/matrix/matrix.controls.legend.ts
985
- function setLegendBtn(self2) {
986
- self2.opts.holder.append("button").style("margin", "2px 0").datum({
987
- label: "Legend Layout",
988
- rows: [
989
- //ontop: false,
990
- {
991
- label: "Font Size",
992
- title: "Set the font size for the legend text",
993
- type: "number",
994
- chartType: "legend",
995
- settingsKey: "fontsize"
996
- },
997
- {
998
- label: "Line Height",
999
- title: "Set the line height for a legend group",
1000
- type: "number",
1001
- chartType: "legend",
1002
- settingsKey: "lineh"
1003
- },
1004
- {
1005
- label: "Icon Height",
1006
- title: "Set the icon height for a legend item",
1007
- type: "number",
1008
- chartType: "legend",
1009
- settingsKey: "iconh"
1010
- },
1011
- {
1012
- label: "Icon Width",
1013
- title: "Set the icon width for a legend item",
1014
- type: "number",
1015
- chartType: "legend",
1016
- settingsKey: "iconw"
1017
- },
1018
- /*{
1019
- label: 'Bottom margin',
1020
- type: 'number',
1021
- chartType: 'legend',
1022
- settingsKey: 'padbtm'
1023
- },*/
1024
- {
1025
- label: "Item Left Pad",
1026
- title: "Set a left margin for each legend item",
1027
- type: "number",
1028
- chartType: "legend",
1029
- settingsKey: "padx"
1030
- },
1031
- {
1032
- label: "Left Margin",
1033
- title: "Set a left margin for the whole legend",
1034
- type: "number",
1035
- chartType: "legend",
1036
- settingsKey: "padleft"
1037
- },
1038
- {
1039
- label: "Left Indent",
1040
- title: `Set a left margin for the first legend item in each group, and should be set to the length of the longest group label. The left indent will align the legend group label text to the right.`,
1041
- type: "number",
1042
- chartType: "legend",
1043
- settingsKey: "hangleft"
1044
- },
1045
- {
1046
- label: "Item Layout",
1047
- title: "Option to separate each legend item into a new line, instead of a horizontal layout in the same line.",
1048
- type: "checkbox",
1049
- chartType: "legend",
1050
- settingsKey: "linesep",
1051
- boxLabel: "Line separated"
1052
- }
1053
- ]
1054
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
1055
- }
1056
-
1057
- // plots/matrix/matrix.controls.mutations.ts
1058
- function setMutationBtn(self2) {
1059
- self2.opts.holder.append("button").style("margin", "2px 0").datum({
1060
- label: "Mutation",
1061
- updateBtn: (btn) => {
1062
- const s = self2.parent.config.settings.matrix;
1063
- btn.style("text-decoration", s.allMatrixMutationHidden ? "line-through" : "").style("text-decoration-thickness", s.allMatrixMutationHidden ? "2px" : "");
1064
- },
1065
- rows: [
1066
- {
1067
- title: `Show mutation options`,
1068
- type: "radio",
1069
- chartType: "matrix",
1070
- settingsKey: "showMatrixMutation",
1071
- options: [
1072
- { label: "Show all mutations", value: "all" },
1073
- { label: `Show only truncating mutations`, value: "onlyTruncating" },
1074
- { label: `Show only protein-changing mutations`, value: "onlyPC" },
1075
- { label: `Do not show mutations`, value: "none" },
1076
- { label: `Show selected mutation`, value: "bySelection" }
1077
- ],
1078
- labelDisplay: "block",
1079
- getDisplayStyle(plot) {
1080
- return plot.chartType == "hierCluster" ? "none" : "table-row";
1081
- },
1082
- callback: self2.parent.mutationControlCallback
1083
- }
1084
- ],
1085
- customInputs: generateMutationItems
1086
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
1087
- }
1088
- function generateMutationItems(self2, app, parent, table) {
1089
- table.attr("class", null);
1090
- const m = parent.config.settings.matrix;
1091
- const cnvLegendGrp = parent.legendData.find((l) => l.dt?.includes(dtcnv));
1092
- if (m.showMatrixMutation !== "none" && (m.allMatrixCNVHidden || !cnvLegendGrp || cnvLegendGrp.crossedOut || !cnvLegendGrp.items.find((i) => !i.greyedOut && !i.crossedOut))) {
1093
- table.select("input[type='radio'][value='none']").property("disabled", true);
1094
- table.select("input[type='radio'][value='none'] + span").style("opacity", "0.5").on("mouseup", null);
1095
- }
1096
- if (m.addMutationCNVButtons && parent.chartType !== "hierCluster" && m.showMatrixMutation == "bySelection")
1097
- parent.mutationControlCallback("bySelection");
1098
- }
1099
-
1100
- // plots/matrix/matrix.controls.cnv.ts
1101
- function setCNVBtn(self2) {
1102
- self2.opts.holder.append("button").style("margin", "2px 0").datum({
1103
- label: "CNV",
1104
- updateBtn: (btn) => {
1105
- const s = self2.parent.config.settings.matrix;
1106
- const notRendered = s.allMatrixCNVHidden;
1107
- btn.style("text-decoration", notRendered ? "line-through" : "").style("text-decoration-thickness", notRendered ? "2px" : "");
1108
- },
1109
- rows: [
1110
- {
1111
- title: `Show CNV options`,
1112
- type: "radio",
1113
- chartType: "matrix",
1114
- settingsKey: "showMatrixCNV",
1115
- options: [
1116
- { label: "Show all CNV", value: "all" },
1117
- { label: `Do not show CNV`, value: "none" },
1118
- { label: `Show selected CNV`, value: "bySelection" }
1119
- ],
1120
- labelDisplay: "block",
1121
- getDisplayStyle(plot) {
1122
- return plot.chartType == "hierCluster" ? "none" : "table-row";
1123
- },
1124
- callback: self2.parent.CNVControlCallback
1125
- }
1126
- ],
1127
- customInputs: generateCNVItems
1128
- }).html((d) => d.label).style("margin", "2px 0").on("click", (event, d) => self2.callback(event, d));
1129
- }
1130
- function generateCNVItems(self2, app, parent, table) {
1131
- table.attr("class", null);
1132
- const m = parent.config.settings.matrix;
1133
- const mutationLegendGrp = parent.legendData.find((l) => l.dt?.includes(dtsnvindel));
1134
- if (m.showMatrixCNV !== "none" && (m.allMatrixMutationHidden || !mutationLegendGrp || mutationLegendGrp.crossedOut || !mutationLegendGrp.items.find((i) => !i.greyedOut && !i.crossedOut))) {
1135
- table.select("input[type='radio'][value='none']").property("disabled", true);
1136
- table.select("input[type='radio'][value='none'] + span").style("opacity", "0.5").on("mouseup", null);
1137
- }
1138
- if (m.addMutationCNVButtons && parent.chartType !== "hierCluster" && m.showMatrixCNV == "bySelection")
1139
- parent.CNVControlCallback("bySelection");
1140
- }
1141
-
1142
- // plots/matrix/matrix.controls.download.ts
1143
- function setDownloadBtn(self2) {
1144
- self2.opts.holder.append("button").style("margin", "2px 0").text("Download").on("focus", () => self2.parent.app.tip.hide()).on("click.sjpp-matrix-download", (event) => {
1145
- const p = self2.parent;
1146
- if (!p.dom.downloadMenu) p.dom.downloadMenu = new Menu({ padding: "" });
1147
- const downloadMenu = p.dom.downloadMenu.clear();
1148
- const div = downloadMenu.d.append("div");
1149
- div.append("div").attr("class", "sja_menuoption sja_sharp_border").text(`SVG image`).on("click.sjpp-matrix-download", () => {
1150
- to_svg(self2.opts.getSvg(), "matrix", { apply_dom_styles: true });
1151
- p.dom.downloadMenu.destroy();
1152
- });
1153
- div.append("div").attr("class", "sja_menuoption sja_sharp_border").text(`TSV data`).on("click.sjpp-matrix-download", () => {
1154
- const lst = p.data.lst;
1155
- const allTerms = p.termOrder.map((t) => t.tw);
1156
- const assayAvailability = p.state.termdbConfig.assayAvailability;
1157
- const controlLabels = p.settings.matrix.controlLabels;
1158
- if (p.config.divideBy?.id && !allTerms.find((a2) => a2.id == p.config.divideBy.id)) {
1159
- allTerms.push(p.config.divideBy);
1160
- }
1161
- const activeSamples = [];
1162
- for (const d of lst) {
1163
- for (const tw of allTerms) {
1164
- if (tw.$id in d) {
1165
- activeSamples.push(d);
1166
- break;
1167
- }
1168
- }
1169
- }
1170
- const header = [controlLabels.Sample];
1171
- for (const tw of allTerms) header.push(tw.term.name);
1172
- const rows = [header];
1173
- for (const sample of activeSamples) {
1174
- const row = [sample._ref_.label];
1175
- for (const tw of allTerms) {
1176
- if (!sample[tw.$id]) {
1177
- row.push("");
1178
- } else {
1179
- if (tw.term.type == "geneVariant") {
1180
- const allVariant = [];
1181
- for (const v of sample[tw.$id].renderedValues) {
1182
- const hasAssayAvailability = assayAvailability?.byDt?.[parseInt(v.dt)];
1183
- if (v.dt == dtsnvindel) {
1184
- allVariant.push(
1185
- (v.origin ? `${v.origin} ` : "") + (hasAssayAvailability ? `${dt2label[v.dt]}:` : "") + `${mclass[v.class]?.label}` + (v.mname ? `,${v.mname}` : "")
1186
- );
1187
- } else if (v.dt == dtcnv) {
1188
- const cnvValue = v.value ? `${hasAssayAvailability ? "" : "CNV:"}${v.value}` : v.class == "CNV_amp" ? "CNV gain" : v.class == "CNV_loss" ? "CNV loss" : v.class == "CNV_homozygous_deletion" ? "CNV homozygous deletion" : v.class == "CNV_amplification" ? "CNV amplification" : v.class == "CNV_loh" ? "CNV loss of heterozygosity" : mclass[v.class]?.label;
1189
- allVariant.push(
1190
- (v.origin ? `${v.origin} ` : "") + (hasAssayAvailability ? `${dt2label[v.dt]}:` : "") + cnvValue
1191
- );
1192
- } else if (v.dt == dtfusionrna || v.dt == dtsv) {
1193
- allVariant.push(
1194
- (v.origin ? `${v.origin} ` : "") + (hasAssayAvailability ? `${dt2label[v.dt]}:` : "") + `${mclass[v.class]?.label}` + (v.gene && v.mname ? `(${v.gene}::${v.mname})` : "")
1195
- );
1196
- } else {
1197
- allVariant.push(`DO NOT SUPPORT dt='${v.dt}'`);
1198
- }
1199
- }
1200
- row.push(allVariant.join("|"));
1201
- } else if (tw.term.type == TermTypes.GENE_EXPRESSION || tw.term.type == TermTypes.METABOLITE_INTENSITY || tw.term.type == TermTypes.PROTEOME_ABUNDANCE) {
1202
- row.push(sample[tw.$id]?.renderedValues?.[0]?.value || "");
1203
- } else {
1204
- row.push(sample[tw.$id]?.renderedValues?.[0] || sample[tw.$id]?.value || "");
1205
- }
1206
- }
1207
- }
1208
- rows.push(row);
1209
- }
1210
- const matrix = rows.map((row) => row.join(" ")).join("\n");
1211
- const a = document.createElement("a");
1212
- document.body.appendChild(a);
1213
- a.addEventListener(
1214
- "click",
1215
- function() {
1216
- const currentDate = (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
1217
- a.download = p.config.settings?.hierCluster?.termGroupName?.startsWith("Gene Expression") ? `GeneExpression.${currentDate}.tsv` : p.chartType == "hierCluster" ? `HierCluster.${currentDate}.tsv` : `${p.app.vocabApi.termdbConfig.matrix?.appName || "Matrix"}.${currentDate}.tsv`;
1218
- a.href = URL.createObjectURL(new Blob([matrix], { type: "text/tab-separated-values" }));
1219
- document.body.removeChild(a);
1220
- },
1221
- false
1222
- );
1223
- a.click();
1224
- p.dom.downloadMenu.destroy();
1225
- });
1226
- downloadMenu.showunder(event.target);
1227
- });
1228
- }
1229
-
1230
- // plots/matrix/matrix.zoomPanScroll.ts
1231
- function setZoomInput(self2) {
1232
- const holder = self2.opts.holder.append("div").style("display", "inline-block").style("margin-left", "50px");
1233
- const s = self2.parent.settings.matrix || self2.parent.config.settings.matrix;
1234
- self2.zoomApi = zoom({
1235
- holder,
1236
- title: "Zoom factor relative to the ideal column width, as computed for the number of columns versus available screen width",
1237
- unit: "",
1238
- width: "80px",
1239
- settings: {
1240
- min: 0.1,
1241
- // will be determined once the auto-computed width is determined
1242
- max: 1,
1243
- // will be determined once the auto-computed width is determined
1244
- value: 1,
1245
- increment: s.zoomIncrement,
1246
- step: s.zoomStep || 5
1247
- },
1248
- callback: (zoomLevel) => {
1249
- const p = self2.parent;
1250
- const c = p.getVisibleCenterCell(0);
1251
- p.app.dispatch({
1252
- type: "plot_edit",
1253
- id: p.id,
1254
- config: {
1255
- settings: {
1256
- matrix: {
1257
- zoomLevel,
1258
- zoomCenterPct: 0.5,
1259
- zoomIndex: c.totalIndex,
1260
- zoomGrpIndex: c.grpIndex
1261
- }
1262
- }
1263
- }
1264
- });
1265
- },
1266
- reset: () => {
1267
- self2.parent.app.dispatch({
1268
- type: "plot_edit",
1269
- id: self2.parent.id,
1270
- config: {
1271
- settings: {
1272
- matrix: {
1273
- zoomLevel: 1,
1274
- zoomCenterPct: 0
1275
- }
1276
- }
1277
- }
1278
- });
1279
- }
1280
- });
1281
- }
1282
- function setDragToggle(self2, opts = {}) {
1283
- const defaults = {
1284
- mouseMode: "select",
1285
- activeBgColor: "rgb(255, 255, 255)"
1286
- };
1287
- opts.target.style("cursor", "default");
1288
- const instance = {
1289
- opts: Object.assign({}, defaults, opts),
1290
- dom: {
1291
- selectBtn: opts.holder.append("button").attr("aria-label", "Click the matrix to select data").style("display", "inline-block").style("width", "25px").style("height", "24.5px").style("background-color", defaults.activeBgColor).on("click", () => setMode("select")),
1292
- grabBtn: opts.holder.append("button").attr("aria-label", "Click the matrix to drag and move").style("display", "inline-block").style("width", "25px").style("height", "24.5px").on("click", () => setMode("pan"))
1293
- }
1294
- };
1295
- icons.arrowPointer(instance.dom.selectBtn, { width: 14, height: 14, transform: "translate(50,50)" });
1296
- icons.grab(instance.dom.grabBtn, { width: 14, height: 14, transform: "translate(30,50)" });
1297
- function setMode(m) {
1298
- instance.opts.mouseMode = m;
1299
- self2.parent.settings.matrix.mouseMode = m;
1300
- opts.target.style("cursor", m == "select" ? "default" : "grab");
1301
- instance.dom.selectBtn.style("background-color", m == "select" ? instance.opts.activeBgColor : "");
1302
- instance.dom.grabBtn.style("background-color", m == "pan" ? instance.opts.activeBgColor : "");
1303
- }
1304
- self2.dragToggleApi = {
1305
- update(s = {}) {
1306
- Object.assign(instance.opts, s);
1307
- setMode(instance.opts.mouseMode);
1308
- },
1309
- getSettings() {
1310
- return {
1311
- mouseMode: instance.opts.mouseMode
1312
- };
1313
- }
1314
- };
1315
- }
1316
- function setSvgScroll(self2, state) {
1317
- self2.svgScrollApi = svgScroll({
1318
- holder: self2.parent.dom.scroll,
1319
- height: state.config.settings.matrix.scrollHeight,
1320
- callback: (dx, eventType) => {
1321
- const p = self2.parent;
1322
- const s = p.settings.matrix;
1323
- const d = p.dimensions;
1324
- if (eventType == "move") {
1325
- p.dom.seriesesG.attr("transform", `translate(${d.xOffset + d.seriesXoffset - dx},${d.yOffset})`);
1326
- p.clusterRenderer.translateElems(-dx, s, d);
1327
- p.layout.top.attr.adjustBoxTransform(-dx);
1328
- p.layout.btm.attr.adjustBoxTransform(-dx);
1329
- if (p.dom.topDendrogram) {
1330
- p.dom.topDendrogram.attr("transform", `translate(${p.topDendroX - dx},0)`);
1331
- }
1332
- } else if (eventType == "up") {
1333
- const c = p.getVisibleCenterCell(-dx);
1334
- p.app.dispatch({
1335
- type: "plot_edit",
1336
- id: p.id,
1337
- config: {
1338
- settings: {
1339
- matrix: {
1340
- zoomCenterPct: 0.5,
1341
- zoomIndex: c.totalIndex,
1342
- zoomGrpIndex: c.grpIndex
1343
- }
1344
- }
1345
- }
1346
- });
1347
- }
1348
- }
1349
- });
1350
- }
1351
-
1352
- // plots/matrix/matrix.controls.ts
1353
- var MatrixControls = class {
1354
- constructor(opts, appState) {
1355
- this.activeTab = "basic";
1356
- this.type = "matrixControls";
1357
- this.opts = opts;
1358
- this.parent = opts.parent;
1359
- this.overrides = {};
1360
- this.opts.holder.style("margin", "10px 10px 20px 10px").style("white-space", "nowrap");
1361
- const state = this.parent.getState(appState);
1362
- const s = state.config.settings.matrix;
1363
- if (this.parent.setClusteringBtn)
1364
- this.parent.setClusteringBtn(this.opts.holder, (event, data) => this.callback(event, data));
1365
- setSamplesBtn(this, s);
1366
- if (state.termdbConfig?.allowedTermTypes?.includes(TermTypes.GENE_VARIANT) || state.termdbConfig.queries.snvindel || this.parent.chartType == "hierCluster" && this.parent.config.dataType == TermTypes.GENE_EXPRESSION) {
1367
- setGenesBtn(this, s);
1368
- }
1369
- if (s.addMutationCNVButtons && this.parent.chartType !== "hierCluster") {
1370
- setMutationBtn(this);
1371
- setCNVBtn(this);
1372
- }
1373
- setVariablesBtn(this, s);
1374
- setDimensionsBtn(this, s);
1375
- setLegendBtn(this);
1376
- setDownloadBtn(this);
1377
- setZoomInput(this);
1378
- setDragToggle(this, {
1379
- holder: this.opts.holder.append("div").style("display", "inline-block"),
1380
- target: this.parent.dom.seriesesG
1381
- });
1382
- setSvgScroll(this, state);
1383
- this.keyboardNavHandler = async (event) => {
1384
- if (event.target.tagName == "BUTTON") this.keyEventTarget = event.target;
1385
- if (event.key == "Escape") {
1386
- this.parent.app.tip.hide();
1387
- } else if (event.key == "Enter" || event.key == "ArrowDown") {
1388
- const elems = event.target.tagName == "BUTTON" ? this.parent.app.tip.d.node().querySelectorAll("input, select") : event.target.querySelectorAll("input, select");
1389
- for (const elem of elems) {
1390
- if (elem.checkVisibility?.() || !elem.checkVisibility && elem.getBoundingClientRect().height) {
1391
- elem.focus();
1392
- return false;
1393
- }
1394
- }
1395
- } else if (event.key == "Tab" && event.shiftKey || event.key == "Backspace" || event.key == "ArrowUp") {
1396
- this.keyEventTarget.focus();
1397
- return false;
1398
- }
1399
- };
1400
- this.btns = this.opts.holder.selectAll(":scope>button").filter((d) => d && d.label).on(`keyup.matrix-${this.parent.id}`, this.keyboardNavHandler);
1401
- }
1402
- main(overrides = {}) {
1403
- this.overrides = overrides;
1404
- this.parent.app.tip.hide();
1405
- this.btns.text(
1406
- (d2) => !d2.getCount || d2.showCount == "hide" ? d2.label : d2.showCount == "append" ? `${d2.label} (n=${d2.getCount()})` : `${d2.getCount()} ${d2.label}`
1407
- ).each(function(d2) {
1408
- if (d2.updateBtn) d2.updateBtn(select_default(this));
1409
- });
1410
- const s = this.parent.settings.matrix || this.parent.config.settings.matrix;
1411
- const min = this.parent.computedSettings.zoomMin;
1412
- const max = this.parent.computedSettings.zoomMax;
1413
- const increment = Math.max(0.01, Number((min / max).toFixed(2)));
1414
- const d = this.parent.dimensions;
1415
- if (this.zoomApi)
1416
- this.zoomApi.update({
1417
- value: s.zoomLevel.toFixed(2),
1418
- min: min.toFixed(2),
1419
- max: max.toFixed(2),
1420
- increment,
1421
- step: s.zoomStep || 1
1422
- });
1423
- if (this.svgScrollApi && d) {
1424
- this.svgScrollApi.update({
1425
- x: d.xOffset,
1426
- y: d.yOffset - s.scrollHeight,
1427
- totalWidth: d.zoomedMainW,
1428
- visibleWidth: d.mainw,
1429
- zoomCenter: s.zoomCenterPct * d.mainw - d.seriesXoffset
1430
- });
1431
- }
1432
- if (this.dragToggleApi) {
1433
- this.dragToggleApi.update(s.mouseMode ? { mouseMode: s.mouseMode } : {});
1434
- }
1435
- }
1436
- getSettings() {
1437
- return {
1438
- mouseMode: this.dragToggleApi.getSettings().mouseMode
1439
- };
1440
- }
1441
- async callback(event, d) {
1442
- const app = this.opts.app;
1443
- const parent = this.opts.parent;
1444
- const tables = d.tables || [d];
1445
- event.target.focus();
1446
- app.tip.clear();
1447
- const table = app.tip.d.append("table").attr("class", "sjpp-controls-table");
1448
- for (const t of tables) {
1449
- if (t.header) {
1450
- table.append("tr").selectAll("th").data(t.header).enter().append("th").html((d2) => d2);
1451
- }
1452
- for (const inputConfig of t.rows) {
1453
- const holder = table.append("tr");
1454
- const input = await initByInput[inputConfig.type](
1455
- Object.assign(
1456
- {},
1457
- {
1458
- holder,
1459
- app,
1460
- dispatch: (action) => app.dispatch(action),
1461
- id: parent.id,
1462
- debug: this.opts.debug,
1463
- parent
1464
- },
1465
- inputConfig
1466
- )
1467
- );
1468
- input.main(parent.config);
1469
- }
1470
- if (t.customInputs) t.customInputs(this, app, parent, table);
1471
- table.selectAll("select, input, button").attr("tabindex", 0).on("keydown", this.keyboardNavHandler);
1472
- }
1473
- app.tip.showunder(event.target);
1474
- }
1475
- };
1476
-
1477
- // plots/matrix/matrix.xtw.ts
1478
- var addons;
1479
- async function getTermGroups(termgroups, app) {
1480
- const termGroups = structuredClone(termgroups);
1481
- if (!addons)
1482
- addons = {
1483
- QualTWValues: discreteAddons,
1484
- QualTWPredefinedGS: discreteAddons,
1485
- QualTWCustomGS: discreteAddons,
1486
- NumTWRegularBin: discreteAddons,
1487
- NumTWCustomBin: discreteAddons,
1488
- NumTWCont: continuousAddons,
1489
- TermCollectionTWCont: TermCollectionContAddons
1490
- };
1491
- const opts = {
1492
- vocabApi: app.vocabApi,
1493
- addons
1494
- };
1495
- for (const [origIndex, tG] of termGroups.entries()) {
1496
- tG.origIndex = origIndex;
1497
- if (tG.type == "hierCluster") continue;
1498
- const xtwlst = [];
1499
- for (const tw of tG.lst) {
1500
- const inputTw = tw.getTw?.() || tw;
1501
- xtwlst.push(
1502
- inputTw.type in opts.addons && routedTermTypes.has(inputTw.term.type) ? await TwRouter.init(inputTw, opts) : inputTw
1503
- );
1504
- }
1505
- tG.lst = xtwlst;
1506
- }
1507
- return termGroups;
1508
- }
1509
- var discreteAddons = {
1510
- setCellProps: {
1511
- value: function(cell, anno, value, s, t, self2, width, height, dx, dy, i) {
1512
- const tw = this.getTw();
1513
- const key = anno.key;
1514
- const values = tw.term.values || {};
1515
- cell.label = "label" in anno ? anno.label : values[key]?.label ? values[key].label : key;
1516
- const tw$id = tw.$id;
1517
- cell.fill = self2.config.settings.matrix.twSpecificSettings?.[tw$id]?.[key]?.color || anno.color || values[anno.key]?.color || self2.data.refs.byTermId?.[tw$id]?.bins?.find((b) => anno.key == b.name)?.color;
1518
- cell.order = t.ref.bins ? t.ref.bins.findIndex((bin) => bin.name == key) : 0;
1519
- cell.x = cell.totalIndex * dx + cell.grpIndex * s.colgspace;
1520
- cell.y = height * i;
1521
- const group = tw.legend?.group || tw$id;
1522
- return { ref: t.ref, group, value: key, entry: { key, label: cell.label, fill: cell.fill } };
1523
- }
1524
- }
1525
- };
1526
- var continuousAddons = {
1527
- setCellProps: {
1528
- value: function(cell, anno, value, s, t, self2, width, height, dx, dy, i) {
1529
- const tw = this.getTw();
1530
- const key = anno.key;
1531
- const values = tw.term.values || {};
1532
- cell.label = "label" in anno ? anno.label : values[key]?.label ? values[key].label : key;
1533
- cell.fill = anno.color || values[anno.key]?.color;
1534
- const tw$id = tw.$id;
1535
- const twSpecificSettings = self2.config.settings.matrix.twSpecificSettings;
1536
- if (!twSpecificSettings[tw$id]) twSpecificSettings[tw$id] = {};
1537
- const twSettings = twSpecificSettings[tw$id];
1538
- if (!twSettings.contBarH) twSettings.contBarH = s.barh;
1539
- if (!("gap" in twSettings)) twSettings.contBarGap = 4;
1540
- const specialValue = tw.term.values?.[cell.key];
1541
- if (specialValue?.uncomputable) {
1542
- cell.x = cell.totalIndex * dx + cell.grpIndex * s.colgspace;
1543
- cell.y = height * i;
1544
- cell.height = twSettings.contBarH;
1545
- cell.fill = "transparent";
1546
- cell.label = specialValue.label;
1547
- const group = tw.legend?.group || tw.$id;
1548
- return {
1549
- ref: t.ref,
1550
- group,
1551
- value: specialValue.label || specialValue.key,
1552
- entry: { key, label: cell.label, fill: cell.fill }
1553
- };
1554
- }
1555
- cell.fill = self2.config.settings.matrix.twSpecificSettings?.[tw$id]?.contBarColor || "#555";
1556
- if (s.transpose) {
1557
- cell.height = t.scale(cell.key);
1558
- cell.x = twSettings.contBarGap;
1559
- } else {
1560
- const vc = cell.term.valueConversion;
1561
- let renderV = vc ? cell.key * vc.scaleFactor : cell.key;
1562
- if (this.q.convert2ZScore) {
1563
- renderV = (renderV - t.mean) / t.std;
1564
- cell.fill = renderV > 0 ? "#FF6666" : "#6666FF";
1565
- cell.zscoreLabel = ` (Z-score: ${renderV.toFixed(2)})`;
1566
- }
1567
- cell.label = "label" in anno ? anno.label : values[key]?.label ? values[key].label : this.term.unit ? `${cell.key.toFixed(2)} ${this.term.unit}` : cell.key.toFixed(2);
1568
- cell.height = renderV >= 0 ? t.scales.pos(renderV) : t.scales.neg(renderV);
1569
- cell.x = cell.totalIndex * dx + cell.grpIndex * s.colgspace;
1570
- cell.y = renderV >= 0 ? t.counts.posMaxHt + twSettings.contBarGap - cell.height : t.counts.posMaxHt + twSettings.contBarGap;
1571
- cell.convertedValueLabel = !vc ? "" : convertUnits(cell.key, vc.fromUnit, vc.toUnit, vc.scaleFactor);
1572
- }
1573
- }
1574
- }
1575
- };
1576
- var TermCollectionContAddons = {
1577
- setCellProps: {
1578
- value: function(cell, anno, value, s, t, self2, width, height, dx, _dy, _i) {
1579
- const tw = this.getTw();
1580
- const twSpecificSettings = self2.config.settings.matrix.twSpecificSettings;
1581
- if (!twSpecificSettings[tw.$id]) twSpecificSettings[tw.$id] = {};
1582
- const twSettings = twSpecificSettings[tw.$id];
1583
- if (!twSettings.contBarH) twSettings.contBarH = s.barh;
1584
- if (!("gap" in twSettings)) twSettings.contBarGap = 4;
1585
- const isNegative = value.value < 0;
1586
- if (isNegative) {
1587
- cell.height = t.scales.neg ? t.scales.neg(value.value) - t.scales.neg(0) : 0;
1588
- cell.x = cell.totalIndex * dx + cell.grpIndex * s.colgspace;
1589
- const cumulativeHeight = t.scales.neg ? t.scales.neg(value.pre_val_sum) - t.scales.neg(0) : 0;
1590
- cell.y = t.counts.posMaxHt + twSettings.contBarGap + (t.scales.neg ? t.scales.neg(0) : 0) + cumulativeHeight;
1591
- } else {
1592
- cell.height = t.scales.pos(value.value) - t.scales.pos(0);
1593
- cell.x = cell.totalIndex * dx + cell.grpIndex * s.colgspace;
1594
- const cumulativeHeight = t.scales.pos(value.pre_val_sum) - t.scales.pos(0);
1595
- cell.y = t.counts.posMaxHt + twSettings.contBarGap - t.scales.pos(0) - cumulativeHeight - cell.height;
1596
- }
1597
- cell.label = value.label;
1598
- cell.fill = twSettings[value.label]?.color || value.color || tw.term.propsByTermId?.[value.label]?.color;
1599
- cell.value = value.value;
1600
- return {
1601
- ref: t.ref,
1602
- group: tw.$id,
1603
- value: value.label,
1604
- order: -1,
1605
- entry: { key: value.label, label: value.label, fill: cell.fill }
1606
- };
1607
- }
1608
- }
1609
- };
1610
-
1611
- // plots/matrix/matrix.js
1612
- var Matrix = class _Matrix extends PlotBase {
1613
- static type = "matrix";
1614
- configTermKeys = ["termgroups.lst", "divideBy"];
1615
- constructor(opts) {
1616
- super(opts);
1617
- this.type = _Matrix.type;
1618
- this.holderTitle = "Sample Matrix";
1619
- this.optionalFeatures = JSON.parse(sessionStorage.getItem("optionalFeatures") || `{}`)?.matrix || [];
1620
- setInteractivity(this);
1621
- setRenderers(this);
1622
- }
1623
- async init(appState) {
1624
- const opts = this.opts;
1625
- if (opts.reactsTo) this.reactsTo = opts.reactsTo;
1626
- this.setDom = setMatrixDom;
1627
- this.setDom(opts);
1628
- this.config = appState.plots.find((p) => p.id === this.id);
1629
- this.settings = Object.assign({}, this.config.settings.matrix);
1630
- this.computed = {};
1631
- if (this.dom.header) this.dom.header.html(this.config.preBuiltPlotTitle || this.holderTitle);
1632
- this.setControls(appState);
1633
- this.clusterRenderer = new MatrixCluster({ holder: this.dom.cluster, app: this.app, parent: this });
1634
- this.legendRenderer = svgLegend({
1635
- holder: this.dom.legendG,
1636
- rectFillFxn: (d) => d.color,
1637
- iconStroke: "#aaa",
1638
- handlers: {
1639
- legend: {
1640
- click: this.legendClick
1641
- }
1642
- },
1643
- settings: {
1644
- isExcludedAttr: "isExcluded"
1645
- },
1646
- note: "CLICK A ROW LABEL OR ITEM TO APPLY FILTERING"
1647
- });
1648
- this.customTipApi = this.dom.tip.getCustomApi({
1649
- d: this.dom.menubody,
1650
- clear: (event) => {
1651
- if (event?.target) this.dom.menutop.style("display", "none");
1652
- this.dom.menubody.selectAll("*").remove();
1653
- return this.customTipApi;
1654
- },
1655
- show: () => {
1656
- this.dom.menubody.style("display", "block");
1657
- },
1658
- hide: () => {
1659
- }
1660
- });
1661
- this.setPill(appState);
1662
- const commonKeys = { mclass, dt2label, morigin };
1663
- for (const k in commonKeys) {
1664
- const v = commonKeys[k];
1665
- this[k] = copyMerge({}, v, appState.termdbConfig[k] || {}, appState.termdbConfig.matrix?.[k] || {});
1666
- }
1667
- }
1668
- setControls(appState) {
1669
- this.controlsRenderer = new MatrixControls(
1670
- {
1671
- app: this.app,
1672
- id: this.id,
1673
- parent: this,
1674
- holder: this.dom.controls,
1675
- getSvg: () => this.dom.svg.node()
1676
- },
1677
- appState
1678
- );
1679
- }
1680
- // reactsTo(action) {
1681
- // // note: a parent app or 'plot' component is expected to already have
1682
- // // a comprehensive reactsTo() call to filter the actions for this component,
1683
- // // so only farther selective action filters should be applied here as needed
1684
- // return true
1685
- // }
1686
- getState(appState) {
1687
- const config = appState.plots.find((p) => p.id === this.id);
1688
- const filter0 = appState.termfilter.filter0;
1689
- this.prevFilter0 = this.state?.filter0;
1690
- const parentConfig = appState.plots.find((p) => p.id === this.parentId);
1691
- const termfilter = getCombinedTermFilter(appState, config.filter || parentConfig?.filter);
1692
- return {
1693
- isVisible: true,
1694
- config,
1695
- filter: termfilter.filter,
1696
- filter0,
1697
- // read-only, invisible filter currently only used for gdc dataset
1698
- hasVerifiedToken: this.app.vocabApi.hasVerifiedToken(),
1699
- tokenVerificationMessage: this.app.vocabApi.tokenVerificationMessage,
1700
- vocab: appState.vocab,
1701
- termdbConfig: appState.termdbConfig,
1702
- clusterMethod: config.settings.hierCluster?.clusterMethod,
1703
- distanceMethod: config.settings.hierCluster?.distanceMethod,
1704
- clusterSamples: config.settings.hierCluster?.clusterSamples,
1705
- clusterRows: config.settings.hierCluster?.clusterRows,
1706
- zScoreTransformation: config.settings.hierCluster?.zScoreTransformation,
1707
- nav: appState.nav,
1708
- groups: rebaseGroupFilter(appState)
1709
- };
1710
- }
1711
- async main() {
1712
- try {
1713
- this.config = await this.getMutableConfig();
1714
- if (this.mayRequireToken()) return;
1715
- const termGroups = await getTermGroups(this.config.termgroups, this.app);
1716
- const prevTranspose = this.settings.transpose;
1717
- Object.assign(this.settings, structuredClone(this.config.settings), this.controlsRenderer.getSettings());
1718
- this.dom.loadingDiv.selectAll("*").remove();
1719
- this.dom.loadingDiv.html("").style("display", "").style("position", "relative").style("left", "45%");
1720
- this.dom.svg.style("opacity", 0.1).style("pointer-events", "none");
1721
- delete this.clickedClusterIds;
1722
- delete this.clickedLeftClusterIds;
1723
- try {
1724
- setComputedConfig(this.config);
1725
- const promises = [];
1726
- if (this.setHierClusterData) promises.push(this.setHierClusterData());
1727
- promises.push(this.setData());
1728
- this.dom.loadingDiv.html("Processing data ...");
1729
- await Promise.all(promises);
1730
- const warnings = this.data.warnings.join("\n");
1731
- this.dom.warningDiv.style("display", warnings.length ? "" : "none").html(warnings);
1732
- this.applyLegendValueFilter();
1733
- if (this.combineData) this.combineData();
1734
- this.app.save({ type: "plot_edit", id: this.id, config: this.config });
1735
- } catch (e) {
1736
- if (e == "no data") {
1737
- this.showNoMatchingDataMessage();
1738
- return;
1739
- } else if (this.app.isAbortError(e)) {
1740
- return;
1741
- } else {
1742
- this.dom.svg.style("display", "none");
1743
- throw e;
1744
- }
1745
- }
1746
- this.termGroups = termGroups;
1747
- this.dom.loadingDiv.html("Updating ...").style("display", "");
1748
- this.termOrder = this.getTermOrder(this.data);
1749
- this.sampleGroups = this.getSampleGroups(this.hierClusterSamples || this.data);
1750
- this.sampleOrder = this.getSampleOrder(this.data);
1751
- this.setLayout();
1752
- if (this.setHierColorScale) this.setHierColorScale(this.hierClusterData.clustering);
1753
- if (!this.sampleOrder?.length) {
1754
- this.showNoMatchingDataMessage();
1755
- }
1756
- this.controlsRenderer.main();
1757
- this.serieses = this.getSerieses(this.data);
1758
- this.dom.loadingDiv.html("Rendering ...");
1759
- if (this.plotDendrogramHclust) this.plotDendrogramHclust();
1760
- this.render();
1761
- this.mayDisplayCohortMessage();
1762
- this.dom.svg.style("display", "").style("opacity", 1).style("pointer-events", "");
1763
- const [xGrps, yGrps] = !this.settings.matrix.transpose ? ["sampleGrps", "termGrps"] : ["termGrps", "sampleGrps"];
1764
- const d = this.dimensions;
1765
- this.clusterRenderer.main({
1766
- settings: this.settings.matrix,
1767
- xGrps: this[xGrps],
1768
- yGrps: this[yGrps],
1769
- dimensions: d
1770
- });
1771
- this.legendRenderer(this.legendData, {
1772
- settings: Object.assign({}, this.settings.legend, {
1773
- svgw: Math.max(400, d.mainw + d.xOffset - this.settings.matrix.margin.right),
1774
- svgh: d.mainh + d.yOffset,
1775
- dimensions: d,
1776
- padleft: this.settings.legend.padleft
1777
- //+ d.xOffset
1778
- })
1779
- });
1780
- await this.adjustSvgDimensions(prevTranspose);
1781
- this.controlsRenderer.main();
1782
- if (this.data.removedHierClusterTerms) {
1783
- for (const r of this.data.removedHierClusterTerms) {
1784
- sayerror(this.dom.errorDiv, r.text + ": " + r.lst.join(", "));
1785
- }
1786
- }
1787
- } catch (e) {
1788
- const message = this.app.vocabApi.tokenVerificationMessage;
1789
- this.mayRequireToken(message);
1790
- if (!message) {
1791
- this.app.tip.hide();
1792
- this.dom.loadingDiv.style("display", "none");
1793
- throw e;
1794
- }
1795
- }
1796
- this.resetInteractions();
1797
- }
1798
- showNoMatchingDataMessage() {
1799
- this.forcedSampleCount = 0;
1800
- this.dom.svg.style("opacity", 1e-3).style("display", "none");
1801
- if (this.termOrder && this.dimensions) this.controlsRenderer.main({ sampleCount: 0 });
1802
- this.dom.loadingDiv.html("");
1803
- const div = this.dom.loadingDiv.append("div").style("display", "inline-block").style("text-align", "center").style("position", "relative").style("left", "-150px");
1804
- div.append("div").style("margin", "5px 10px").html("No matching cohort sample data for the current gene list.");
1805
- if (this.settings.matrix.showHints?.includes("genesetEdit")) {
1806
- const div1 = div.append("div").style("margin", "5px 10px");
1807
- div1.append("span").html("You may change the selected cohort,");
1808
- if (this.config.legendGrpFilter?.lst.length || this.config.legendValueFilter?.lst.length) {
1809
- const cnvBtn = this.controlsRenderer.btns.filter((d) => d.label == "CNV")?.node();
1810
- if (cnvBtn) {
1811
- div1.append("br");
1812
- div1.append("span").html("show hidden ");
1813
- div1.append("span").html("CNV").style("cursor", "pointer").style("text-decoration", "underline").on("click", () => {
1814
- cnvBtn.click();
1815
- });
1816
- }
1817
- const mutationBtn = this.controlsRenderer.btns.filter((d) => d.label == "Mutation")?.node();
1818
- if (cnvBtn && mutationBtn) div1.append("span").html(" or ");
1819
- if (mutationBtn) {
1820
- div1.append("span").style("cursor", "pointer").style("text-decoration", "underline").html("Mutation").on("click", () => {
1821
- mutationBtn.click();
1822
- });
1823
- }
1824
- if (cnvBtn || mutationBtn) div1.append("span").html(" data,");
1825
- }
1826
- div1.append("br");
1827
- div1.append("span").html("or edit the gene list from the ");
1828
- div1.append("span").style("cursor", "pointer").style("text-decoration", "underline").html("Gene Set Edit Group menu.").on("click", () => {
1829
- const GenesBtn = this.controlsRenderer.btns.filter((d) => d.label == "Genes")?.node().click();
1830
- const i = setInterval(() => {
1831
- const editBtn = this.app.tip.d.selectAll("button").filter(function() {
1832
- return this.innerHTML == "Edit Group";
1833
- }).node();
1834
- if (editBtn) {
1835
- editBtn.click();
1836
- clearInterval(i);
1837
- }
1838
- }, 100);
1839
- });
1840
- }
1841
- this.dom.svg.style("display", "none");
1842
- }
1843
- mayDisplayCohortMessage() {
1844
- const msg = deepEqual(this.state.filter0, this.prevFilter0) ? "" : "The gene list is persisted across cohorts.";
1845
- if (msg) {
1846
- this.dom.loadingDiv.html("");
1847
- const div = this.dom.loadingDiv.append("div").style("display", "inline-block").style("text-align", "center").style("position", "relative").style("left", "-150px");
1848
- div.append("div").html(msg);
1849
- if (this.settings.matrix.showHints?.includes("genesetEdit")) {
1850
- const div1 = div.append("div");
1851
- div1.append("span").html(" You may edit the gene list from the ");
1852
- div1.append("span").style("cursor", "pointer").style("text-decoration", "underline").html("Gene Set Edit Group menu.").on("click", () => {
1853
- const GenesBtn = this.controlsRenderer.btns.filter((d) => d.label == "Genes")?.node().click();
1854
- const i = setInterval(() => {
1855
- const editBtn = this.app.tip.d.selectAll("button").filter(function() {
1856
- return this.innerHTML == "Edit Group";
1857
- }).node();
1858
- if (editBtn) {
1859
- editBtn.click();
1860
- clearInterval(i);
1861
- }
1862
- }, 100);
1863
- });
1864
- }
1865
- }
1866
- this.dom.loadingDiv.style("display", msg ? "" : "none");
1867
- }
1868
- sampleKey(s) {
1869
- return s.row.sample;
1870
- }
1871
- sampleLabel(s) {
1872
- return s.label || s.row._ref_.label || "";
1873
- }
1874
- sampleGrpKey(s) {
1875
- return s.grp.name;
1876
- }
1877
- sampleGrpLabel(s) {
1878
- return s.grp.label || s.grp.name || "";
1879
- }
1880
- termKey(t) {
1881
- return t.tw.$id;
1882
- }
1883
- termLabel(t) {
1884
- return t.label;
1885
- }
1886
- termGrpKey(t) {
1887
- return t.grp.name;
1888
- }
1889
- termGrpLabel(t) {
1890
- return t.grp.label || t.grp.name || [{ text: "\u22EE", dx: 3, cls: "sjpp-exclude-svg-download" }];
1891
- }
1892
- destroy() {
1893
- select_default(window).on(`resize.sjpp-${self.id}`, null);
1894
- }
1895
- };
1896
- for (const m of [matrix_data_exports, matrix_groups_exports, matrix_layout_exports, matrix_serieses_exports, matrix_legend_exports]) {
1897
- for (const methodName in m) {
1898
- Matrix.prototype[methodName] = m[methodName];
1899
- }
1900
- }
1901
- var matrixInit = getCompInit(Matrix);
1902
- var componentInit = matrixInit;
1903
- function makeChartBtnMenu(holder, chartsInstance) {
1904
- chartsInstance.dom.tip.clear();
1905
- const menuDiv = holder.append("div");
1906
- if (chartsInstance.state.termdbConfig.matrixplots) {
1907
- for (const plot of chartsInstance.state.termdbConfig.matrixplots) {
1908
- menuDiv.append("button").style("margin", "10px").style("padding", "10px 15px").style("border-radius", "20px").style("border-color", "#ededed").style("display", "inline-block").text(plot.name).on("click", async () => {
1909
- chartsInstance.dom.tip.hide();
1910
- const config = await chartsInstance.app.vocabApi.getMatrixByName(plot.name);
1911
- config.preBuiltPlotTitle = plot.name;
1912
- chartsInstance.app.dispatch({
1913
- type: "plot_create",
1914
- config
1915
- });
1916
- });
1917
- }
1918
- }
1919
- const chart = {
1920
- clickTo: chartsInstance.showTree_selectlst,
1921
- chartType: "matrix",
1922
- usecase: { target: "matrix", detail: "termgroups" },
1923
- processSelection: (lst) => {
1924
- return [
1925
- {
1926
- name: "",
1927
- lst: lst.map((term) => {
1928
- return { term };
1929
- })
1930
- }
1931
- ];
1932
- }
1933
- };
1934
- chartsInstance.showTree_selectlst(chart);
1935
- }
1936
-
1937
- export {
1938
- Matrix,
1939
- matrixInit,
1940
- componentInit,
1941
- makeChartBtnMenu
1942
- };
1943
- //# sourceMappingURL=chunk-DBFPAZG3.js.map