@sjcrh/proteinpaint-client 2.74.2 → 2.76.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.
- package/dist/{2dmaf-b2d78c57.js → 2dmaf-74b99126.js} +1 -1
- package/dist/AppHeader-cecb39c2.js +1 -0
- package/dist/{ColorScale-9c76aef3.js → ColorScale-21cab8d2.js} +1 -1
- package/dist/DEanalysis-95bad59a.js +1 -0
- package/dist/Disco-a6e921a0.js +1 -0
- package/dist/Disco.UI-9ad999ed.js +1 -0
- package/dist/{DragControls-586f72db.js → DragControls-e3b6a937.js} +1 -1
- package/dist/{DziViewer-6311327c.js → DziViewer-354a790d.js} +1 -1
- package/dist/FilterRxComp-701a1480.js +1 -0
- package/dist/{FilterStateless-046081c2.js → FilterStateless-54c0b763.js} +1 -1
- package/dist/{HicApp-40e44cba.js → HicApp-d5a946bf.js} +1 -1
- package/dist/{OrbitControls-0cda1772.js → OrbitControls-694652cd.js} +1 -1
- package/dist/WSIViewer-dc7f8eb0.js +1 -0
- package/dist/adSandbox-f438e388.js +1 -0
- package/dist/app-3320ab6f.js +1 -0
- package/dist/app-649f8357.js +1 -0
- package/dist/app-b369b169.js +1 -0
- package/dist/app.js +1 -1
- package/dist/bam-431875ef.js +1 -0
- package/dist/barchart-8277ed43.js +1 -0
- package/dist/barchart.events-da29c90d.js +1 -0
- package/dist/{bars.renderer-5f7a4174.js → bars.renderer-dcfdd59b.js} +1 -1
- package/dist/block-6aedd569.js +1 -0
- package/dist/block.lazyload-87b12654.js +1 -0
- package/dist/block.legend-d3f61ef7.js +1 -0
- package/dist/{block.mds-effc078d.js → block.mds-3ad17dfa.js} +1 -1
- package/dist/{block.mds.cnv-ec861a26.js → block.mds.cnv-857ba868.js} +1 -1
- package/dist/{block.mds.expressionrank-a2ad7c80.js → block.mds.expressionrank-7e3b208c.js} +1 -1
- package/dist/{block.mds.expressionstat-31dc5595.js → block.mds.expressionstat-f2d31c86.js} +1 -1
- package/dist/{block.mds.geneboxplot-3ca857ce.js → block.mds.geneboxplot-f0fbaf12.js} +1 -1
- package/dist/{block.mds.junction-debba938.js → block.mds.junction-7f87f48f.js} +1 -1
- package/dist/{block.mds.svcnv-8dc5abdf.js → block.mds.svcnv-ac035c12.js} +1 -1
- package/dist/{block.mds.svcnv.share-81e62600.js → block.mds.svcnv.share-886d9479.js} +1 -1
- package/dist/block.mds2-7852c1ee.js +1 -0
- package/dist/{block.svg-9121e8e7.js → block.svg-9b916fa6.js} +1 -1
- package/dist/{block.tk.aicheck-c1b478e9.js → block.tk.aicheck-6770e333.js} +1 -1
- package/dist/{block.tk.ase-0f6ded48.js → block.tk.ase-ee807e59.js} +1 -1
- package/dist/{block.tk.bam-7cd06aee.js → block.tk.bam-00fba6e8.js} +1 -1
- package/dist/{block.tk.bedgraphdot-3ef8b94e.js → block.tk.bedgraphdot-7fda78e9.js} +1 -1
- package/dist/{block.tk.bigwig.ui-d1248810.js → block.tk.bigwig.ui-cc1a42f3.js} +1 -1
- package/dist/{block.tk.hicstraw-ee731e55.js → block.tk.hicstraw-526470e3.js} +1 -1
- package/dist/{block.tk.junction-4d8cab4d.js → block.tk.junction-b43a4cda.js} +1 -1
- package/dist/{block.tk.junction.textmatrixui-a6430b27.js → block.tk.junction.textmatrixui-a60ed78a.js} +1 -1
- package/dist/{block.tk.ld-8429a18b.js → block.tk.ld-d15bde41.js} +1 -1
- package/dist/{block.tk.menu-3f31f958.js → block.tk.menu-3aeb93c6.js} +1 -1
- package/dist/{block.tk.pgv-07e46705.js → block.tk.pgv-9af2bd64.js} +1 -1
- package/dist/boxplot-e17a17b7.js +1 -0
- package/dist/brainImaging-bf2ceee9.js +1 -0
- package/dist/{brush-c386fe3d.js → brush-aa175142.js} +1 -1
- package/dist/categorical-a52014a1.js +1 -0
- package/dist/condition-c646e357.js +1 -0
- package/dist/controls-287e6efa.js +1 -0
- package/dist/{controls.btns-1cb2bfab.js → controls.btns-79b805dd.js} +1 -1
- package/dist/controls.config-28d6d6a8.js +1 -0
- package/dist/cuminc-9e275854.js +1 -0
- package/dist/{customdata.inputui-cbd712ea.js → customdata.inputui-dc49d94b.js} +1 -1
- package/dist/dataDownload-3a3d4f33.js +1 -0
- package/dist/databrowser.ui-d8d3f8fd.js +1 -0
- package/dist/{density-19266ebf.js → density-a82a8b1c.js} +1 -1
- package/dist/dictionary-c5a19d90.js +1 -0
- package/dist/{drag-0b968811.js → drag-7b30ba17.js} +1 -1
- package/dist/{e2pca-b8752945.js → e2pca-82765817.js} +1 -1
- package/dist/{ep-a86b185a.js → ep-d017ec2f.js} +1 -1
- package/dist/facet-a9b44ef3.js +1 -0
- package/dist/{fusion.parse-244b2b97.js → fusion.parse-d40d0b9d.js} +1 -1
- package/dist/geneExpClustering-34c3f518.js +1 -0
- package/dist/geneExpression-0d1b7244.js +1 -0
- package/dist/{geneExpression-e0430f2e.js → geneExpression-589f485b.js} +1 -1
- package/dist/{geneExpression-387205bf.js → geneExpression-7d14983f.js} +1 -1
- package/dist/geneORA-903a780f.js +1 -0
- package/dist/{geneVariant-7de021b6.js → geneVariant-89601b34.js} +1 -1
- package/dist/geneVariant-92c4e870.js +1 -0
- package/dist/{genefusion.ui-a331de19.js → genefusion.ui-7e22e811.js} +1 -1
- package/dist/{genesearch-ea59f5d4.js → genesearch-a4e19f0d.js} +1 -1
- package/dist/geneset-108a39d2.js +1 -0
- package/dist/genomeBrowser-12f86a36.js +1 -0
- package/dist/genomeBrowser.controls-d5067811.js +1 -0
- package/dist/{groupsetting-20ffef77.js → groupsetting-b4416a96.js} +1 -1
- package/dist/gsea-543dab25.js +1 -0
- package/dist/hierCluster-26e14090.js +1 -0
- package/dist/hierCluster.config-98e82dff.js +1 -0
- package/dist/{hierCluster.interactivity-9b433033.js → hierCluster.interactivity-e56f6542.js} +1 -1
- package/dist/hierCluster.renderers-74a64cf5.js +1 -0
- package/dist/{html.legend-abb5452e.js → html.legend-a3f4ebfe.js} +1 -1
- package/dist/imagePlot-b9eae4ae.js +1 -0
- package/dist/{lasso-55cf4057.js → lasso-f767f634.js} +1 -1
- package/dist/launch.adhoc-abca6af3.js +1 -0
- package/dist/leftlabel.sample-24c2388d.js +1 -0
- package/dist/legacyDataset-e0e201ab.js +1 -0
- package/dist/{log-cf45fcf2.js → log-99af3443.js} +1 -1
- package/dist/{lollipop-c5b6e615.js → lollipop-806f8fa4.js} +1 -1
- package/dist/{maf-7535f1f9.js → maf-b06579e4.js} +1 -1
- package/dist/{maftimeline-1292ab62.js → maftimeline-4840a380.js} +1 -1
- package/dist/matrix-00bb50ff.js +1 -0
- package/dist/matrix.cells-914dd0c6.js +1 -0
- package/dist/{matrix.cluster-168bc96b.js → matrix.cluster-783ceab0.js} +1 -1
- package/dist/matrix.config-6ce74dfe.js +1 -0
- package/dist/matrix.controls-7b2a6f95.js +1 -0
- package/dist/{matrix.data-b1d0febe.js → matrix.data-dac4f1b7.js} +1 -1
- package/dist/{matrix.dom-00defa30.js → matrix.dom-4e10bbe9.js} +1 -1
- package/dist/matrix.groups-b9fca14a.js +1 -0
- package/dist/matrix.interactivity-84169b43.js +1 -0
- package/dist/{matrix.layout-c2345231.js → matrix.layout-dd5a44fd.js} +1 -1
- package/dist/matrix.legend-ac6d45e6.js +1 -0
- package/dist/matrix.renderers-78010275.js +1 -0
- package/dist/matrix.serieses-9b4fd744.js +1 -0
- package/dist/matrix.sort-014d798d.js +1 -0
- package/dist/{matrix.sorterUi-a741ba2e.js → matrix.sorterUi-9bf7e6f9.js} +1 -1
- package/dist/{mavb-92136d17.js → mavb-c6be46fc.js} +1 -1
- package/dist/{mds.fimo-c03115b4.js → mds.fimo-bff6a1ed.js} +1 -1
- package/dist/mds.samplescatterplot-9a02b9fb.js +1 -0
- package/dist/{mds.survivalplot-366db380.js → mds.survivalplot-055549f4.js} +1 -1
- package/dist/{metaboliteIntensity-ddb6e480.js → metaboliteIntensity-fac92f8b.js} +1 -1
- package/dist/niceNumLabels-238aabce.js +1 -0
- package/dist/{nodrag-2c046d31.js → nodrag-16ad4b03.js} +1 -1
- package/dist/{notify-44ebc0df.js → notify-224cccbd.js} +1 -1
- package/dist/{numeric-918d4686.js → numeric-b0b17185.js} +1 -1
- package/dist/numeric.binary-1f9e93f2.js +1 -0
- package/dist/numeric.continuous-ebcd0567.js +1 -0
- package/dist/numeric.discrete-7b97044a.js +1 -0
- package/dist/numeric.spline-1be88f3d.js +1 -0
- package/dist/numeric.toggle-7fa2a770.js +1 -0
- package/dist/oncomatrix-351af2a0.js +1 -0
- package/dist/{parseData-e66308cd.js → parseData-21fe9822.js} +1 -1
- package/dist/partjson.esm-b3f1fc21.js +1 -0
- package/dist/{plot.2dvaf-73dbfbd1.js → plot.2dvaf-18a35e4b.js} +1 -1
- package/dist/plot.app-30c4b8e5.js +1 -0
- package/dist/plot.barplot-7c4865a2.js +1 -0
- package/dist/{plot.boxplot-641da058.js → plot.boxplot-fe3046c6.js} +1 -1
- package/dist/plot.brainImaging-2ceb6023.js +1 -0
- package/dist/plot.disco-6011f87f.js +1 -0
- package/dist/{plot.dzi-41ea26e5.js → plot.dzi-6728a7c8.js} +1 -1
- package/dist/plot.ssgq-5581dc56.js +1 -0
- package/dist/{plot.vaf2cov-80e58833.js → plot.vaf2cov-b2284c64.js} +1 -1
- package/dist/{plot.wsi-51cc48ef.js → plot.wsi-9a9d4034.js} +1 -1
- package/dist/profileBarchart-0476f1f8.js +1 -0
- package/dist/profileHome-32eb9b50.js +1 -0
- package/dist/profilePlot-c7e099e8.js +1 -0
- package/dist/profilePolar-6b981e63.js +1 -0
- package/dist/profileRadar-bca1cc03.js +1 -0
- package/dist/profileRadarFacility-bbb1ecd8.js +1 -0
- package/dist/profileSummary-b114204f.js +1 -0
- package/dist/recover-49e09de0.js +1 -0
- package/dist/regression.inputs-a761f40d.js +1 -0
- package/dist/regression.inputs.values.table-5929d25a.js +1 -0
- package/dist/regression.results-69bc42d0.js +1 -0
- package/dist/{renderPvalueTable-895a72c2.js → renderPvalueTable-dc5d15f2.js} +1 -1
- package/dist/sampleScatter-2d0ed680.js +1 -0
- package/dist/{sampleScatter.rendererThree-5e686004.js → sampleScatter.rendererThree-0b12ac61.js} +2 -2
- package/dist/sampleView-484ab133.js +1 -0
- package/dist/samplelst-689796e6.js +1 -0
- package/dist/{samplematrix-2a1d7d82.js → samplematrix-2b137a05.js} +1 -1
- package/dist/scatter-205e013f.js +1 -0
- package/dist/{select2Terms-b4fffc50.js → select2Terms-b21e184a.js} +1 -1
- package/dist/{selectGenomeWithTklst-acf7e568.js → selectGenomeWithTklst-466995b4.js} +1 -1
- package/dist/singleCellCellType-5db730bb.js +1 -0
- package/dist/{singleCellGeneExpression-6de17162.js → singleCellGeneExpression-7147a2d0.js} +1 -1
- package/dist/singleCellPlot-73b2738f.js +1 -0
- package/dist/{singlecell-f76c856a.js → singlecell-24409b72.js} +1 -1
- package/dist/singlecell-bca774ed.js +1 -0
- package/dist/{snp-9590a1b4.js → snp-37d06246.js} +1 -1
- package/dist/snp-a8388ce4.js +1 -0
- package/dist/snplocus-7a1ea8c9.js +1 -0
- package/dist/{snplst-007a1926.js → snplst-6865d7c7.js} +1 -1
- package/dist/{spliceevent.a53ss.diagram-63dfef69.js → spliceevent.a53ss.diagram-e2eab72b.js} +1 -1
- package/dist/{spliceevent.exonskip.diagram-76fa9af8.js → spliceevent.exonskip.diagram-4d5df3a1.js} +1 -1
- package/dist/spliceevent.exonskip.getdefault-a94aad6e.js +1 -0
- package/dist/{spliceevent.noeventdiagram-64a099e0.js → spliceevent.noeventdiagram-ea97b0fb.js} +1 -1
- package/dist/{spliceevent.phrase-770c8cac.js → spliceevent.phrase-c5832470.js} +1 -1
- package/dist/{stattable-f1189f0f.js → stattable-7c5ecc2f.js} +1 -1
- package/dist/{style.gdc-89cfdb0f.js → style.gdc-131f3c77.js} +1 -1
- package/dist/summary-5ec455d3.js +1 -0
- package/dist/{sunburst-d5379952.js → sunburst-533902a7.js} +1 -1
- package/dist/survival-92250664.js +1 -0
- package/dist/survival-e16e068f.js +1 -0
- package/dist/{svg.download-86850940.js → svg.download-35926549.js} +1 -1
- package/dist/{svg.legend-a94b0697.js → svg.legend-8d490df2.js} +1 -1
- package/dist/{svgraph-c57b9ae3.js → svgraph-6fac8cbc.js} +1 -1
- package/dist/{svmr-cf6f1b27.js → svmr-d07ff695.js} +1 -1
- package/dist/table-29d5a973.js +1 -0
- package/dist/table-ad744310.js +1 -0
- package/dist/termInfo-bf99a37e.js +1 -0
- package/dist/{termdb.bins-9faa5170.js → termdb.bins-8b656cc3.js} +1 -1
- package/dist/termsetting-33ea66f1.js +1 -0
- package/dist/tk-071a7550.js +1 -0
- package/dist/{toggleButtons-002aeda1.js → toggleButtons-dbdbad01.js} +1 -1
- package/dist/tp.ui-9c2e9fc5.js +1 -0
- package/dist/tslib.es6-c3c2d88f.js +1 -0
- package/dist/tvs.density-f6128793.js +1 -0
- package/dist/{tvs.geneVariant-3a65ad94.js → tvs.geneVariant-ca4bdbb1.js} +1 -1
- package/dist/tvs.numeric-0260a825.js +1 -0
- package/dist/{tvs.samplelst-1eeb586b.js → tvs.samplelst-cb71b3bf.js} +1 -1
- package/dist/{uiUtils-1336bad7.js → uiUtils-f1bd2bcc.js} +1 -1
- package/dist/{variantBrowser-f0c812c1.js → variantBrowser-7c540224.js} +1 -1
- package/dist/{vcf-c4a23924.js → vcf-5cc55588.js} +1 -1
- package/dist/violin-2ba509eb.js +1 -0
- package/dist/violin.interactivity-4da6d7a9.js +1 -0
- package/dist/{violin.renderer-dafd89fa.js → violin.renderer-ce024265.js} +1 -1
- package/dist/{violinRenderer-8215f40d.js → violinRenderer-f7c96a60.js} +1 -1
- package/dist/{viridis-ffd14c4d.js → viridis-01ab20c5.js} +1 -1
- package/dist/{y-dd197cc9.js → y-67939f83.js} +1 -1
- package/dist/{zoom-9c63e74c.js → zoom-25dce8b9.js} +1 -1
- package/package.json +6 -4
- package/dist/AppHeader-a2a7e518.js +0 -1
- package/dist/DEanalysis-a6b50e49.js +0 -1
- package/dist/Disco-1c71b7dd.js +0 -1
- package/dist/Disco.UI-4c16ee50.js +0 -1
- package/dist/FilterRxComp-242f4615.js +0 -1
- package/dist/WSIViewer-d90032d7.js +0 -1
- package/dist/adSandbox-3528c372.js +0 -1
- package/dist/app-07dee349.js +0 -1
- package/dist/app-a8c4854a.js +0 -1
- package/dist/app-ade9c62a.js +0 -1
- package/dist/bam-92483a98.js +0 -1
- package/dist/barchart-3e69d094.js +0 -1
- package/dist/barchart.events-9b11d97e.js +0 -1
- package/dist/block-dcb130fb.js +0 -1
- package/dist/block.lazyload-9f031cac.js +0 -1
- package/dist/block.legend-b2987cd9.js +0 -1
- package/dist/block.mds2-de6e0986.js +0 -1
- package/dist/boxplot-1178fffc.js +0 -1
- package/dist/brainImaging-98ed7aa2.js +0 -1
- package/dist/categorical-26528ce8.js +0 -1
- package/dist/condition-b0d74550.js +0 -1
- package/dist/controls-0bacec22.js +0 -1
- package/dist/controls.config-0ccc9d79.js +0 -1
- package/dist/controls.divide-a9fe9466.js +0 -1
- package/dist/controls.overlay-fe20d41d.js +0 -1
- package/dist/controls.term1-faa2efcf.js +0 -1
- package/dist/cuminc-7e2cac2d.js +0 -1
- package/dist/dataDownload-ade8d840.js +0 -1
- package/dist/databrowser.ui-716f0519.js +0 -1
- package/dist/dictionary-3f83ce63.js +0 -1
- package/dist/facet-6850cfed.js +0 -1
- package/dist/geneExpClustering-7fd3c87e.js +0 -1
- package/dist/geneExpression-6462537d.js +0 -1
- package/dist/geneORA-7eb818c4.js +0 -1
- package/dist/geneVariant-b58e924a.js +0 -1
- package/dist/geneset-9f69ad3f.js +0 -1
- package/dist/genomeBrowser-1b2b83f7.js +0 -1
- package/dist/genomeBrowser.controls-cd8ddeb1.js +0 -1
- package/dist/gsea-36376589.js +0 -1
- package/dist/hierCluster-f1e30c19.js +0 -1
- package/dist/hierCluster.config-da3510b1.js +0 -1
- package/dist/hierCluster.renderers-610d8860.js +0 -1
- package/dist/imagePlot-7089bdff.js +0 -1
- package/dist/launch.adhoc-d229fd55.js +0 -1
- package/dist/leftlabel.sample-a919168c.js +0 -1
- package/dist/legacyDataset-1cbcb67d.js +0 -1
- package/dist/matrix-0614794d.js +0 -1
- package/dist/matrix.cells-819d4991.js +0 -1
- package/dist/matrix.config-c54ca273.js +0 -1
- package/dist/matrix.controls-5eca7822.js +0 -1
- package/dist/matrix.groups-4660dd70.js +0 -1
- package/dist/matrix.interactivity-23d83183.js +0 -1
- package/dist/matrix.legend-2e647224.js +0 -1
- package/dist/matrix.renderers-43445f4f.js +0 -1
- package/dist/matrix.serieses-972fbe5d.js +0 -1
- package/dist/matrix.sort-80d9b788.js +0 -1
- package/dist/mds.samplescatterplot-1623e6d0.js +0 -1
- package/dist/niceNumLabels-6cfc1508.js +0 -1
- package/dist/numeric.binary-80467e8b.js +0 -1
- package/dist/numeric.continuous-69a62a15.js +0 -1
- package/dist/numeric.discrete-86181905.js +0 -1
- package/dist/numeric.spline-1b07fd13.js +0 -1
- package/dist/numeric.toggle-37c4bee8.js +0 -1
- package/dist/oncomatrix-475271da.js +0 -1
- package/dist/plot.app-aa916e0e.js +0 -1
- package/dist/plot.barplot-8b440a2b.js +0 -1
- package/dist/plot.brainImaging-2f796b0c.js +0 -1
- package/dist/plot.disco-43e18d2f.js +0 -1
- package/dist/plot.ssgq-e49cb70b.js +0 -1
- package/dist/profileBarchart-91463ab6.js +0 -1
- package/dist/profileHome-d37a6821.js +0 -1
- package/dist/profilePlot-9ca577cb.js +0 -1
- package/dist/profilePolar-19c7da5b.js +0 -1
- package/dist/profileRadar-8bf094e3.js +0 -1
- package/dist/profileRadarFacility-f9fd8971.js +0 -1
- package/dist/profileSummary-93999c14.js +0 -1
- package/dist/recover-36ada47f.js +0 -1
- package/dist/regression.inputs-cb57ece6.js +0 -1
- package/dist/regression.inputs.values.table-908bb37a.js +0 -1
- package/dist/regression.results-c186a8dc.js +0 -1
- package/dist/roundValue-b0d0517c.js +0 -1
- package/dist/sampleScatter-9d5b3630.js +0 -1
- package/dist/sampleView-2d895023.js +0 -1
- package/dist/samplelst-9f8343ff.js +0 -1
- package/dist/scatter-b4992f64.js +0 -1
- package/dist/singleCellCellType-84a0c2cf.js +0 -1
- package/dist/singleCellPlot-2f2b8619.js +0 -1
- package/dist/singlecell-90567dde.js +0 -1
- package/dist/snp-79ec95ba.js +0 -1
- package/dist/snplocus-cb629be1.js +0 -1
- package/dist/spliceevent.exonskip.getdefault-31d2950c.js +0 -1
- package/dist/summary-b77bef3c.js +0 -1
- package/dist/survival-61ab375a.js +0 -1
- package/dist/survival-80a0ade9.js +0 -1
- package/dist/table-79e3e776.js +0 -1
- package/dist/table-eee91e14.js +0 -1
- package/dist/termInfo-f851b415.js +0 -1
- package/dist/tk-75566002.js +0 -1
- package/dist/tp.ui-02911b56.js +0 -1
- package/dist/tslib.es6-1f85f553.js +0 -1
- package/dist/tvs.density-026fca97.js +0 -1
- package/dist/tvs.numeric-3f3d9919.js +0 -1
- package/dist/violin-1515c3e6.js +0 -1
- package/dist/violin.interactivity-8e2f480d.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{M as t,P as e,d as a,z as i}from"./app-a8c4854a.js";const n=`ABCDEFGHIJKLMNOPQRSTUVWXYZ`.split("");function r(r){const{controls:s,holder:l}=r;const o=s.parent;const d=structuredClone(o.config.settings.matrix);const p=d.controlLabels;const c=new t({padding:"",parent_menu:o.app.tip?.d.node()});let y=[],g,u={};const h={dom:{tip:c},opts:r,highlightColor:"none",label:`Sort ${p.Samples}`,title:`Set how to sort ${p.samples}`,type:"custom",expanded:r.expanded||false,expandedSection:r.expandedSection||"",init(t={},s={}){c.clear().hide();if(o.config.settings.matrix!=d)e(d,o.config.settings.matrix);if(d!==t)e(d,t);h.settings=d;h.activeOption=structuredClone(d.sortOptions[d.sortSamplesBy]);g=[{label:`For each selected row, sort ${p.samples} by matching data`,notDraggable:true,tiebreakers:[],handler:U},...h.activeOption.sortPriority,{label:`Sort ${p.samples} by name, alphabetically`,notDraggable:true,tiebreakers:[]}];Object.assign(r,s);r.holder.selectAll("*").remove();const l=r.holder.append("div").style("text-align","right");l.append("button").html("Apply").on("click",j);l.append("button").html("Reset").on("click",((t,e)=>h.init()));const u=r.holder.append("table");const $=u.append("thead");$.append("th").html("Priority").style("text-align","left").style("max-width","0px");$.append("th").html("Description");$.append("th").html("Action");let I=0,M=0;for(const t of g){const e=t.tiebreakers?.[0]?.order||t.handler;const r=u.append("thead").datum(t).property("draggable",!t.notDraggable).attr("droppable",true).on("dragstart",f).on("dragover",m).on("dragleave",x).on("drop",v);y.push(a(r));const s=r.append("tr").style("background-color","#eee").on("mouseover",V);s.append("th").style("padding","5px").style("vertical-align","top").style("font-weight",400).html(n[M++]).on("click",e?b:null);const l=s.append("th").style("padding","5px").style("vertical-align","top").style("text-align","left").style("cursor",e?"pointer":"").on("click",e?b:null);l.append("span").style("margin-right","12px").style("font-weight",400).html(t.label);s.append("th").style("padding","5px").style("vertical-align","top").style("text-align","center").style("font-weight",400).style("cursor",e?"pointer":"").append("span").html(e?"Details":" ").on("click",e?b:null);const o=u.append("tbody").datum(t).style("display",h.expandedSection=="all"||h.expandedSection==t.label?"":"none");for(const e of t.tiebreakers){if(e.skip)continue;if(!t.types?.includes("geneVariant")){continue}const a=o.append("tr").on("mouseover",V).datum(e).attr("draggable",!e.disabled&&t.types?.length!==0).attr("droppable",!e.disabled&&t.types?.length!==0).on("dragstart",k).on("dragover",O).on("dragleave",D).on("drop",A);if(!e.disabled)I++;const n=a.append("td").attr("title",e.disabled?`This tiebreaker is currently not being used to sort ${p.cases}. Check the box to use.`:`The number indicates the order in which this tiebreaker is used. Unched the box to skip.`).datum(e);n.style("padding","5px").style("vertical-align","top").style("text-align","center");n.append("span").html(!e.disabled?I:"");const r=a.append("td").style("opacity",e.disabled?.5:1).style("padding","5px").style("vertical-align","top").style("max-width","500px");r.append("span").html(e.label||"");if(!e.disabled){const t=r.append("label");t.append("span").html("<br>(use data list order ");if(!e.isOrdered)e.isOrdered=false;t.append("input").datum(e).attr("type","checkbox").property("checked",e.isOrdered).style("vertical-align","bottom").on("change",S);t.append("span").html(")");const a=e.order;r.append("div").attr("class","sjpp-matrix-sorter-ui-value").selectAll("div").data(a.map(((t,a)=>({lstName:"order",key:t,cls:i[t],tb:e,dragstart:P,dragover:w,dragleave:T,drop:_,filterByClass:d.filterByClass,index:a})))).enter().append("div").style("display",e.isOrdered?"block":"inline-block").each(C);if(e.notUsed?.length){const t=r.append("div");t.append("div").attr("data-testid","sjpp-matrix-sorter-ui-hidden-add").style("display","inline-block").style("padding","5x").style("vertical-align","top").style("padding","3px 5px").style("cursor","pointer").html(`+Add`).on("click",N)}}const s=a.append("td").style("text-align","center").style("vertical-align","top");if(e.mayToggle){s.append("button").datum(e).html(e.disabled?"Enable":"Disable").on("click",B)}}const c=o.append("tr").attr("draggable",true).on("mouseover",V);c.append("td").html(" ");const g=c.append("td").style("text-align","left").html(t.details&&!t.order?.length?t.details:" ");if(t.handler)t.handler(g,c,o);c.append("td").html(" ")}},toggleSection:b,trackDraggedSection:f,highlightSection:m,unhighlightSection:x,adjustSortPriority:v,trackDraggedTieBreaker:k,highlightTieBreaker:O,unhighlightTieBreaker:D,adjustTieBreakers:A,trackDraggedValue:P,highlightValue:w,unhighlightValue:T,adjustValueOrder:_,apply:j};function b(t,e={label:"all"}){h.expandedSection=h.expandedSection===e.label?"":e.label;h.expanded=!!h.expandedSection;h.init()}function f(t,e){u.type="sortPriority";u.data=e;u.index=h.activeOption.sortPriority.indexOf(e)}function m(t,e){if(u.type!="sortPriority"||e==u.data)return;t.preventDefault();const i=h.activeOption.sortPriority.indexOf(e);const n=i<u.index?"border-top":i>u.index?"border-bottom":"";if(!n)return;a(this).selectAll("th").style(n,"2px solid blue")}function x(t,e){if(u.type!="sortPriority")return;t.preventDefault();a(this).selectAll("th").style("border","none")}function v(t,e){if(e==u.data)return;const a=h.activeOption.sortPriority.indexOf(e);const i=o.config.settings.matrix;h.activeOption.sortPriority.splice(u.index,1);h.activeOption.sortPriority.splice(a,0,u.data);h.init({sortOptions:{[i.sortSamplesBy]:h.activeOption}})}function k(t,e){u.type="tiebreaker";u.data=e;u.sectionData=t.target.closest("tbody").__data__;u.priorityIndex=h.activeOption.sortPriority.indexOf(u.sectionData);u.index=u.sectionData.tiebreakers.indexOf(e)}function O(t,e){if(u.type!="tiebreaker"||e==u.data)return;t.preventDefault();const i=u.sectionData.tiebreakers.indexOf(e);const n=i<u.index?"border-top":i>u.index?"border-bottom":"";if(!n)return;a(this).selectAll("td:nth-child(2)").style(n,"2px solid blue")}function D(t,e){if(u.type!="tiebreaker")return;t.preventDefault();a(this).selectAll("td:nth-child(2)").style("border","none")}function S(t,e){t.stopPropagation();e.isOrdered=!e.isOrdered;h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}function B(t,e){t.stopPropagation();e.disabled=!e.disabled;h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}function A(t,e){if(u.type!="tiebreaker"||e==u.data)return;t.preventDefault();const a=u.sectionData.tiebreakers.indexOf(e);const i=o.config.settings.matrix;u.sectionData.tiebreakers.splice(u.index,1);u.sectionData.tiebreakers.splice(a,0,u.data);h.init({sortOptions:{[i.sortSamplesBy]:h.activeOption}})}function C(t){const e=[];if(t.tb.notUsed?.includes(t.key))e.push(`- Click on this label to include in used data values.`);if(t.filterByClass[t.key])e.unshift("- Click on the corresponding entry in the matrix legend or Mutation/CNV menus to unhide");if(e.length)e.unshift(`To use this data value for sorting ${p.samples}:`);t.tb.notUsed?.includes(t.key);const i=t.filterByClass[t.key]=="value"?.5:1;const n=a(this).attr("title",e.length?e.join("\n"):`Click to not use this data value to sort ${p.samples}`).attr("draggable",t.tb.isOrdered?true:false).attr("droppable",t.tb.isOrdered?true:false).style("width","fit-content").style("margin-right","10px").style("overflow","hidden").style("white-space","nowrap").style("opacity",i).style("cursor","pointer").on("dragstart",t.dragstart).on("dragover",t.dragover).on("dragleave",t.dragleave).on("drop",t.drop).on("mouseenter",(()=>r.style("opacity",1))).on("mouseleave",(()=>r.style("opacity",0))).on("click",(()=>{if(e.length){const a="sjpp-matrix-sorter-value-note";n.selectAll(`.${a}`).remove();const i=n.append("div").attr("class",a).style("max-width","200px").style("padding","5px");i.html(e.join("<br>"));if(t.filterByClass[t.key])return}const a=t.lstName=="order"?"notUsed":"order";if(!t.tb[a])t.tb[a]=[];const i=t.tb[a];t.tb[t.lstName].splice(t.index,1);if(t.lstName=="order")i.unshift(t.key);else i.push(t.key);h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}));n.append("div").style("display","inline-block").style("cursor","pointer").style("width","12px").style("height","12px").style("margin-right","3px").style("background-color",t.cls.color);n.append("span").style("cursor","pointer").style("text-decoration",t.filterByClass[t.key]=="case"?"line-through":"").html(t.cls.label+(t.filterByClass[t.key]?" (<i>not used since this value is hidden</i>)":""));const r=n.append("div").style("display","inline-block").style("width","12px").style("cursor","pointer").style("opacity",0).style("color",t.lstName=="order"?"red":"green").html(t.lstName=="order"?"✗":"✓")}function P(t,e){t.stopPropagation?.();u.type="value";u.data=e;u.sectionData=t.target.closest("tbody").__data__;u.priorityIndex=h.activeOption.sortPriority.indexOf(u.sectionData);u.tiebreaker=t.target.closest("tr").__data__;u.tbIndex=u.sectionData.tiebreakers.indexOf(u.priorityIndex);u.order=u.tiebreaker.order}function w(t,e){t.stopPropagation?.();if(u.type!="value"||e==u.data)return;if(e.tb!=u.data.tb)return;t.preventDefault();u.order.indexOf(e);a(this).style("border","2px solid blue")}function T(t,e){t.stopPropagation?.();if(u.type!="value")return;t.preventDefault();a(this).style("border","none")}function _(t,e){t.stopPropagation?.();if(u.type!="value"||e==u.data)return;t.preventDefault();const a=h.settings;u.data.tb[u.data.lstName].splice(u.data.index,1);e.tb[e.lstName].splice(e.index,0,u.data.key);const i=a.hiddenVariants.indexOf(u.data.key);const n=structuredClone(a.hiddenVariants);const r=structuredClone(a.filterByClass);if(i!=-1){n.splice(i,1);r[u.data.key]=false}h.init({hiddenVariants:n,filterByClass:r,sortOptions:{[a.sortSamplesBy]:h.activeOption}})}function N(t,e){t?.stopPropagation();const a=c.clear().d.append("div").attr("data-testid","sjpp-matrix-sorter-ui-hidden-vals").style("margin-top","3px").style("vertical-align","top").style("padding-left","12px");a.selectAll("div").data(e.notUsed.map(((t,a)=>({lstName:"notUsed",key:t,cls:i[t],tb:e,dragstart:P,dragover:w,dragleave:T,drop:_,filterByClass:d.filterByClass,index:a})))).enter().append("div").style("display","block").each(C);c.showunder(t.target)}function j(){o.app.tip?.hide();o.app.dispatch({type:"plot_edit",id:o.id,config:{settings:{matrix:{sortOptions:{[d.sortSamplesBy]:h.activeOption}}}}})}function V(){}function U(t,e){if(!o.selectedTermsToSortAgainst?.length){t.html(`Click on a matrix row label and the left triangle to add an entry here`);return}const i=o.selectedTermsToSortAgainst.map((t=>({t:t,label:t.tw.term.name+(t.tw.term.type=="geneVariant"?" alterations":" values")})));const n=a(e.node().parentNode);n.selectAll("tr").remove();n.selectAll("tr").data(i).enter().append("tr").selectAll("td").data(((t,e)=>[{label:e+1,textAlign:"center",cursor:"",t:t.t},{label:t.label,textAlign:"left",cursor:""},{label:"Delete",textAlign:"center",cursor:"pointer",click:o.unsortSamplesAgainstTerm,data:t}])).enter().append("td").style("text-align",(t=>t.textAlign)).style("cursor",(t=>t.cursor)).html((t=>t.label)).on("click",((t,e)=>e.click?.(t,e)))}h.init();h.api={main:h.init,destroy:()=>{r.holder.selectAll("*").remove()}};if(r.debug)h.api.Inner=h;return h.api}export{r as getSorterUi};
|
|
1
|
+
import{M as t,P as e,d as a,z as i}from"./app-b369b169.js";const n=`ABCDEFGHIJKLMNOPQRSTUVWXYZ`.split("");function r(r){const{controls:s,holder:l}=r;const o=s.parent;const d=structuredClone(o.config.settings.matrix);const p=d.controlLabels;const c=new t({padding:"",parent_menu:o.app.tip?.d.node()});let y=[],g,u={};const h={dom:{tip:c},opts:r,highlightColor:"none",label:`Sort ${p.Samples}`,title:`Set how to sort ${p.samples}`,type:"custom",expanded:r.expanded||false,expandedSection:r.expandedSection||"",init(t={},s={}){c.clear().hide();if(o.config.settings.matrix!=d)e(d,o.config.settings.matrix);if(d!==t)e(d,t);h.settings=d;h.activeOption=structuredClone(d.sortOptions[d.sortSamplesBy]);g=[{label:`For each selected row, sort ${p.samples} by matching data`,notDraggable:true,tiebreakers:[],handler:U},...h.activeOption.sortPriority,{label:`Sort ${p.samples} by name, alphabetically`,notDraggable:true,tiebreakers:[]}];Object.assign(r,s);r.holder.selectAll("*").remove();const l=r.holder.append("div").style("text-align","right");l.append("button").html("Apply").on("click",j);l.append("button").html("Reset").on("click",((t,e)=>h.init()));const u=r.holder.append("table");const $=u.append("thead");$.append("th").html("Priority").style("text-align","left").style("max-width","0px");$.append("th").html("Description");$.append("th").html("Action");let I=0,M=0;for(const t of g){const e=t.tiebreakers?.[0]?.order||t.handler;const r=u.append("thead").datum(t).property("draggable",!t.notDraggable).attr("droppable",true).on("dragstart",f).on("dragover",m).on("dragleave",x).on("drop",v);y.push(a(r));const s=r.append("tr").style("background-color","#eee").on("mouseover",V);s.append("th").style("padding","5px").style("vertical-align","top").style("font-weight",400).html(n[M++]).on("click",e?b:null);const l=s.append("th").style("padding","5px").style("vertical-align","top").style("text-align","left").style("cursor",e?"pointer":"").on("click",e?b:null);l.append("span").style("margin-right","12px").style("font-weight",400).html(t.label);s.append("th").style("padding","5px").style("vertical-align","top").style("text-align","center").style("font-weight",400).style("cursor",e?"pointer":"").append("span").html(e?"Details":" ").on("click",e?b:null);const o=u.append("tbody").datum(t).style("display",h.expandedSection=="all"||h.expandedSection==t.label?"":"none");for(const e of t.tiebreakers){if(e.skip)continue;if(!t.types?.includes("geneVariant")){continue}const a=o.append("tr").on("mouseover",V).datum(e).attr("draggable",!e.disabled&&t.types?.length!==0).attr("droppable",!e.disabled&&t.types?.length!==0).on("dragstart",k).on("dragover",O).on("dragleave",D).on("drop",A);if(!e.disabled)I++;const n=a.append("td").attr("title",e.disabled?`This tiebreaker is currently not being used to sort ${p.cases}. Check the box to use.`:`The number indicates the order in which this tiebreaker is used. Unched the box to skip.`).datum(e);n.style("padding","5px").style("vertical-align","top").style("text-align","center");n.append("span").html(!e.disabled?I:"");const r=a.append("td").style("opacity",e.disabled?.5:1).style("padding","5px").style("vertical-align","top").style("max-width","500px");r.append("span").html(e.label||"");if(!e.disabled){const t=r.append("label");t.append("span").html("<br>(use data list order ");if(!e.isOrdered)e.isOrdered=false;t.append("input").datum(e).attr("type","checkbox").property("checked",e.isOrdered).style("vertical-align","bottom").on("change",S);t.append("span").html(")");const a=e.order;r.append("div").attr("class","sjpp-matrix-sorter-ui-value").selectAll("div").data(a.map(((t,a)=>({lstName:"order",key:t,cls:i[t],tb:e,dragstart:P,dragover:w,dragleave:T,drop:_,filterByClass:d.filterByClass,index:a})))).enter().append("div").style("display",e.isOrdered?"block":"inline-block").each(C);if(e.notUsed?.length){const t=r.append("div");t.append("div").attr("data-testid","sjpp-matrix-sorter-ui-hidden-add").style("display","inline-block").style("padding","5x").style("vertical-align","top").style("padding","3px 5px").style("cursor","pointer").html(`+Add`).on("click",N)}}const s=a.append("td").style("text-align","center").style("vertical-align","top");if(e.mayToggle){s.append("button").datum(e).html(e.disabled?"Enable":"Disable").on("click",B)}}const c=o.append("tr").attr("draggable",true).on("mouseover",V);c.append("td").html(" ");const g=c.append("td").style("text-align","left").html(t.details&&!t.order?.length?t.details:" ");if(t.handler)t.handler(g,c,o);c.append("td").html(" ")}},toggleSection:b,trackDraggedSection:f,highlightSection:m,unhighlightSection:x,adjustSortPriority:v,trackDraggedTieBreaker:k,highlightTieBreaker:O,unhighlightTieBreaker:D,adjustTieBreakers:A,trackDraggedValue:P,highlightValue:w,unhighlightValue:T,adjustValueOrder:_,apply:j};function b(t,e={label:"all"}){h.expandedSection=h.expandedSection===e.label?"":e.label;h.expanded=!!h.expandedSection;h.init()}function f(t,e){u.type="sortPriority";u.data=e;u.index=h.activeOption.sortPriority.indexOf(e)}function m(t,e){if(u.type!="sortPriority"||e==u.data)return;t.preventDefault();const i=h.activeOption.sortPriority.indexOf(e);const n=i<u.index?"border-top":i>u.index?"border-bottom":"";if(!n)return;a(this).selectAll("th").style(n,"2px solid blue")}function x(t,e){if(u.type!="sortPriority")return;t.preventDefault();a(this).selectAll("th").style("border","none")}function v(t,e){if(e==u.data)return;const a=h.activeOption.sortPriority.indexOf(e);const i=o.config.settings.matrix;h.activeOption.sortPriority.splice(u.index,1);h.activeOption.sortPriority.splice(a,0,u.data);h.init({sortOptions:{[i.sortSamplesBy]:h.activeOption}})}function k(t,e){u.type="tiebreaker";u.data=e;u.sectionData=t.target.closest("tbody").__data__;u.priorityIndex=h.activeOption.sortPriority.indexOf(u.sectionData);u.index=u.sectionData.tiebreakers.indexOf(e)}function O(t,e){if(u.type!="tiebreaker"||e==u.data)return;t.preventDefault();const i=u.sectionData.tiebreakers.indexOf(e);const n=i<u.index?"border-top":i>u.index?"border-bottom":"";if(!n)return;a(this).selectAll("td:nth-child(2)").style(n,"2px solid blue")}function D(t,e){if(u.type!="tiebreaker")return;t.preventDefault();a(this).selectAll("td:nth-child(2)").style("border","none")}function S(t,e){t.stopPropagation();e.isOrdered=!e.isOrdered;h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}function B(t,e){t.stopPropagation();e.disabled=!e.disabled;h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}function A(t,e){if(u.type!="tiebreaker"||e==u.data)return;t.preventDefault();const a=u.sectionData.tiebreakers.indexOf(e);const i=o.config.settings.matrix;u.sectionData.tiebreakers.splice(u.index,1);u.sectionData.tiebreakers.splice(a,0,u.data);h.init({sortOptions:{[i.sortSamplesBy]:h.activeOption}})}function C(t){const e=[];if(t.tb.notUsed?.includes(t.key))e.push(`- Click on this label to include in used data values.`);if(t.filterByClass[t.key])e.unshift("- Click on the corresponding entry in the matrix legend or Mutation/CNV menus to unhide");if(e.length)e.unshift(`To use this data value for sorting ${p.samples}:`);t.tb.notUsed?.includes(t.key);const i=t.filterByClass[t.key]=="value"?.5:1;const n=a(this).attr("aria-label",e.length?e.join("\n"):`Click to not use this data value to sort ${p.samples}`).attr("draggable",t.tb.isOrdered?true:false).attr("droppable",t.tb.isOrdered?true:false).style("width","fit-content").style("margin-right","10px").style("overflow","hidden").style("white-space","nowrap").style("opacity",i).style("cursor","pointer").on("dragstart",t.dragstart).on("dragover",t.dragover).on("dragleave",t.dragleave).on("drop",t.drop).on("mouseenter",(()=>r.style("opacity",1))).on("mouseleave",(()=>r.style("opacity",0))).on("click",(()=>{if(e.length){const a="sjpp-matrix-sorter-value-note";n.selectAll(`.${a}`).remove();const i=n.append("div").attr("class",a).style("max-width","200px").style("padding","5px");i.html(e.join("<br>"));if(t.filterByClass[t.key])return}const a=t.lstName=="order"?"notUsed":"order";if(!t.tb[a])t.tb[a]=[];const i=t.tb[a];t.tb[t.lstName].splice(t.index,1);if(t.lstName=="order")i.unshift(t.key);else i.push(t.key);h.init({sortOptions:{[d.sortSamplesBy]:h.activeOption}})}));n.append("div").style("display","inline-block").style("cursor","pointer").style("width","12px").style("height","12px").style("margin-right","3px").style("background-color",t.cls.color);n.append("span").style("cursor","pointer").style("text-decoration",t.filterByClass[t.key]=="case"?"line-through":"").html(t.cls.label+(t.filterByClass[t.key]?" (<i>not used since this value is hidden</i>)":""));const r=n.append("div").style("display","inline-block").style("width","12px").style("cursor","pointer").style("opacity",0).style("color",t.lstName=="order"?"red":"green").html(t.lstName=="order"?"✗":"✓")}function P(t,e){t.stopPropagation?.();u.type="value";u.data=e;u.sectionData=t.target.closest("tbody").__data__;u.priorityIndex=h.activeOption.sortPriority.indexOf(u.sectionData);u.tiebreaker=t.target.closest("tr").__data__;u.tbIndex=u.sectionData.tiebreakers.indexOf(u.priorityIndex);u.order=u.tiebreaker.order}function w(t,e){t.stopPropagation?.();if(u.type!="value"||e==u.data)return;if(e.tb!=u.data.tb)return;t.preventDefault();u.order.indexOf(e);a(this).style("border","2px solid blue")}function T(t,e){t.stopPropagation?.();if(u.type!="value")return;t.preventDefault();a(this).style("border","none")}function _(t,e){t.stopPropagation?.();if(u.type!="value"||e==u.data)return;t.preventDefault();const a=h.settings;u.data.tb[u.data.lstName].splice(u.data.index,1);e.tb[e.lstName].splice(e.index,0,u.data.key);const i=a.hiddenVariants.indexOf(u.data.key);const n=structuredClone(a.hiddenVariants);const r=structuredClone(a.filterByClass);if(i!=-1){n.splice(i,1);r[u.data.key]=false}h.init({hiddenVariants:n,filterByClass:r,sortOptions:{[a.sortSamplesBy]:h.activeOption}})}function N(t,e){t?.stopPropagation();const a=c.clear().d.append("div").attr("data-testid","sjpp-matrix-sorter-ui-hidden-vals").style("margin-top","3px").style("vertical-align","top").style("padding-left","12px");a.selectAll("div").data(e.notUsed.map(((t,a)=>({lstName:"notUsed",key:t,cls:i[t],tb:e,dragstart:P,dragover:w,dragleave:T,drop:_,filterByClass:d.filterByClass,index:a})))).enter().append("div").style("display","block").each(C);c.showunder(t.target)}function j(){o.app.tip?.hide();o.app.dispatch({type:"plot_edit",id:o.id,config:{settings:{matrix:{sortOptions:{[d.sortSamplesBy]:h.activeOption}}}}})}function V(){}function U(t,e){if(!o.selectedTermsToSortAgainst?.length){t.html(`Click on a matrix row label and the left triangle to add an entry here`);return}const i=o.selectedTermsToSortAgainst.map((t=>({t:t,label:t.tw.term.name+(t.tw.term.type=="geneVariant"?" alterations":" values")})));const n=a(e.node().parentNode);n.selectAll("tr").remove();n.selectAll("tr").data(i).enter().append("tr").selectAll("td").data(((t,e)=>[{label:e+1,textAlign:"center",cursor:"",t:t.t},{label:t.label,textAlign:"left",cursor:""},{label:"Delete",textAlign:"center",cursor:"pointer",click:o.unsortSamplesAgainstTerm,data:t}])).enter().append("td").style("text-align",(t=>t.textAlign)).style("cursor",(t=>t.cursor)).html((t=>t.label)).on("click",((t,e)=>e.click?.(t,e)))}h.init();h.api={main:h.init,destroy:()=>{r.holder.selectAll("*").remove()}};if(r.debug)h.api.Inner=h;return h.api}export{r as getSorterUi};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{M as t,bn as e,bo as a,Z as n,j as l,U as o,I as r,ag as s,a9 as i,d as c,ah as d,f as p}from"./app-a8c4854a.js";import{b as f}from"./block.lazyload-9f031cac.js";import{d as u}from"./lasso-55cf4057.js";import{b as g,a as m}from"./axis-747c801e.js";import"./drag-0b968811.js";import"./nodrag-2c046d31.js";import"./pointer-c7475677.js";const h="#ffa200";const v=new t;function x(t,e,a,n){if(!t.dataname){t.dataname="Differential expression"}if(t.input){const l=t.input;delete t.input;const o=b({genome:t.genome,filename:t.dataname,holder:a,tracks:t.tracks,hostURL:t.hostURL,jwt:n},l.trim().split("\n"));if(o){e("Error with diferential gene expressionn data: "+o)}return}let l;if(t.url){l=new Request(t.hostURL+"/urltextfile",{method:"POST",body:JSON.stringify({url:t.url,jwt:n})});delete t.url}else if(t.file){l=new Request(t.hostURL+"/textfile",{method:"POST",body:JSON.stringify({file:t.file,jwt:n})});delete t.file}else{e("neither .input nor .url given for MA-Volcano plot");return}const o=a.append("div").style("margin","20px").style("color","#aaa").style("font-size","1.5em").text("Loading differential gene expression data ...");fetch(l).then((t=>t.json())).then((e=>{if(e.error)throw{message:e.error};if(!e.text)throw{message:"no data loaded"};const l=b({genome:t.genome,filename:t.dataname,holder:a,tracks:t.tracks,hostURL:t.hostURL,jwt:n},e.text.trim().split("\n"));if(l)throw{message:"Error with differential gene expression data: "+l}})).catch((t=>{e(t.message);if(t.stack)console.log(t.stack)})).then((()=>{o.remove()}))}function y(t,n,l,o,r){let s,i,c,d,p,f;if(o!==undefined)[i,c,d,p,f]=e(o,t);else{[s,i,c,d,p,f]=a(100,100,t);s.header.text("Differential gene expression viewer");s.body.style("margin","10px")}i.append("div").style("margin-top","30px").style("color","#858585").html(`\n\t\t<p>Interactive MA and Volcano plot for exploring differentially expressed genes.</p>\n\t\t<a href=https://docs.google.com/document/d/1gEhywyMzMQRM10NFvsObw1yDSWxVY7pxYjsQ2-nd6x4/edit?usp=sharing target=_blank>File format</a>\n\t\t`);function u(t,e){p.style("color",e?"red":"black").text(t)}const g=()=>{d.selectAll("*").remove();const e=d.append("input").attr("type","file").on("change",(e=>{const a=e.target.files[0];if(!a){g();return}if(!a.size){u("Invalid file "+a.name);g();return}const i=new FileReader;i.onload=e=>{const i=c.options[c.selectedIndex].innerHTML;const d=b({genome:t[i],filename:a.name,hostURL:n,jwt:l,holder:o,sandbox_header:r},e.target.result.trim().split("\n"));if(d){u(d,1);g();return}if(s)s.pane.remove()};i.onerror=function(){u("Error reading file "+a.name,1);g();return};i.readAsText(a,"utf8")}));setTimeout((()=>e.node().focus()),1100)};g()}function b(t,e){if(t.tracks){for(const e of t.tracks){e.iscustom=true}}const[a,o]=k(e[0].trim());if(a){return a}t.hastvalue=o.includes("tvalue");const r=[];let s=0;let i=0;let c=0;for(let a=1;a<e.length;a++){const n=e[a];if(n=="")continue;if(n[0]=="#")continue;const l=n.trim().split("\t");const d={};for(let t=0;t<o.length;t++){d[o[t]]=l[t]}if(!d.gene){return"(line "+(a+1)+") missing gene"}d.gene=d.gene.replace(/"/g,"");if(!d.logfoldchange){return"(line "+(a+1)+") missing log fold change"}{const t=Number.parseFloat(d.logfoldchange);if(Number.isNaN(t)){c++;continue}d.logfoldchange=t}if(!d.averagevalue){return"(line "+(a+1)+") missing average value"}{const t=Number.parseFloat(d.averagevalue);if(Number.isNaN(t)){return"(line "+(a+1)+") invalid value for average value: "+d.averagevalue}d.averagevalue=t}if(!d.pvalue){s++;continue}else{const t=Number.parseFloat(d.pvalue);if(Number.isNaN(t)){s++;continue}d.pvalue=t}if(d.pvalueadj){const t=Number.parseFloat(d.pvalueadj);if(Number.isNaN(t)){i++;continue}d.pvalueadj=t}if(t.hastvalue){if(!d.tvalue){return"(line "+(a+1)+") missing T value"}{const t=Number.parseFloat(d.tvalue);if(Number.isNaN(t)){return"(line "+(a+1)+") invalid value for T value: "+d.tvalue}d.tvalue=t}}r.push(d)}if(r.length==0){return"No valid data"}if(t.holder==undefined){const e=n({x:100,y:100});e.header.text(t.filename);t.holder=e.body}else{t.holder.selectAll("*").remove();if(t.sandbox_header!==undefined)t.holder.append("div").html('<span style="opacity:.5;font-size:.7em">FILE: </span> '+t.filename)}t.data=r;if(c+s+i>0){const e=t.holder.append("div").style("width","800px");if(c){l(e,c+" lines dropped for invalid log fold change value")}if(s){l(e,s+" lines dropped for invalid P value")}if(i){l(e,i+" lines dropped for invalid adjusted P value")}}_(t);return null}function k(t){const e=t.toLowerCase().split("\t");const a=t.split("\t");if(a.length<=1){return["invalid file header"]}const n=(...t)=>{for(const a of t){const t=e.indexOf(a);if(t!=-1)return t}return-1};let l=n("gene");if(l==-1)return["gene missing from header"];a[l]="gene";l=n("logfc","log.foldchange");if(l==-1)return["log.foldchange missing from header"];a[l]="logfoldchange";l=n("aveexpr","average.value");if(l==-1)return["average.value missing from header"];a[l]="averagevalue";l=n("t","t.value");if(l!=-1){a[l]="tvalue"}l=n("p.value");if(l==-1)return["p.value missing from header"];a[l]="pvalue";l=n("p.value.adjusted","adj.p.val","adjustedp-value(fdr)");if(l!=-1){a[l]="pvalueadj"}return[null,a]}function _(t){if(t.hastvalue){let e=Math.abs(t.data[0].tvalue);let a=0;for(const n of t.data){const t=Math.abs(n.tvalue);e=Math.min(e,t);a=Math.max(a,t)}t.tvaluemin=e;t.tvaluemax=a}const e=t.holder.append("div").style("display","inline-block").style("vertical-align","top").style("margin","20px");const a=w(e,t);const n=t.holder.append("div").style("display","inline-block").style("vertical-align","top").style("margin","20px");const l=M(n,t);const r=t.holder.append("div").style("margin","20px");const s=r.append("textarea").style("display","inline-block").attr("rows",5).attr("cols",10).style("resize","both").attr("placeholder","Enter genes, separate by space or newline");const i=r.append("div").style("display","inline-block").style("margin-left","10px").style("vertical-align","top");i.append("button").style("display","block").text("Show gene labels").on("click",(e=>{const a=s.property("value").trim();if(a=="")return;const n=new Set;for(const t of a.split(/[\s\n\t]+/)){n.add(t.toUpperCase())}if(n.size==0)return;for(const e of t.data){if(!e.ma_label&&n.has(e.gene.toUpperCase())){A(e,t)}}}));i.append("button").style("display","block").text("Remove all labels").on("click",(e=>{for(const e of t.data){if(e.ma_label){A(e,t)}}}));i.append("div").style("margin-top","10px").style("color","#858585").style("font-size",".8em").html('<span style="font-size:1.3em">TIP:</span> click circles to toggle highlight on genes;<br>drag to move a gene label around.');const c=r.append("div").style("display","inline-block").style("margin-left","30px").style("vertical-align","top");c.append("button").text("Get MA plot").style("display","block").on("click",(t=>{o(a.node(),"MAplot")}));c.append("button").text("Get volcano plot").style("display","block").on("click",(t=>{o(l.node(),"Volcano")}))}function w(t,e){const a=[];let n=0,l=0;for(const t of e.data){n=Math.min(n,t.logfoldchange);l=Math.max(l,t.logfoldchange);a.push(t.averagevalue)}a.sort(((t,e)=>t-e));const o=a[0];const i=a[a.length-1];let c,d,p,f,u,v,x,y=50,b=50,k;const _=t.append("svg");const w=_.append("g");const M=_.append("g");const A=_.append("text").text("Average expression value").attr("fill","black").attr("text-anchor","middle");const E=_.append("text").text("log2(fold change)").attr("fill","black").attr("text-anchor","middle");e.ma_dotarea=_.append("g");const P=e.ma_dotarea.append("rect").attr("stroke","#ededed").attr("fill","none").attr("shape-rendering","crispEdges");const U=r().domain([o,i]);const z=r().domain([n,l]);let F;if(e.hastvalue){F=r().domain([e.tvaluemin,e.tvaluemax])}const S=e.ma_dotarea.selectAll().data(e.data).enter().append("g").each((function(t){t.ma_g=this}));const T=S.append("circle").attr("stroke","black").attr("stroke-opacity",.2).attr("stroke-width",1).attr("fill",h).attr("fill-opacity",0).each((function(t){t.ma_circle=this})).on("mouseover",N).on("mouseout",R).on("click",((t,a)=>{L(a,e,t.clientX,t.clientY)}));const I=e.ma_dotarea.append("line").attr("stroke","#ccc").attr("shape-rendering","crispEdges");const O=_.append("g");const Y=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const X=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const C=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const V=O.append("rect").attr("fill","white").attr("stroke",h).attr("shape-rendering","crispEdges");const D=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const q=a[Math.ceil(a.length*.05)];const J=a[Math.ceil(a.length*.95)];const G=a[Math.ceil(a.length*.25)];const Q=a[Math.ceil(a.length*.75)];const H=a[Math.ceil(a.length/2)];function W(t,a){p=t;f=a;c=Math.max(50,p/8);d=Math.max(50,f/8);k=Math.max(p,f)/80;const n=k*3;U.range([0,p]);z.range([f,0]);if(F)F.range([k,n]);T.each((t=>{t.ma_radius=F?F(Math.abs(t.tvalue)):k}));x=k*3;u=Math.max(n,p/50);v=Math.max(n,f/50);w.attr("transform","translate("+c+","+y+")");M.attr("transform","translate("+(c+u)+","+(y+f+v+x+v)+")");A.attr("x",c+u+p/2).attr("y",y+f+v+x+v+d-5);E.attr("transform","translate(15,"+(y+f/2)+") rotate(-90)");e.ma_dotarea.attr("transform","translate("+(c+u)+","+y+")");P.attr("width",p).attr("height",f);S.attr("transform",(t=>"translate("+U(t.averagevalue)+","+z(t.logfoldchange)+")"));T.attr("r",(t=>t.ma_radius));I.attr("x2",p).attr("y1",z(0)).attr("y2",z(0));O.attr("transform","translate("+(c+u)+","+(y+f+v)+")");const l=U(q),o=U(G),r=U(H),i=U(Q),h=U(J);X.attr("x1",l).attr("x2",l).attr("y2",x);C.attr("x1",h).attr("x2",h).attr("y2",x);D.attr("x1",r).attr("x2",r).attr("y2",x);V.attr("x",o).attr("width",i-o).attr("height",x);Y.attr("x1",l).attr("x2",h).attr("y1",x/2).attr("y2",x/2);_.attr("width",c+u+p+b).attr("height",y+f+v+x+v+d);s({axis:w.call(g().scale(z)),color:"black",showline:true});s({axis:M.call(m().scale(U)),color:"black",showline:true})}W(400,400);j(S.selectAll("circle"),_,"vo_circle");return _}function M(t,e){let a=0,n=0,l=0,o=0;for(const t of e.data){a=Math.min(a,t.logfoldchange);n=Math.max(n,t.logfoldchange);if(t.pvalue==0){continue}else{const e=-Math.log(t.pvalue,10);l=Math.min(l,e);o=Math.max(o,e)}}let i,c,d,p,f,u,v=50,x=50,y;const b=t.append("svg");const k=b.append("g");const _=b.append("g");const w=b.append("text").text("log2(fold change)").attr("fill","black").attr("text-anchor","middle");const M=b.append("text").text("-log(P value)").attr("fill","black").attr("text-anchor","middle");e.vo_dotarea=b.append("g");const A=e.vo_dotarea.append("rect").attr("stroke","#ededed").attr("fill","none").attr("shape-rendering","crispEdges");const E=r().domain([a,n]);const P=r().domain([l,o]);let U;if(e.hastvalue)U=r().domain([e.tvaluemin,e.tvaluemax]);const z=e.vo_dotarea.selectAll().data(e.data).enter().append("g").each((function(t){t.vo_g=this}));const F=z.append("circle").attr("stroke","black").attr("stroke-opacity",.2).attr("stroke-width",1).attr("fill",h).attr("fill-opacity",0).each((function(t){t.vo_circle=this})).on("mouseover",N).on("mouseout",R).on("click",((t,a)=>{L(a,e,t.clientX,t.clientY)}));const S=e.vo_dotarea.append("line").attr("stroke","#ccc").attr("shape-rendering","crispEdges");function T(t,a){d=t;p=a;i=Math.max(50,d/8);c=Math.max(50,p/8);y=Math.max(d,p)/80;const n=y*3;if(U)U.range([y,n]);F.each((t=>{t.vo_radius=U?U(Math.abs(t.tvalue)):y}));f=Math.max(n,d/50);u=Math.max(n,p/50);k.attr("transform","translate("+i+","+v+")");_.attr("transform","translate("+(i+f)+","+(v+p+u)+")");w.attr("x",i+f+d/2).attr("y",v+p+u+c-5);M.attr("transform","translate(15,"+(v+p/2)+") rotate(-90)");e.vo_dotarea.attr("transform","translate("+(i+f)+","+v+")");A.attr("width",d).attr("height",p);E.range([0,d]);P.range([p,0]);z.attr("transform",(t=>"translate("+E(t.logfoldchange)+","+P(t.pvalue==0?o:-Math.log(t.pvalue,10))+")"));F.attr("r",(t=>t.vo_radius));S.attr("x1",E(0)).attr("x2",E(0)).attr("y2",p);b.attr("width",i+f+d+x).attr("height",v+p+u+c);s({axis:k.call(g().scale(P)),color:"black",showline:true});s({axis:_.call(m().scale(E)),color:"black",showline:true})}T(400,400);if(e.data[0].pvalueadj!=undefined){const a=t.append("div").style("margin","20px");a.append("span").text("Select P value for Volcano plot:");const n=a.append("select").style("margin-left","5px").on("change",(t=>{l=0;o=0;const a=n.node().selectedIndex==0;for(const t of e.data){const e=a?t.pvalue:t.pvalueadj;if(e==0)continue;const n=-Math.log(e,10);l=Math.min(l,n);o=Math.max(o,n)}P.domain([l,o]);s({axis:k.call(g().scale(P)),color:"black",showline:true});z.attr("transform",(t=>{const e=a?t.pvalue:t.pvalueadj;return"translate("+E(t.logfoldchange)+","+P(e==0?o:-Math.log(e,10))+")"}));M.text(a?"-log(P value)":"-log(adjusted P value)")}));n.append("option").text("Unadjusted P value");n.append("option").text("Adjusted P value")}j(z.selectAll("circle"),b,"ma_circle");return b}function j(t,e,a){const n=u().items(t).targetArea(e);function l(){e.selectAll(".possible").style("fill-opacity",0).classed("not_possible",true).classed("selected",false).each((t=>{c(t[a]).attr("fill-opacity",0)}))}function o(){n.possibleItems().style("fill-opacity",.9).classed("not_possible",false).classed("possible",true).each((t=>{c(t[a]).attr("fill-opacity",.9)}))}function r(){}n.on("start",l).on("draw",o).on("end",r);e.call(n)}function N(t,e){v.clear().show(t.clientX,t.clientY);const a=[{k:"gene",v:e.gene},{k:"average value",v:e.averagevalue},{k:"log fold change",v:e.logfoldchange},{k:"P value",v:e.pvalue}];if(e.pvalueadj!=undefined){a.push({k:"adjusted P value",v:e.pvalueadj})}if(e.tvalue!=undefined){a.push({k:"T value",v:e.tvalue})}for(const t in e){if(t=="gene"||t=="averagevalue"||t=="logfoldchange"||t=="pvalue"||t=="pvalueadj"||t=="tvalue"){continue}const n=e[t];if(typeof n!="string"){continue}a.push({k:t,v:n})}i(v.d,a);if(!e.ma_label){c(e.ma_circle).attr("fill-opacity",.9);c(e.vo_circle).attr("fill-opacity",.9)}}function R(t,e){v.hide();if(!e.ma_label){c(e.ma_circle).attr("fill-opacity",0);c(e.vo_circle).attr("fill-opacity",0)}}function A(t,e){if(t.ma_label){t.ma_label.remove();t.ma_labelbg.remove();t.ma_label=null;t.vo_label.remove();t.vo_labelbg.remove();t.vo_label=null;c(t.ma_circle).attr("fill-opacity",0);c(t.vo_circle).attr("fill-opacity",0);return}e.ma_dotarea.node().appendChild(t.ma_g);t.ma_labelbg=c(t.ma_g).append("text").text(t.gene).attr("x",t.ma_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("font-family",d).attr("fill","none").attr("stroke","white").attr("stroke-width",3);t.ma_label=c(t.ma_g).append("text").text(t.gene).attr("x",t.ma_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("fill","black").attr("font-family",d).on("mousedown",((t,e)=>{E(e.ma_label,e.ma_labelbg,t)}));e.vo_dotarea.node().appendChild(t.vo_g);t.vo_labelbg=c(t.vo_g).append("text").text(t.gene).attr("x",t.vo_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("font-family",d).attr("fill","none").attr("stroke","white").attr("stroke-width",3);t.vo_label=c(t.vo_g).append("text").text(t.gene).attr("x",t.vo_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("fill","black").attr("font-family",d).on("mousedown",((t,e)=>{E(e.vo_label,e.vo_labelbg,t)}));c(t.ma_circle).attr("fill-opacity",.8);c(t.vo_circle).attr("fill-opacity",.8)}function E(t,e,a){event.preventDefault();const n=Number.parseFloat(t.attr("x"));const l=Number.parseFloat(t.attr("y"));const o=a.clientX;const r=a.clientY;const s=c(document.body);s.on("mousemove",(a=>{t.attr("x",n+a.clientX-o).attr("y",l+a.clientY-r);e.attr("x",n+a.clientX-o).attr("y",l+a.clientY-r)})).on("mouseup",(t=>{s.on("mousemove",null).on("mouseup",null)}))}function L(t,e,a,l){if(e.tracks){if(!t.ma_label){const o=n({x:a+20,y:l-50});o.header.text(t.gene);P(e,t.gene,o.body)}}A(t,e)}function P(t,e,a){fetch(new Request(t.hostURL+"/genelookup",{method:"POST",body:JSON.stringify({deep:1,input:e,genome:t.genome.name,jwt:t.jwt})})).then((t=>t.json())).then((n=>{if(n.error)throw{message:n.error};if(!n.gmlst||n.gmlst.length==0)throw{message:"No genes can be found for "+e};const l=new Map;for(const t of n.gmlst){if(!l.has(t.chr)){l.set(t.chr,{chr:t.chr,start:t.start,stop:t.stop})}l.get(t.chr).start=Math.min(t.start,l.get(t.chr).start);l.get(t.chr).stop=Math.max(t.stop,l.get(t.chr).stop)}const o=[...l][0][1];const r=[...t.tracks];p(t.genome,r);f({holder:a,hostURL:t.hostURL,jwt:t.jwt,genome:t.genome,chr:o.chr,start:o.start,stop:o.stop,tklst:r,nobox:true})})).catch((t=>{l(a,t.message);if(t.stack)console.log(t.stack)}))}export{x as mavbparseinput,y as mavbui};
|
|
1
|
+
import{M as t,bn as e,bo as a,Z as n,j as l,U as o,I as r,ag as s,a9 as i,d as c,ah as d,f as p}from"./app-b369b169.js";import{b as f}from"./block.lazyload-87b12654.js";import{d as u}from"./lasso-f767f634.js";import{b as g,a as m}from"./axis-747c801e.js";import"./drag-7b30ba17.js";import"./nodrag-16ad4b03.js";import"./pointer-c7475677.js";const h="#ffa200";const v=new t;function x(t,e,a,n){if(!t.dataname){t.dataname="Differential expression"}if(t.input){const l=t.input;delete t.input;const o=y({genome:t.genome,filename:t.dataname,holder:a,tracks:t.tracks,hostURL:t.hostURL,jwt:n},l.trim().split("\n"));if(o){e("Error with diferential gene expressionn data: "+o)}return}let l;if(t.url){l=new Request(t.hostURL+"/urltextfile",{method:"POST",body:JSON.stringify({url:t.url,jwt:n})});delete t.url}else if(t.file){l=new Request(t.hostURL+"/textfile",{method:"POST",body:JSON.stringify({file:t.file,jwt:n})});delete t.file}else{e("neither .input nor .url given for MA-Volcano plot");return}const o=a.append("div").style("margin","20px").style("color","#aaa").style("font-size","1.5em").text("Loading differential gene expression data ...");fetch(l).then((t=>t.json())).then((e=>{if(e.error)throw{message:e.error};if(!e.text)throw{message:"no data loaded"};const l=y({genome:t.genome,filename:t.dataname,holder:a,tracks:t.tracks,hostURL:t.hostURL,jwt:n},e.text.trim().split("\n"));if(l)throw{message:"Error with differential gene expression data: "+l}})).catch((t=>{e(t.message);if(t.stack)console.log(t.stack)})).then((()=>{o.remove()}))}function b(t,n,l,o,r){let s,i,c,d,p,f;if(o!==undefined)[i,c,d,p,f]=e(o,t);else{[s,i,c,d,p,f]=a(100,100,t);s.header.text("Differential gene expression viewer");s.body.style("margin","10px")}i.append("div").style("margin-top","30px").style("color","#858585").html(`\n\t\t<p>Interactive MA and Volcano plot for exploring differentially expressed genes.</p>\n\t\t<a href=https://docs.google.com/document/d/1gEhywyMzMQRM10NFvsObw1yDSWxVY7pxYjsQ2-nd6x4/edit?usp=sharing target=_blank>File format</a>\n\t\t`);function u(t,e){p.style("color",e?"red":"black").text(t)}const g=()=>{d.selectAll("*").remove();const e=d.append("input").attr("type","file").on("change",(e=>{const a=e.target.files[0];if(!a){g();return}if(!a.size){u("Invalid file "+a.name);g();return}const i=new FileReader;i.onload=e=>{const i=c.options[c.selectedIndex].innerHTML;const d=y({genome:t[i],filename:a.name,hostURL:n,jwt:l,holder:o,sandbox_header:r},e.target.result.trim().split("\n"));if(d){u(d,1);g();return}if(s)s.pane.remove()};i.onerror=function(){u("Error reading file "+a.name,1);g();return};i.readAsText(a,"utf8")}));setTimeout((()=>e.node().focus()),1100)};g()}function y(t,e){if(t.tracks){for(const e of t.tracks){e.iscustom=true}}const[a,o]=k(e[0].trim());if(a){return a}t.hastvalue=o.includes("tvalue");const r=[];let s=0;let i=0;let c=0;for(let a=1;a<e.length;a++){const n=e[a];if(n=="")continue;if(n[0]=="#")continue;const l=n.trim().split("\t");const d={};for(let t=0;t<o.length;t++){d[o[t]]=l[t]}if(!d.gene){return"(line "+(a+1)+") missing gene"}d.gene=d.gene.replace(/"/g,"");if(!d.logfoldchange){return"(line "+(a+1)+") missing log fold change"}{const t=Number.parseFloat(d.logfoldchange);if(Number.isNaN(t)){c++;continue}d.logfoldchange=t}if(!d.averagevalue){return"(line "+(a+1)+") missing average value"}{const t=Number.parseFloat(d.averagevalue);if(Number.isNaN(t)){return"(line "+(a+1)+") invalid value for average value: "+d.averagevalue}d.averagevalue=t}if(!d.pvalue){s++;continue}else{const t=Number.parseFloat(d.pvalue);if(Number.isNaN(t)){s++;continue}d.pvalue=t}if(d.pvalueadj){const t=Number.parseFloat(d.pvalueadj);if(Number.isNaN(t)){i++;continue}d.pvalueadj=t}if(t.hastvalue){if(!d.tvalue){return"(line "+(a+1)+") missing T value"}{const t=Number.parseFloat(d.tvalue);if(Number.isNaN(t)){return"(line "+(a+1)+") invalid value for T value: "+d.tvalue}d.tvalue=t}}r.push(d)}if(r.length==0){return"No valid data"}if(t.holder==undefined){const e=n({x:100,y:100});e.header.text(t.filename);t.holder=e.body}else{t.holder.selectAll("*").remove();if(t.sandbox_header!==undefined)t.holder.append("div").html('<span style="opacity:.5;font-size:.7em">FILE: </span> '+t.filename)}t.data=r;if(c+s+i>0){const e=t.holder.append("div").style("width","800px");if(c){l(e,c+" lines dropped for invalid log fold change value")}if(s){l(e,s+" lines dropped for invalid P value")}if(i){l(e,i+" lines dropped for invalid adjusted P value")}}_(t);return null}function k(t){const e=t.toLowerCase().split("\t");const a=t.split("\t");if(a.length<=1){return["invalid file header"]}const n=(...t)=>{for(const a of t){const t=e.indexOf(a);if(t!=-1)return t}return-1};let l=n("gene");if(l==-1)return["gene missing from header"];a[l]="gene";l=n("logfc","log.foldchange");if(l==-1)return["log.foldchange missing from header"];a[l]="logfoldchange";l=n("aveexpr","average.value");if(l==-1)return["average.value missing from header"];a[l]="averagevalue";l=n("t","t.value");if(l!=-1){a[l]="tvalue"}l=n("p.value");if(l==-1)return["p.value missing from header"];a[l]="pvalue";l=n("p.value.adjusted","adj.p.val","adjustedp-value(fdr)");if(l!=-1){a[l]="pvalueadj"}return[null,a]}function _(t){if(t.hastvalue){let e=Math.abs(t.data[0].tvalue);let a=0;for(const n of t.data){const t=Math.abs(n.tvalue);e=Math.min(e,t);a=Math.max(a,t)}t.tvaluemin=e;t.tvaluemax=a}const e=t.holder.append("div").style("display","inline-block").style("vertical-align","top").style("margin","20px");const a=w(e,t);const n=t.holder.append("div").style("display","inline-block").style("vertical-align","top").style("margin","20px");const l=M(n,t);const r=t.holder.append("div").style("margin","20px");const s=r.append("textarea").style("display","inline-block").attr("rows",5).attr("cols",10).style("resize","both").attr("placeholder","Enter genes, separate by space or newline");const i=r.append("div").style("display","inline-block").style("margin-left","10px").style("vertical-align","top");i.append("button").style("display","block").text("Show gene labels").on("click",(e=>{const a=s.property("value").trim();if(a=="")return;const n=new Set;for(const t of a.split(/[\s\n\t]+/)){n.add(t.toUpperCase())}if(n.size==0)return;for(const e of t.data){if(!e.ma_label&&n.has(e.gene.toUpperCase())){A(e,t)}}}));i.append("button").style("display","block").text("Remove all labels").on("click",(e=>{for(const e of t.data){if(e.ma_label){A(e,t)}}}));i.append("div").style("margin-top","10px").style("color","#858585").style("font-size",".8em").html('<span style="font-size:1.3em">TIP:</span> click circles to toggle highlight on genes;<br>drag to move a gene label around.');const c=r.append("div").style("display","inline-block").style("margin-left","30px").style("vertical-align","top");c.append("button").text("Get MA plot").style("display","block").on("click",(t=>{o(a.node(),"MAplot")}));c.append("button").text("Get volcano plot").style("display","block").on("click",(t=>{o(l.node(),"Volcano")}))}function w(t,e){const a=[];let n=0,l=0;for(const t of e.data){n=Math.min(n,t.logfoldchange);l=Math.max(l,t.logfoldchange);a.push(t.averagevalue)}a.sort(((t,e)=>t-e));const o=a[0];const i=a[a.length-1];let c,d,p,f,u,v,x,b=50,y=50,k;const _=t.append("svg");const w=_.append("g");const M=_.append("g");const A=_.append("text").text("Average expression value").attr("fill","black").attr("text-anchor","middle");const E=_.append("text").text("log2(fold change)").attr("fill","black").attr("text-anchor","middle");e.ma_dotarea=_.append("g");const P=e.ma_dotarea.append("rect").attr("stroke","#ededed").attr("fill","none").attr("shape-rendering","crispEdges");const U=r().domain([o,i]);const z=r().domain([n,l]);let F;if(e.hastvalue){F=r().domain([e.tvaluemin,e.tvaluemax])}const S=e.ma_dotarea.selectAll().data(e.data).enter().append("g").each((function(t){t.ma_g=this}));const T=S.append("circle").attr("stroke","black").attr("stroke-opacity",.2).attr("stroke-width",1).attr("fill",h).attr("fill-opacity",0).each((function(t){t.ma_circle=this})).on("mouseover",N).on("mouseout",R).on("click",((t,a)=>{L(a,e,t.clientX,t.clientY)}));const I=e.ma_dotarea.append("line").attr("stroke","#ccc").attr("shape-rendering","crispEdges");const O=_.append("g");const Y=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const X=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const C=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const V=O.append("rect").attr("fill","white").attr("stroke",h).attr("shape-rendering","crispEdges");const D=O.append("line").attr("stroke",h).attr("shape-rendering","crispEdges");const q=a[Math.ceil(a.length*.05)];const J=a[Math.ceil(a.length*.95)];const G=a[Math.ceil(a.length*.25)];const Q=a[Math.ceil(a.length*.75)];const H=a[Math.ceil(a.length/2)];function W(t,a){p=t;f=a;c=Math.max(50,p/8);d=Math.max(50,f/8);k=Math.max(p,f)/80;const n=k*3;U.range([0,p]);z.range([f,0]);if(F)F.range([k,n]);T.each((t=>{t.ma_radius=F?F(Math.abs(t.tvalue)):k}));x=k*3;u=Math.max(n,p/50);v=Math.max(n,f/50);w.attr("transform","translate("+c+","+b+")");M.attr("transform","translate("+(c+u)+","+(b+f+v+x+v)+")");A.attr("x",c+u+p/2).attr("y",b+f+v+x+v+d-5);E.attr("transform","translate(15,"+(b+f/2)+") rotate(-90)");e.ma_dotarea.attr("transform","translate("+(c+u)+","+b+")");P.attr("width",p).attr("height",f);S.attr("transform",(t=>"translate("+U(t.averagevalue)+","+z(t.logfoldchange)+")"));T.attr("r",(t=>t.ma_radius));I.attr("x2",p).attr("y1",z(0)).attr("y2",z(0));O.attr("transform","translate("+(c+u)+","+(b+f+v)+")");const l=U(q),o=U(G),r=U(H),i=U(Q),h=U(J);X.attr("x1",l).attr("x2",l).attr("y2",x);C.attr("x1",h).attr("x2",h).attr("y2",x);D.attr("x1",r).attr("x2",r).attr("y2",x);V.attr("x",o).attr("width",i-o).attr("height",x);Y.attr("x1",l).attr("x2",h).attr("y1",x/2).attr("y2",x/2);_.attr("width",c+u+p+y).attr("height",b+f+v+x+v+d);s({axis:w.call(g().scale(z)),color:"black",showline:true});s({axis:M.call(m().scale(U)),color:"black",showline:true})}W(400,400);j(S.selectAll("circle"),_,"vo_circle");return _}function M(t,e){let a=0,n=0,l=0,o=0;for(const t of e.data){a=Math.min(a,t.logfoldchange);n=Math.max(n,t.logfoldchange);if(t.pvalue==0){continue}else{const e=-Math.log(t.pvalue,10);l=Math.min(l,e);o=Math.max(o,e)}}let i,c,d,p,f,u,v=50,x=50,b;const y=t.append("svg");const k=y.append("g");const _=y.append("g");const w=y.append("text").text("log2(fold change)").attr("fill","black").attr("text-anchor","middle");const M=y.append("text").text("-log(P value)").attr("fill","black").attr("text-anchor","middle");e.vo_dotarea=y.append("g");const A=e.vo_dotarea.append("rect").attr("stroke","#ededed").attr("fill","none").attr("shape-rendering","crispEdges");const E=r().domain([a,n]);const P=r().domain([l,o]);let U;if(e.hastvalue)U=r().domain([e.tvaluemin,e.tvaluemax]);const z=e.vo_dotarea.selectAll().data(e.data).enter().append("g").each((function(t){t.vo_g=this}));const F=z.append("circle").attr("stroke","black").attr("stroke-opacity",.2).attr("stroke-width",1).attr("fill",h).attr("fill-opacity",0).each((function(t){t.vo_circle=this})).on("mouseover",N).on("mouseout",R).on("click",((t,a)=>{L(a,e,t.clientX,t.clientY)}));const S=e.vo_dotarea.append("line").attr("stroke","#ccc").attr("shape-rendering","crispEdges");function T(t,a){d=t;p=a;i=Math.max(50,d/8);c=Math.max(50,p/8);b=Math.max(d,p)/80;const n=b*3;if(U)U.range([b,n]);F.each((t=>{t.vo_radius=U?U(Math.abs(t.tvalue)):b}));f=Math.max(n,d/50);u=Math.max(n,p/50);k.attr("transform","translate("+i+","+v+")");_.attr("transform","translate("+(i+f)+","+(v+p+u)+")");w.attr("x",i+f+d/2).attr("y",v+p+u+c-5);M.attr("transform","translate(15,"+(v+p/2)+") rotate(-90)");e.vo_dotarea.attr("transform","translate("+(i+f)+","+v+")");A.attr("width",d).attr("height",p);E.range([0,d]);P.range([p,0]);z.attr("transform",(t=>"translate("+E(t.logfoldchange)+","+P(t.pvalue==0?o:-Math.log(t.pvalue,10))+")"));F.attr("r",(t=>t.vo_radius));S.attr("x1",E(0)).attr("x2",E(0)).attr("y2",p);y.attr("width",i+f+d+x).attr("height",v+p+u+c);s({axis:k.call(g().scale(P)),color:"black",showline:true});s({axis:_.call(m().scale(E)),color:"black",showline:true})}T(400,400);if(e.data[0].pvalueadj!=undefined){const a=t.append("div").style("margin","20px");a.append("span").text("Select P value for Volcano plot:");const n=a.append("select").style("margin-left","5px").on("change",(t=>{l=0;o=0;const a=n.node().selectedIndex==0;for(const t of e.data){const e=a?t.pvalue:t.pvalueadj;if(e==0)continue;const n=-Math.log(e,10);l=Math.min(l,n);o=Math.max(o,n)}P.domain([l,o]);s({axis:k.call(g().scale(P)),color:"black",showline:true});z.attr("transform",(t=>{const e=a?t.pvalue:t.pvalueadj;return"translate("+E(t.logfoldchange)+","+P(e==0?o:-Math.log(e,10))+")"}));M.text(a?"-log(P value)":"-log(adjusted P value)")}));n.append("option").text("Unadjusted P value");n.append("option").text("Adjusted P value")}j(z.selectAll("circle"),y,"ma_circle");return y}function j(t,e,a){const n=u().items(t).targetArea(e);function l(){e.selectAll(".possible").style("fill-opacity",0).classed("not_possible",true).classed("selected",false).each((t=>{c(t[a]).attr("fill-opacity",0)}))}function o(){n.possibleItems().style("fill-opacity",.9).classed("not_possible",false).classed("possible",true).each((t=>{c(t[a]).attr("fill-opacity",.9)}))}function r(){}n.on("start",l).on("draw",o).on("end",r);e.call(n)}function N(t,e){v.clear().show(t.clientX,t.clientY);const a=[{k:"gene",v:e.gene},{k:"average value",v:e.averagevalue},{k:"log fold change",v:e.logfoldchange},{k:"P value",v:e.pvalue}];if(e.pvalueadj!=undefined){a.push({k:"adjusted P value",v:e.pvalueadj})}if(e.tvalue!=undefined){a.push({k:"T value",v:e.tvalue})}for(const t in e){if(t=="gene"||t=="averagevalue"||t=="logfoldchange"||t=="pvalue"||t=="pvalueadj"||t=="tvalue"){continue}const n=e[t];if(typeof n!="string"){continue}a.push({k:t,v:n})}i(v.d,a);if(!e.ma_label){c(e.ma_circle).attr("fill-opacity",.9);c(e.vo_circle).attr("fill-opacity",.9)}}function R(t,e){v.hide();if(!e.ma_label){c(e.ma_circle).attr("fill-opacity",0);c(e.vo_circle).attr("fill-opacity",0)}}function A(t,e){if(t.ma_label){t.ma_label.remove();t.ma_labelbg.remove();t.ma_label=null;t.vo_label.remove();t.vo_labelbg.remove();t.vo_label=null;c(t.ma_circle).attr("fill-opacity",0);c(t.vo_circle).attr("fill-opacity",0);return}e.ma_dotarea.node().appendChild(t.ma_g);t.ma_labelbg=c(t.ma_g).append("text").text(t.gene).attr("x",t.ma_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("font-family",d).attr("fill","none").attr("stroke","white").attr("stroke-width",3);t.ma_label=c(t.ma_g).append("text").text(t.gene).attr("x",t.ma_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("fill","black").attr("font-family",d).on("mousedown",((t,e)=>{E(e.ma_label,e.ma_labelbg,t)}));e.vo_dotarea.node().appendChild(t.vo_g);t.vo_labelbg=c(t.vo_g).append("text").text(t.gene).attr("x",t.vo_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("font-family",d).attr("fill","none").attr("stroke","white").attr("stroke-width",3);t.vo_label=c(t.vo_g).append("text").text(t.gene).attr("x",t.vo_radius+5).attr("y",0).attr("dominant-baseline","central").attr("font-size",14).attr("fill","black").attr("font-family",d).on("mousedown",((t,e)=>{E(e.vo_label,e.vo_labelbg,t)}));c(t.ma_circle).attr("fill-opacity",.8);c(t.vo_circle).attr("fill-opacity",.8)}function E(t,e,a){event.preventDefault();const n=Number.parseFloat(t.attr("x"));const l=Number.parseFloat(t.attr("y"));const o=a.clientX;const r=a.clientY;const s=c(document.body);s.on("mousemove",(a=>{t.attr("x",n+a.clientX-o).attr("y",l+a.clientY-r);e.attr("x",n+a.clientX-o).attr("y",l+a.clientY-r)})).on("mouseup",(t=>{s.on("mousemove",null).on("mouseup",null)}))}function L(t,e,a,l){if(e.tracks){if(!t.ma_label){const o=n({x:a+20,y:l-50});o.header.text(t.gene);P(e,t.gene,o.body)}}A(t,e)}function P(t,e,a){fetch(new Request(t.hostURL+"/genelookup",{method:"POST",body:JSON.stringify({deep:1,input:e,genome:t.genome.name,jwt:t.jwt})})).then((t=>t.json())).then((n=>{if(n.error)throw{message:n.error};if(!n.gmlst||n.gmlst.length==0)throw{message:"No genes can be found for "+e};const l=new Map;for(const t of n.gmlst){if(!l.has(t.chr)){l.set(t.chr,{chr:t.chr,start:t.start,stop:t.stop})}l.get(t.chr).start=Math.min(t.start,l.get(t.chr).start);l.get(t.chr).stop=Math.max(t.stop,l.get(t.chr).stop)}const o=[...l][0][1];const r=[...t.tracks];p(t.genome,r);f({holder:a,hostURL:t.hostURL,jwt:t.jwt,genome:t.genome,chr:o.chr,start:o.start,stop:o.stop,tklst:r,nobox:true})})).catch((t=>{l(a,t.message);if(t.stack)console.log(t.stack)}))}export{x as mavbparseinput,b as mavbui};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{M as t,k as e,p as a,q as n,ah as r,a9 as o,ag as i,I as s,w as l}from"./app-a8c4854a.js";import{c as p}from"./axis-747c801e.js";const f=80;const c=5;async function d(t){window.obj=t;t.errdiv=t.div.append("div");try{g(t);await h(t)}catch(e){t.errdiv.text(e.message||e);if(e.stack)console.log(e.stack)}}function g(a){a.motifrowheight=16;a.gaincolor="red";a.losscolor="blue";a.flankspan=15;if(!a.fimo_thresh)a.fimo_thresh=.001;if(!a.minabslogp)a.minabslogp=1;a.tip=new t;const n=a.div.append("table").style("border-spacing","3px").style("border-collapse","separate").style("margin","10px");{const t=n.append("tr");t.append("td").text("Flanking sequence (#nt)");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.flankspan).on("keyup",(t=>{if(!e(t))return;const n=Number.parseInt(t.target.value);if(n<10){window.alert("Enter integer above 10");return}if(n==a.flankspan)return;a.flankspan=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}{const t=n.append("tr");t.append("td").text("P-value cutoff");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.fimo_thresh).on("keyup",(t=>{if(!e(t))return;const n=Number.parseFloat(t.target.value);if(n<=0){window.alert("Enter a p value between 0 to 1");return}if(n==a.fimo_thresh)return;a.fimo_thresh=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}{const t=n.append("tr");t.append("td").text("Minimum log10 p-value difference");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.minabslogp).on("keyup",(t=>{if(!e(t))return;const n=Number.parseFloat(t.target.value);if(n<=0){window.alert("Enter a number above 0");return}if(n==a.minabslogp)return;a.minabslogp=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}a.wait=a.div.append("div");a.svg=a.div.append("svg");a.dynamic_g=a.svg.append("g");a.legend={};a.legend.logpvaluediv=a.div.append("div");m(a)}function m(t){if(!t.factor_profiles)return;if(!Array.isArray(t.factor_profiles))throw"factor_profiles is not array";for(const e of t.factor_profiles){if(!e.name)throw"name missing for a profile";if(!e.leftpad)e.leftpad=20;if(!e.width)e.width=300;e.headerg=t.svg.append("g");e.textlabel=e.headerg.append("text").text(e.name).attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30);if(e.isgenevalue){e.color="green";e.axisg=e.headerg.append("g");continue}if(e.isgenevalueonesample){if(!e.samplename)throw"samplename missing for isgenevalueonesample";e.barcolor="#62945B";e.axisg=e.headerg.append("g");continue}throw"unknown profile type"}}function h(t){a(t.wait.text("Loading..."));t.dynamic_g.selectAll("*").remove();const e={genome:t.genome.name,m:t.m,fimo_thresh:t.fimo_thresh,flankspan:t.flankspan,minabslogp:t.minabslogp};return n("fimo",e).then((e=>{if(e.error)throw"Error: cannot do motif finding: "+e.error;if(t.callback_once){t.callback_once();delete t.callback_once}if(!e.items||e.items.length==0)throw"Found no motif change due to this mutation";t.wait.style("display","none");for(const t of e.items){if(t.attr){t.gene=t.attr["Transcription factor"]}else{t.gene=t.name}}return u(e,t)})).catch((e=>{t.wait.style("display","block").text(e.message||e);if(e.stack)console.log(e.stack)}))}async function u(t,e){x(t,e);if(e.factor_profiles){await b(t,e);let a=Number.parseInt(e.svg.attr("width"));for(const n of e.factor_profiles){n.headerg.attr("transform","translate("+(a+n.leftpad)+","+f+")");n.motifs=[];for(const e of t.items){const t=e.layer1_g.append("g").attr("transform","translate("+(a+n.leftpad)+",0)");n.motifs.push({motif:e,g:t,message:t.append("text").text("Loading...").attr("dominant-baseline","central").attr("fill","#ccc")})}a+=n.leftpad+n.width;e.svg.attr("width",a+5);await _(e,n);for(const e of t.items){e.bgbox.attr("width",a);e.coverbox.attr("width",a)}}}}function x(t,e){const a=14;const n=a*t.refseq.length;{const n=(e.m.pos-t.refstart+.5)*a;const r=e.dynamic_g.append("g").attr("transform","translate("+n+","+f+")");r.append("rect").attr("x",-a/2).attr("y",-10).attr("width",a).attr("height",10).attr("fill","#666");r.append("text").attr("y",-15).attr("text-anchor","middle").text(e.m.chr+":"+e.m.pos+" "+e.m.ref+">"+e.m.alt)}let o=f+c;const i=1;const s=e.dynamic_g.append("g").attr("transform","translate(0,"+o+")");for(const[o,l]of t.items.entries()){l.g=s.append("g").attr("transform","translate(0,"+(e.motifrowheight*(o+.5)+i*o)+")");l.layer1_g=l.g.append("g");l.layer2_g=l.g.append("g");l.bgbox=l.layer1_g.append("rect").attr("y",-e.motifrowheight/2).attr("width",n).attr("height",e.motifrowheight).attr("fill","white");const p=(l.start-t.refstart)*a;const f=(Math.min(l.stop,t.refstop)-l.start)*a;l.layer1_g.append("rect").attr("x",p).attr("y",-e.motifrowheight/2).attr("width",f).attr("height",e.motifrowheight).attr("fill",l.gain?e.gaincolor:e.losscolor).attr("fill-opacity",l.logpvaluediff/(l.gain?t.valuemax:t.valuemin));let c;if(l.strand=="+"){c="> "+l.name+" >"}else{c="< "+l.name+" <"}l.layer1_g.append("text").text(c).attr("x",p+f/2).attr("dominant-baseline","central").attr("text-anchor","middle").attr("stroke","white").attr("stroke-width",3).attr("font-size",e.motifrowheight-3).attr("font-family",r).style("white-space","pre");l.layer1_g.append("text").text(c).attr("x",p+f/2).attr("dominant-baseline","central").attr("text-anchor","middle").attr("font-size",e.motifrowheight-3).attr("font-family",r).style("white-space","pre");l.coverbox=l.layer2_g.append("rect").attr("y",-e.motifrowheight/2).attr("width",n).attr("height",e.motifrowheight).attr("fill","white").attr("fill-opacity",0).on("mouseover",(t=>{l.bgbox.attr("fill","#f9fabd");y(l,e,t)})).on("mouseout",(()=>{l.bgbox.attr("fill","white");e.tip.hide()}))}o+=(i+e.motifrowheight)*t.items.length+20;v(t,e);e.svg.attr("width",n).attr("height",o)}function y(t,e,a){e.tip.clear();if(t.attr){e.tip.d.append("div").text("MOTIF").style("font-weight","bold");const a=[{k:"P-values",v:w(t,e)},{k:"Strand",v:t.strand}];o(e.tip.d,a);e.tip.d.append("div").text("FACTOR").style("font-weight","bold");const n=[];for(const e in t.attr){n.push({k:e,v:t.attr[e]})}o(e.tip.d,n)}else{const a=[{k:"TF",v:t.name},{k:"P-values",v:w(t,e)},{k:"Strand",v:t.strand}];o(e.tip.d,a)}e.tip.show(a.clientX,a.clientY)}function w(t,e){return(t.pvalue_ref==undefined?'<span style="opacity:.5;padding:2px"><span style="font-size:.7em">REF</span> not found</span>':'<span style="background-color:'+e.losscolor+';padding:2px;color:white;"><span style="font-size:.7em">REF</span> '+t.pvalue_ref+"</span>")+"<br>"+(t.pvalue_alt==undefined?'<span style="opacity:.5;padding:2px"><span style="font-size:.7em">ALT</span> not found</span>':'<span style="background-color:'+e.gaincolor+';padding:2px;color:white;"><span style="font-size:.7em">ALT</span> '+t.pvalue_alt+"</span>")}function v(t,e){e.legend.logpvaluediv.selectAll("*").remove();const a=50,n=4,o=12,l=55,f=20;e.legend.logpvaluediv.append("span").text("Log10 p-value difference");const c=e.legend.logpvaluediv.append("svg").attr("width",(a+l)*2).attr("height",o+n+f);const d=c.append("g").attr("transform","translate("+a+","+(o+n)+")");i({axis:d.call(p().scale(s().domain([t.valuemin,0,t.valuemax]).range([0,l,l*2])).tickValues([t.valuemin,0,t.valuemax]).tickSize(n))});const g=Math.random().toString();const m=Math.random().toString();const h=c.append("defs");{const t=h.append("linearGradient").attr("id",m);t.append("stop").attr("offset","0%").attr("stop-color",e.losscolor);t.append("stop").attr("offset","100%").attr("stop-color","white")}{const t=h.append("linearGradient").attr("id",g);t.append("stop").attr("offset","0%").attr("stop-color","white");t.append("stop").attr("offset","100%").attr("stop-color",e.gaincolor)}c.append("rect").attr("x",a).attr("y",o+n).attr("width",l).attr("height",f).attr("fill","url(#"+m+")");c.append("rect").attr("x",a+l).attr("y",o+n).attr("width",l).attr("height",f).attr("fill","url(#"+g+")");c.append("text").attr("x",a-5).attr("y",o+n+f/2).attr("font-family",r).attr("font-size",o).attr("text-anchor","end").attr("dominant-baseline","central").attr("fill","black").text("Loss");c.append("text").attr("x",a+l*2+5).attr("y",o+n+f/2).attr("font-family",r).attr("font-size",o).attr("dominant-baseline","central").attr("fill","black").text("Gain")}async function b(t,e){e.gene2position={};const a=new Set;for(const e of t.items){a.add(e.gene)}for(const t of a){const a=await k(t,e);if(a){e.gene2position[t]=a}}}function k(t,e){return n("genelookup",{genome:e.genome.name,input:t,deep:1}).then((t=>{if(!t.gmlst)return null;const e=l(t.gmlst);return e[0]}))}function _(t,e){if(e.isgenevalue){return M(t,e)}if(e.isgenevalueonesample){return E(t,e)}throw"unknown profile type"}async function E(t,e){const r={genome:t.genome.name,genes:[],sample:e.samplename};if(e.mdslabel){r.dslabel=e.mdslabel;r.querykey=e.querykey;if(e.samplegroup_attrlst){r.getgroup=e.samplegroup_attrlst}}else{r.iscustom=1;r.file=e.file;r.url=e.url;r.indexURL=e.indexURL}for(const e in t.gene2position){const a=t.gene2position[e];r.genes.push({gene:e,chr:a.chr,start:a.start,stop:a.stop})}return n("mdsgenevalueonesample",r).then((a=>{if(a.error)throw a.error;for(const t of e.motifs){t.message.text("No data")}if(a.nodata)return;if(!a.result)throw"error";let n=0,r=0;for(const t in a.result){n=Math.min(n,a.result[t]);r=Math.max(r,a.result[t])}const o=s().domain([n,r]).range([0,e.width]);i({axis:e.axisg.call(p().scale(o).ticks(4)),showline:1});for(const n of e.motifs){const r=a.result[n.motif.gene];if(Number.isFinite(r)){n.message.text("");n.g.append("rect").attr("y",-t.motifrowheight/2).attr("width",Math.max(1,o(r))).attr("height",t.motifrowheight).attr("shape-rendering","crispEdges").attr("fill",e.barcolor)}}e.textlabel.attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30)})).catch((e=>{if(e.stack)console.log(e.stack);a(t.wait.text(e.message||e))}))}async function M(t,e){e.gene2result=new Map;for(const a in t.gene2position){const n=await L(t,e,a);if(n){z(t,e,a,n);e.gene2result.set(a,n);F(t,e)}}N(t,e)}function z(t,e,a,n){if(n.nodata)return;for(const t of e.motifs){if(t.motif.gene!=a)continue;t.boxplot={out:[]};if(n.w1!=undefined){t.boxplot.hline=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linew1=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linew2=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.box=t.g.append("rect").attr("fill","white").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linep50=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges")}if(n.out){for(const a of n.out){const n=t.g.append("circle").attr("stroke",e.color).attr("fill","white").attr("fill-opacity",0);t.boxplot.out.push({value:a.value,circle:n})}}}}function F(t,e){let a=0,n=0;for(const t of e.gene2result.values()){a=Math.min(a,t.min);n=Math.max(n,t.max)}const r=s().domain([a,n]).range([0,e.width]);const o=t.motifrowheight-2;for(const[t,a]of e.gene2result){for(const n of e.motifs){if(n.motif.gene!=t)continue;const e=n.boxplot;if(!e)continue;if(e.hline){const t=r(a.w1);const n=r(a.w2);const i=r(a.p25);const s=r(a.p50);const l=r(a.p75);e.hline.transition().attr("x1",t).attr("x2",n);e.linew1.transition().attr("x1",t).attr("x2",t).attr("y1",-o/2).attr("y2",o/2);e.linew2.transition().attr("x1",n).attr("x2",n).attr("y1",-o/2).attr("y2",o/2);e.box.transition().attr("x",i).attr("y",-o/2).attr("width",l-i).attr("height",o);e.linep50.transition().attr("x1",s).attr("x2",s).attr("y1",-o/2).attr("y2",o/2)}for(const t of e.out){t.circle.transition().attr("cx",r(t.value)).attr("r",o/3)}}}i({axis:e.axisg.transition().call(p().scale(r).ticks(4)),showline:1})}function L(t,e,a){const r=t.gene2position[a];const o={genome:t.genome.name,gene:a,chr:r.chr,start:r.start,stop:r.stop,getgroup2boxplot:1};if(e.mdslabel){o.dslabel=e.mdslabel;o.querykey=e.querykey;if(e.samplegroup_attrlst){o.getgroup=e.samplegroup_attrlst}}else{o.iscustom=1;o.file=e.file;o.url=e.url;o.indexURL=e.indexURL}return n("mdsgeneboxplot",o).then((t=>{if(t.error)throw"Error: "+t.error;if(t.nodata)throw"No data";for(const t of e.motifs){if(t.motif.gene==a){t.message.text("")}}return t})).catch((t=>{if(t.stack)console.log(t.stack);for(const n of e.motifs){if(n.motif.gene==a){n.message.text(t.message||t)}}}))}function N(t,e){let a=0;for(const t of e.gene2result.values()){a=Math.max(a,t.n)}e.textlabel.text(e.name+" (n="+a+")").attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30)}export{d as init};
|
|
1
|
+
import{M as t,k as e,p as a,q as n,ah as r,a9 as o,ag as i,I as s,w as l}from"./app-b369b169.js";import{c as p}from"./axis-747c801e.js";const f=80;const c=5;async function d(t){window.obj=t;t.errdiv=t.div.append("div");try{g(t);await h(t)}catch(e){t.errdiv.text(e.message||e);if(e.stack)console.log(e.stack)}}function g(a){a.motifrowheight=16;a.gaincolor="red";a.losscolor="blue";a.flankspan=15;if(!a.fimo_thresh)a.fimo_thresh=.001;if(!a.minabslogp)a.minabslogp=1;a.tip=new t;const n=a.div.append("table").style("border-spacing","3px").style("border-collapse","separate").style("margin","10px");{const t=n.append("tr");t.append("td").text("Flanking sequence (#nt)");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.flankspan).on("keyup",(t=>{if(!e(t))return;const n=Number.parseInt(t.target.value);if(n<10){window.alert("Enter integer above 10");return}if(n==a.flankspan)return;a.flankspan=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}{const t=n.append("tr");t.append("td").text("P-value cutoff");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.fimo_thresh).on("keyup",(t=>{if(!e(t))return;const n=Number.parseFloat(t.target.value);if(n<=0){window.alert("Enter a p value between 0 to 1");return}if(n==a.fimo_thresh)return;a.fimo_thresh=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}{const t=n.append("tr");t.append("td").text("Minimum log10 p-value difference");const r=t.append("td");r.append("input").attr("type","number").style("margin","0px 10px").style("width","100px").property("value",a.minabslogp).on("keyup",(t=>{if(!e(t))return;const n=Number.parseFloat(t.target.value);if(n<=0){window.alert("Enter a number above 0");return}if(n==a.minabslogp)return;a.minabslogp=n;h(a)}));r.append("span").style("font-size","0.7em").style("opacity",.5).text("Press ENTER to update")}a.wait=a.div.append("div");a.svg=a.div.append("svg");a.dynamic_g=a.svg.append("g");a.legend={};a.legend.logpvaluediv=a.div.append("div");m(a)}function m(t){if(!t.factor_profiles)return;if(!Array.isArray(t.factor_profiles))throw"factor_profiles is not array";for(const e of t.factor_profiles){if(!e.name)throw"name missing for a profile";if(!e.leftpad)e.leftpad=20;if(!e.width)e.width=300;e.headerg=t.svg.append("g");e.textlabel=e.headerg.append("text").text(e.name).attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30);if(e.isgenevalue){e.color="green";e.axisg=e.headerg.append("g");continue}if(e.isgenevalueonesample){if(!e.samplename)throw"samplename missing for isgenevalueonesample";e.barcolor="#62945B";e.axisg=e.headerg.append("g");continue}throw"unknown profile type"}}function h(t){a(t.wait.text("Loading..."));t.dynamic_g.selectAll("*").remove();const e={genome:t.genome.name,m:t.m,fimo_thresh:t.fimo_thresh,flankspan:t.flankspan,minabslogp:t.minabslogp};return n("fimo",e).then((e=>{if(e.error)throw"Error: cannot do motif finding: "+e.error;if(t.callback_once){t.callback_once();delete t.callback_once}if(!e.items||e.items.length==0)throw"Found no motif change due to this mutation";t.wait.style("display","none");for(const t of e.items){if(t.attr){t.gene=t.attr["Transcription factor"]}else{t.gene=t.name}}return u(e,t)})).catch((e=>{t.wait.style("display","block").text(e.message||e);if(e.stack)console.log(e.stack)}))}async function u(t,e){x(t,e);if(e.factor_profiles){await v(t,e);let a=Number.parseInt(e.svg.attr("width"));for(const n of e.factor_profiles){n.headerg.attr("transform","translate("+(a+n.leftpad)+","+f+")");n.motifs=[];for(const e of t.items){const t=e.layer1_g.append("g").attr("transform","translate("+(a+n.leftpad)+",0)");n.motifs.push({motif:e,g:t,message:t.append("text").text("Loading...").attr("dominant-baseline","central").attr("fill","#ccc")})}a+=n.leftpad+n.width;e.svg.attr("width",a+5);await _(e,n);for(const e of t.items){e.bgbox.attr("width",a);e.coverbox.attr("width",a)}}}}function x(t,e){const a=14;const n=a*t.refseq.length;{const n=(e.m.pos-t.refstart+.5)*a;const r=e.dynamic_g.append("g").attr("transform","translate("+n+","+f+")");r.append("rect").attr("x",-a/2).attr("y",-10).attr("width",a).attr("height",10).attr("fill","#666");r.append("text").attr("y",-15).attr("text-anchor","middle").text(e.m.chr+":"+e.m.pos+" "+e.m.ref+">"+e.m.alt)}let o=f+c;const i=1;const s=e.dynamic_g.append("g").attr("transform","translate(0,"+o+")");for(const[o,l]of t.items.entries()){l.g=s.append("g").attr("transform","translate(0,"+(e.motifrowheight*(o+.5)+i*o)+")");l.layer1_g=l.g.append("g");l.layer2_g=l.g.append("g");l.bgbox=l.layer1_g.append("rect").attr("y",-e.motifrowheight/2).attr("width",n).attr("height",e.motifrowheight).attr("fill","white");const p=(l.start-t.refstart)*a;const f=(Math.min(l.stop,t.refstop)-l.start)*a;l.layer1_g.append("rect").attr("x",p).attr("y",-e.motifrowheight/2).attr("width",f).attr("height",e.motifrowheight).attr("fill",l.gain?e.gaincolor:e.losscolor).attr("fill-opacity",l.logpvaluediff/(l.gain?t.valuemax:t.valuemin));let c;if(l.strand=="+"){c="> "+l.name+" >"}else{c="< "+l.name+" <"}l.layer1_g.append("text").text(c).attr("x",p+f/2).attr("dominant-baseline","central").attr("text-anchor","middle").attr("stroke","white").attr("stroke-width",3).attr("font-size",e.motifrowheight-3).attr("font-family",r).style("white-space","pre");l.layer1_g.append("text").text(c).attr("x",p+f/2).attr("dominant-baseline","central").attr("text-anchor","middle").attr("font-size",e.motifrowheight-3).attr("font-family",r).style("white-space","pre");l.coverbox=l.layer2_g.append("rect").attr("y",-e.motifrowheight/2).attr("width",n).attr("height",e.motifrowheight).attr("fill","white").attr("fill-opacity",0).on("mouseover",(t=>{l.bgbox.attr("fill","#f9fabd");y(l,e,t)})).on("mouseout",(()=>{l.bgbox.attr("fill","white");e.tip.hide()}))}o+=(i+e.motifrowheight)*t.items.length+20;b(t,e);e.svg.attr("width",n).attr("height",o)}function y(t,e,a){e.tip.clear();if(t.attr){e.tip.d.append("div").text("MOTIF").style("font-weight","bold");const a=[{k:"P-values",v:w(t,e)},{k:"Strand",v:t.strand}];o(e.tip.d,a);e.tip.d.append("div").text("FACTOR").style("font-weight","bold");const n=[];for(const e in t.attr){n.push({k:e,v:t.attr[e]})}o(e.tip.d,n)}else{const a=[{k:"TF",v:t.name},{k:"P-values",v:w(t,e)},{k:"Strand",v:t.strand}];o(e.tip.d,a)}e.tip.show(a.clientX,a.clientY)}function w(t,e){return(t.pvalue_ref==undefined?'<span style="opacity:.5;padding:2px"><span style="font-size:.7em">REF</span> not found</span>':'<span style="background-color:'+e.losscolor+';padding:2px;color:white;"><span style="font-size:.7em">REF</span> '+t.pvalue_ref+"</span>")+"<br>"+(t.pvalue_alt==undefined?'<span style="opacity:.5;padding:2px"><span style="font-size:.7em">ALT</span> not found</span>':'<span style="background-color:'+e.gaincolor+';padding:2px;color:white;"><span style="font-size:.7em">ALT</span> '+t.pvalue_alt+"</span>")}function b(t,e){e.legend.logpvaluediv.selectAll("*").remove();const a=50,n=4,o=12,l=55,f=20;e.legend.logpvaluediv.append("span").text("Log10 p-value difference");const c=e.legend.logpvaluediv.append("svg").attr("width",(a+l)*2).attr("height",o+n+f);const d=c.append("g").attr("transform","translate("+a+","+(o+n)+")");i({axis:d.call(p().scale(s().domain([t.valuemin,0,t.valuemax]).range([0,l,l*2])).tickValues([t.valuemin,0,t.valuemax]).tickSize(n))});const g=Math.random().toString();const m=Math.random().toString();const h=c.append("defs");{const t=h.append("linearGradient").attr("id",m);t.append("stop").attr("offset","0%").attr("stop-color",e.losscolor);t.append("stop").attr("offset","100%").attr("stop-color","white")}{const t=h.append("linearGradient").attr("id",g);t.append("stop").attr("offset","0%").attr("stop-color","white");t.append("stop").attr("offset","100%").attr("stop-color",e.gaincolor)}c.append("rect").attr("x",a).attr("y",o+n).attr("width",l).attr("height",f).attr("fill","url(#"+m+")");c.append("rect").attr("x",a+l).attr("y",o+n).attr("width",l).attr("height",f).attr("fill","url(#"+g+")");c.append("text").attr("x",a-5).attr("y",o+n+f/2).attr("font-family",r).attr("font-size",o).attr("text-anchor","end").attr("dominant-baseline","central").attr("fill","black").text("Loss");c.append("text").attr("x",a+l*2+5).attr("y",o+n+f/2).attr("font-family",r).attr("font-size",o).attr("dominant-baseline","central").attr("fill","black").text("Gain")}async function v(t,e){e.gene2position={};const a=new Set;for(const e of t.items){a.add(e.gene)}for(const t of a){const a=await k(t,e);if(a){e.gene2position[t]=a}}}function k(t,e){return n("genelookup",{genome:e.genome.name,input:t,deep:1}).then((t=>{if(!t.gmlst)return null;const e=l(t.gmlst);return e[0]}))}function _(t,e){if(e.isgenevalue){return M(t,e)}if(e.isgenevalueonesample){return E(t,e)}throw"unknown profile type"}async function E(t,e){const r={genome:t.genome.name,genes:[],sample:e.samplename};if(e.mdslabel){r.dslabel=e.mdslabel;r.querykey=e.querykey;if(e.samplegroup_attrlst){r.getgroup=e.samplegroup_attrlst}}else{r.iscustom=1;r.file=e.file;r.url=e.url;r.indexURL=e.indexURL}for(const e in t.gene2position){const a=t.gene2position[e];r.genes.push({gene:e,chr:a.chr,start:a.start,stop:a.stop})}return n("mdsgenevalueonesample",r).then((a=>{if(a.error)throw a.error;for(const t of e.motifs){t.message.text("No data")}if(a.nodata)return;if(!a.result)throw"error";let n=0,r=0;for(const t in a.result){n=Math.min(n,a.result[t]);r=Math.max(r,a.result[t])}const o=s().domain([n,r]).range([0,e.width]);i({axis:e.axisg.call(p().scale(o).ticks(4)),showline:1});for(const n of e.motifs){const r=a.result[n.motif.gene];if(Number.isFinite(r)){n.message.text("");n.g.append("rect").attr("y",-t.motifrowheight/2).attr("width",Math.max(1,o(r))).attr("height",t.motifrowheight).attr("shape-rendering","crispEdges").attr("fill",e.barcolor)}}e.textlabel.attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30)})).catch((e=>{if(e.stack)console.log(e.stack);a(t.wait.text(e.message||e))}))}async function M(t,e){e.gene2result=new Map;for(const a in t.gene2position){const n=await L(t,e,a);if(n){z(t,e,a,n);e.gene2result.set(a,n);F(t,e)}}N(t,e)}function z(t,e,a,n){if(n.nodata)return;for(const t of e.motifs){if(t.motif.gene!=a)continue;t.boxplot={out:[]};if(n.w1!=undefined){t.boxplot.hline=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linew1=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linew2=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.box=t.g.append("rect").attr("fill","white").attr("stroke",e.color).attr("shape-rendering","crispEdges");t.boxplot.linep50=t.g.append("line").attr("stroke",e.color).attr("shape-rendering","crispEdges")}if(n.out){for(const a of n.out){const n=t.g.append("circle").attr("stroke",e.color).attr("fill","white").attr("fill-opacity",0);t.boxplot.out.push({value:a.value,circle:n})}}}}function F(t,e){let a=0,n=0;for(const t of e.gene2result.values()){a=Math.min(a,t.min);n=Math.max(n,t.max)}const r=s().domain([a,n]).range([0,e.width]);const o=t.motifrowheight-2;for(const[t,a]of e.gene2result){for(const n of e.motifs){if(n.motif.gene!=t)continue;const e=n.boxplot;if(!e)continue;if(e.hline){const t=r(a.w1);const n=r(a.w2);const i=r(a.p25);const s=r(a.p50);const l=r(a.p75);e.hline.transition().attr("x1",t).attr("x2",n);e.linew1.transition().attr("x1",t).attr("x2",t).attr("y1",-o/2).attr("y2",o/2);e.linew2.transition().attr("x1",n).attr("x2",n).attr("y1",-o/2).attr("y2",o/2);e.box.transition().attr("x",i).attr("y",-o/2).attr("width",l-i).attr("height",o);e.linep50.transition().attr("x1",s).attr("x2",s).attr("y1",-o/2).attr("y2",o/2)}for(const t of e.out){t.circle.transition().attr("cx",r(t.value)).attr("r",o/3)}}}i({axis:e.axisg.transition().call(p().scale(r).ticks(4)),showline:1})}function L(t,e,a){const r=t.gene2position[a];const o={genome:t.genome.name,gene:a,chr:r.chr,start:r.start,stop:r.stop,getgroup2boxplot:1};if(e.mdslabel){o.dslabel=e.mdslabel;o.querykey=e.querykey;if(e.samplegroup_attrlst){o.getgroup=e.samplegroup_attrlst}}else{o.iscustom=1;o.file=e.file;o.url=e.url;o.indexURL=e.indexURL}return n("mdsgeneboxplot",o).then((t=>{if(t.error)throw"Error: "+t.error;if(t.nodata)throw"No data";for(const t of e.motifs){if(t.motif.gene==a){t.message.text("")}}return t})).catch((t=>{if(t.stack)console.log(t.stack);for(const n of e.motifs){if(n.motif.gene==a){n.message.text(t.message||t)}}}))}function N(t,e){let a=0;for(const t of e.gene2result.values()){a=Math.max(a,t.n)}e.textlabel.text(e.name+" (n="+a+")").attr("x",e.width/2).attr("text-anchor","middle").attr("y",-30)}export{d as init};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{d as e,M as t,j as s,a7 as a,a8 as l,I as o,a9 as n,k as i,N as r,Z as c,v as p,aa as d,q as m,ab as f,p as u,ac as y,ad as b,f as v}from"./app-b369b169.js";import{s as x}from"./legacy-d3-polyfill-bdb2d792.js";import{b as g}from"./block.lazyload-87b12654.js";import{d as h}from"./lasso-f767f634.js";import{d as _}from"./zoom-25dce8b9.js";import{f as k}from"./FilterStateless-54c0b763.js";import{e as w}from"./FilterRxComp-701a1480.js";import"./termsetting-33ea66f1.js";import{g as O}from"./filter-b3d3964e.js";import"./drag-7b30ba17.js";import"./nodrag-16ad4b03.js";import"./pointer-c7475677.js";import"./table-29d5a973.js";import"./tslib.es6-c3c2d88f.js";import"./partjson.esm-b3f1fc21.js";import"./termdb.bins-8b656cc3.js";import"path";function j(e){const t={waitTime:0,pad:5,nameKey:"",steps:[{type:"restyle",applyTo:"all",css:{selector:"text",key:"font-size",value:"12px"}},{type:"move",repeat:2,pad:0,css:{selector:"text"},boxSorter:(e,t)=>{if(e.x1>t.x1)return-1;if(t.x1>e.x1)return 1;if(e.y1>t.y1)return-1;if(t.y1>e.y1)return 1;return 0}}]};return Object.assign(t,e)}async function z(e,t={}){if(!e||!e.size())return;const s=j(t);if(!s.steps||!s.steps.length)return;if(!s.svg)s.svg=e.node().closest("svg");await R(s.waitTime);s.svgBox=s.svg.getBoundingClientRect();const a=S(e,s);const l=A(a);window.boxes=a;if(l){const t=s.steps.shift();const o=t.applyTo=="all"?a:t.type=="move"?a.filter((e=>e.collisions.length)):a.filter((e=>e.collisions.length===l));if(o.length){if(t.boxSorter)o.sort(t.boxSorter);for(const e of o){const l=S(e.label,s)[0];Object.assign(e,l);F(e,a.filter((t=>t!=e)));await C[t.type](e,t,a,s)}}if(typeof t.repeat=="number"&&t.repeat>0){t.repeat+=-1;s.steps.unshift(t)}if(s.steps.length)setTimeout((()=>z(e,s)),0);else a.forEach(B)}else a.forEach(B)}function S(t,s){const a=[];t.each((function(t){const l=this;const o=l.getBoundingClientRect();const n={elem:l,label:e(l),x1:o.x-s.svgBox.x,x2:o.x-s.svgBox.x+o.width,y1:o.y-s.svgBox.y,y2:o.y-s.svgBox.y+o.height,width:o.width,height:o.height};n.maxFree={n:Math.max(n.y1,0),s:Math.max(s.svgBox.y+s.svgBox.height-n.y2,0),e:Math.max(s.svgBox.x+s.svgBox.width-n.x2,0),w:Math.max(n.x1,0)};n.corners={};n.overlapSum=0;n.collisions=[];n.maxOverlaps={};if(s.nameKey)n.name=t[s.nameKey];N(n,s.svgBox);a.push(n)}));return a}function A(e){let t=0;for(const s of e){const a=F(s,e.filter((e=>e!=s)));if(t===0||a>0&&a<t){t=a}}e.sort(M);return t}function M(e,t){return e.collisions.length-t.collisions.length}function F(e,t){const s=e.x1,a=e.x2;const l=e.y1,o=e.y2;for(const n of t){if(n===e)continue;const t={};if(n.x2<s){t.w=s-n.x2}else if(n.x1>a){t.e=n.x1-a}if(n.y2<l){t.n=l-n.y2}else if(n.y1>o){t.s=n.y1-o}const i={};if(Object.keys(t).length){if("n"in t&&t.n<e.maxFree.n)e.maxFree.n=t.n;if("s"in t&&t.s<e.maxFree.s)e.maxFree.s=t.s;if("e"in t&&t.e<e.maxFree.e)e.maxFree.e=t.e;if("w"in t&&t.w<e.maxFree.w)e.maxFree.w=t.w}else{if(n.x1<=s&&a<=n.x2){if(n.x1<=s&&s<=n.x2){const t=n.x2-s;if(!("x"in e.maxOverlaps)||e.maxOverlaps.x.val<t)e.maxOverlaps.x={val:t,dir:"w"};if(n.y1<=l&&l<=n.y2){const s=n.y2-l;i.nw=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"n"}}if(n.y1<=o&&o<=n.y2){const s=o-n.y1;i.sw=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"s"}}}if(n.x1<=a&&a<=n.x2){const t=a-n.x1;if(!("x"in e.maxOverlaps)||e.maxOverlaps.x.val<t)e.maxOverlaps.x={val:t,dir:"e"};if(n.y1<=l&&l<=n.y2){const s=n.y2-l;i.ne=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"n"}}if(n.y1<=o&&o<=n.y2){const s=o-n.y1;i.se=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"s"}}}}else{if(s<=n.x1&&n.x1<=a){const t=a-n.x1;if(!("x"in e.maxOverlaps)||e.maxOverlaps.x.val<t)e.maxOverlaps.x={val:t,dir:"e"};if(l<=n.y1&&n.y1<=o){const s=o-n.y1;i.se=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"s"}}if(l<=n.y2&&n.y2<=o){const s=n.y2-l;i.ne=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"n"}}}if(s<=n.x2&&n.x2<=a){const t=n.x2-s;if(!("x"in e.maxOverlaps)||e.maxOverlaps.x.val<t)e.maxOverlaps.x={val:t,dir:"w"};if(l<=n.y1&&n.y1<=o){const s=o-n.y1;i.sw=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"s"}}if(l<=n.y2&&n.y2<=o){const s=n.y2-l;i.nw=t*s;if(!("y"in e.maxOverlaps)||e.maxOverlaps.y.val<s)e.maxOverlaps.y={val:s,dir:"n"}}}}}const r=Object.keys(i);if(r.length){e.collisions.push({box:n.name,corners:r});for(const t of r){if(!e.corners[t])e.corners[t]={against:[],sum:0};e.corners[t].against.push(n.name);e.corners[t].sum+=i[t];e.overlapSum+=i[t]}}}return e.collisions.length}function N(e,t){const s=e.x1,a=e.x2;const l=e.y1,o=e.y2;const n=[];if(s<0){e.maxOverlaps.x={val:Math.abs(s),dir:"w"};n.push("w");e.corners.w={against:[],sum:Math.abs(s)*e.height};e.overlapSum+=e.corners.w.sum}const i=a-t.width;if(i>0&&(!e.maxOverlaps.x||e.maxOverlaps.x.val<i)){e.maxOverlaps.x={val:i,dir:"e"};n.push("e");e.corners.e={against:["svgbox"],sum:i*e.height};e.overlapSum+=e.corners.e.sum}if(l<0){e.maxOverlaps.y={val:Math.abs(l),dir:"n"};n.push("n");e.corners.n={against:["svgbox"],sum:Math.abs(l)};e.overlapSum+=e.corners.n.sum}const r=o-t.height;if(r>0&&(!e.maxOverlaps.y||e.maxOverlaps.y.val<r)){e.maxOverlaps.y={val:r,dir:"s"};n.push("s");e.corners.s={against:["svgbox"],sum:r*e.height};e.overlapSum+=e.corners.s.sum}if(n.length)e.collisions.push({box:"svg",corners:n})}async function E(t,s,a,l){const o=new Map;t.label.selectAll(s.css.selector).each((function(t){const a=e(this);o.set(this,a.attr(s.css.key));a.attr(s.css.key,s.css.value)}));await R(l.waitTime);const n=S(t.label,l)[0];a.indexOf(t);F(n,a.filter((e=>e!=t)));if(s.applyTo=="all"){Object.assign(t,n)}else{if(n.overlapSum>=t.overlapSum){t.label.selectAll(s.css.selector).each((function(t){e(this).attr(s.css.key,o.get(this))}))}else{Object.assign(t,n)}}}async function T(t,s,a,l){const o=Object.keys(t.maxFree).filter((e=>t.maxFree[e]>0));if(!o.length)return;const n=new Map;if(t.maxOverlaps.y&&t.maxOverlaps.y.val>0){if(t.maxOverlaps.y.dir=="s"&&o.includes("n")){t.label.selectAll(s.css.selector).each((function(a){const l=e(this);n.set(this,l.attr("y")||0);l.attr("y",Math.max(-t.maxFree.n,-t.maxOverlaps.y.val)-s.pad)}))}if(t.maxOverlaps.y.dir=="n"&&o.includes("s")){t.label.selectAll(s.css.selector).each((function(a){const l=e(this);n.set(this,l.attr("y")||0);l.attr("y",Math.min(t.maxFree.s,t.maxOverlaps.y.val)+s.pad)}))}}if(n.size){await R(l.waitTime);const o=S(t.label,l)[0];F(o,a.filter((e=>e!=t)));if(o.overlapSum>=t.overlapSum){t.label.selectAll(s.css.selector).each((function(t){e(this).attr("y",n.get(this))}))}else{Object.assign(t,o);if(!t.collisions.length)return}}if(t.maxOverlaps.x&&t.maxOverlaps.x.val>0){if(t.maxOverlaps.x.dir=="e"&&o.includes("w")){t.label.selectAll(s.css.selector).each((function(a){const l=e(this);n.set(this,l.attr("x")||0);l.attr("x",Math.max(-t.maxFree.w,-t.maxOverlaps.x.val)-s.pad)}))}if(t.maxOverlaps.x.dir=="w"&&o.includes("e")){t.label.selectAll(s.css.selector).each((function(a){const l=e(this);n.set(this,l.attr("x")||0);l.attr("x",Math.min(t.maxFree.e,t.maxOverlaps.x.val)+s.pad)}))}}if(!n.size)return;await R(l.waitTime);const i=S(t.label,l)[0];F(i,a.filter((e=>e!=t)));if(i.overlapSum>=t.overlapSum){t.label.selectAll(s.css.selector).each((function(t){e(this).attr("x",n.get(this))}))}else{Object.assign(t,i)}}const C={restyle:E,move:T};function B(e){return}function R(e){return new Promise((t=>setTimeout(t,e)))}const q=3;const L=.7;const I="black";async function X(e,a,l){if(l){window.obj=e}if(!e.lasso)e.lasso={postSelectMenuOptions:[{label:"List samples",callback:"listSamples"}]};e.menu=new t({padding:"2px"});e.menu2=new t({padding:"10px"});e.tip=new t({padding:"5px"});e.errordiv=a.append("div").style("margin","10px");e.sayerror=t=>{s(e.errordiv,typeof t=="string"?t:t.message);if(t.stack)console.log(t.stack)};const o=a.append("table").style("border-spacing","20px");const n=o.append("tr");const i=n.append("td").style("vertical-align","top");const r=n.append("td").style("vertical-align","top");{const d=r.append("div").style("margin-bottom","5px");d.append("input").attr("type","text").attr("placeholder","Search sample").style("width","200px").on("keyup",(t=>{const s=t.target.value;if(!s){e.dotselection.transition().attr("r",q);return}const a=s.toLowerCase();e.dotselection.filter((e=>m(e,a))).transition().attr("r",q*2);e.dotselection.filter((e=>!m(e,a))).transition().attr("r",1)}));function m(e,t){let s=false;let a=Object.values(e).filter((e=>e!=null&&typeof e!="number"));let l=a.filter((e=>typeof e!="object")).map((e=>e.toLowerCase()));l.forEach((e=>{if(e.toLowerCase().includes(t))return s=true}));if(!s){a.forEach((e=>{if(e&&typeof e=="object"){const a=Object.values(e).filter((e=>e!=null&&typeof e!="number")).map((e=>e.toLowerCase()));a.forEach((e=>{if(e.toLowerCase().includes(t))return s=true}))}}))}return s}}const c=r.append("div").style("overflow-x","hidden").style("overflow-y","auto").style("height","100vh");e.legendtable=c.append("table").style("border-spacing","5px");e.filterDiv=i.append("div").style("position","relative");const p=i.append("div").style("position","relative");e.scattersvg=p.append("svg");e.scattersvg_resizehandle=p.append("div");e.scattersvg_buttons=p.append("div");try{await Y(e);D(e);G(e);P(e)}catch(f){if(f.stack)console.log(f.stack);e.sayerror(f.message||f)}}async function Y(e){if(e.dslabel){const t=["genome="+e.genome.name,"dslabel="+e.dslabel];if(e.analysisdata){if(e.analysisdata.subset){if(!e.analysisdata.subset.key)throw".subset.key missing";if(!e.analysisdata.subset.value)throw".subset.value missing";t.push("subsetkey="+e.analysisdata.subset.key);t.push("subsetvalue="+e.analysisdata.subset.value)}}const s=await a("mdssamplescatterplot?"+t.join("&"));if(s.error)throw s.error;if(!s.dots)throw"server error";e.sample2dot=new Map;for(const t of s.dots){e.sample2dot.set(t.sample,t)}U(e,s);e.colorbyattributes=s.colorbyattributes;e.colorbygeneexpression=s.colorbygeneexpression;e.tracks=s.tracks;e.querykey=s.querykey;e.sample_attributes=e.mds.sampleAttribute.attributes;return}const t=e.analysisdata;if(e.disco||t.disco){const s=e.disco||t.disco;e.mds=e.genome.datasets[s.dslabel]}else if(e.mds){e.mds=e.genome.datasets[e.mds.dslabel]}if(!t)throw"both .analysisdata{} and .dslabel are missing";if(t.samples){if(!Array.isArray(t.samples))throw".analysisdata.samples is not array";e.dots=t.samples}else if(t.tabular_data){let s=t.tabular_data.split("\n");if(s.length<2)throw"at least 2 rows, header row + at least 1 sample data must be supplied";t.samples=[];const a=s.shift().split("\t");if(a.length<3)throw"at least 3 columns are required with X, Y and sample name";t.samplekey=a[2];let l=a.indexOf("x");if(l==-1)l=a.indexOf("X");if(l==-1)throw'"X" or "x" column missing from tabular data';let o=a.indexOf("y");if(o==-1)o=a.indexOf("Y");if(o==-1)throw'"Y" or "y" column missing from tabular data';for(const e of s){const s=e.split("\t");const n={};for(const[e,t]of s.entries()){if(e==l)n.x=Number.parseFloat(t);else if(e==o)n.y=Number.parseFloat(t);else n[a[e]]=t}t.samples.push(n)}e.dots=t.samples;if(t.sample_attributes==undefined){t.sample_attributes={};for(const[e,s]of a.entries()){if(e<=2)continue;t.sample_attributes[s]={label:s}}}if(!t.colorbyattributes&&a.length>3)t.colorbyattributes=[{key:a[3]}]}else{throw"unknown data encoding in .analysisdata{}"}e.sample2dot=new Map;for(const s of e.dots){if(!Number.isFinite(s.x)||!Number.isFinite(s.y))throw"non-numeric x/y for a sample";if(t.samplekey){s.sample=s[t.samplekey];delete s[t.samplekey]}if(t.sample_attributes){s.s={};for(const e in t.sample_attributes){s.s[e]=s[e];delete s[e]}}e.sample2dot.set(s.sample,s)}e.sample_attributes=t.sample_attributes;e.colorbyattributes=t.colorbyattributes;e.attr_levels=t.attr_levels;if(t.user_samples){if(!Array.isArray(t.user_samples))throw".user_samples[] is not array";e.dots_user=[];for(const s of t.user_samples){if(!Number.isFinite(s.x)||!Number.isFinite(s.y))throw"non-numeric x/y for a USER sample";if(t.samplekey){s.sample=s[t.samplekey];delete s[t.samplekey]}if(!s.color)s.color=I;e.dots_user.push(s)}}if(!e.filterApi){e.filterApi=k({btn:e.filterDiv.append("div"),btnLabel:"Filter",emptyLabel:"+New Filter",holder:e.filterDiv.append("div"),vocab:w(t),debug:true,callback(s){e.filteredSamples=O(t.samples,s);if(e.dotselection._groups[0].length!=e.filteredSamples.size){e.dotselection.transition().attr("r",(t=>e.filteredSamples.has(t.sample)?q:0)).style("opacity",(t=>e.filteredSamples.has(t.sample)?1:0))}else{e.dotselection.transition().attr("r",q).style("opacity",1)}V(e)}});e.filterApi.main({type:"tvslst",join:"",lst:[]});e.filteredSamples=[]}}function U(e,t){if(!e.analysisdata){e.dots=t.dots;return}if(!e.analysisdata.str)throw".analysisdata.str missing while trying to combine client/server data";const s=new Map;e.dots_user=[];for(const t of e.analysisdata.str.trim().split("\n")){const a=t.split("\t");if(a.length<3){continue}const l=a[2];if(!l)continue;const o={x:Number(a[0]),y:Number(a[1])};if(Number.isNaN(o.x)||Number.isNaN(o.y))continue;if(a[3]){o.sample=l;o.color=I;e.dots_user.push(o);continue}s.set(l,o)}e.dots=[];for(const a of t.dots){const t=s.get(a.sample);if(!t)continue;a.x=t.x;a.y=t.y;e.dots.push(a)}}function D(e){if(e.colorbyattributes){if(!Array.isArray(e.colorbyattributes))throw".colorbyattributes[] is not array";if(!e.sample_attributes)throw".sample_attributes{} missing when .colorbyattributes is defined";for(const t of e.colorbyattributes){if(typeof t!="object")throw"one of .colorbyattributes[] is not array";if(!t.key)throw".key missing from one of .colorbyattributes[]";const s=e.sample_attributes[t.key];if(!s)throw"unknown key from .colorbyattributes: "+t.key;t.label=s.label;t.values=s.values;if(!t.values){t.values={};for(const s of e.dots){const e=s.s[t.key];if(e==undefined||e==null)continue;t.values[e]={}}}const a=l(x);for(const e in t.values){if(!t.values[e].color)t.values[e].color=a(e)}if(e.analysisdata){const s=e.analysisdata.sample_attributes;if(s[t.key].values==undefined)s[t.key].values=t.values}}}if(e.attr_levels){if(!Array.isArray(e.attr_levels))throw".attr_levels[] is not array";if(e.attr_levels.length<2)throw".attr_levels[] array has less than 2 items";if(!e.sample_attributes)throw".sample_attributes is missing when .attr_levels is defined";for(const t of e.attr_levels){if(!t.key)throw".key missing from one of attr_levels[]";const s=e.sample_attributes[t.key];if(!s)throw".attr_levels key missing from sample_attributes{}: "+t.key;if(!s.values){s.values={};for(const a of e.dots){const e=a.s[t.key];if(e==undefined||e==null||s.values[e])continue;s.values[e]={}}const a=l(x);for(const e in s.values){if(!s.values[e].color)s.values[e].color=a(e)}s.orderByCount=true}if(t.label);}}}function P(t){const s=t.scattersvg.node().closest(".sja_root_holder");let a=t.dots[0].x,l=a,r=t.dots[0].y,c=r;for(const e of[...t.dots,...t.dots_user||[]]){a=Math.min(a,e.x);l=Math.max(l,e.x);r=Math.min(r,e.y);c=Math.max(c,e.y)}let p=t.xscale=o().domain([a,l]);let d=t.yscale=o().domain([r,c]);if(!t.dimensions)t.dimensions={};if(!("autoResize"in t.dimensions))t.dimensions.autoResize=true;if(!("minWidth"in t.dimensions))t.dimensions.minWidth=300;if(!("minHeight"in t.dimensions))t.dimensions.minHeight=300;let m;const f=250;const u=s.getBoundingClientRect();let y=30,b=50,v=100,x=30,g=20,h=t.dimensions.width?t.dimensions.width:Math.max(t.dimensions.minWidth,.75*(u.width-f)),_=t.dimensions.height?t.dimensions.height:Math.max(t.dimensions.minHeight,Math.min(1.2*h,.5*u.height)),k=18;const w=t.scattersvg;const O=t.dotg=w.append("g").attr("transform","translate("+(v+g)+","+y+")");const j=O.selectAll().data(t.dots).enter().append("g").attr("class","sample_dot");const S=j.append("circle").attr("stroke","none").attr("r",q).on("mouseover",((e,s)=>{e.target.setAttribute("stroke","white");const a=[{k:"Sample",v:s.sample}];if(t.sample_attributes){for(const e in t.sample_attributes){const l=t.sample_attributes[e];s.s[e];a.push({k:l.label,v:s.s[e]})}}n(t.tip.clear().d,a);t.tip.show(e.clientX,e.clientY)})).on("mouseout",((e,s)=>{e.target.setAttribute("stroke","none");t.tip.hide()})).on("click",((e,s)=>{Q(s,t,e)}));t.dotselection=S;let A,M,F,N,E;const T=t.userlabel_grp={userlabels:N,userlabel_borders:E};if(t.dots_user){A=O.selectAll().data(t.dots_user).enter().append("g").attr("class","sample_dot");M=A.append("circle").attr("stroke","none").attr("fill",(e=>e.color)).attr("r",q).on("mouseover",((e,s)=>{const a=[{k:"Sample",v:s.sample}];if(t.sample_attributes){for(const e in t.sample_attributes){const l=t.sample_attributes[e];if(s[e])a.push({k:l.label,v:s[e]})}}n(t.tip.clear().d,a);t.tip.show(e.clientX,e.clientY);Object.values(T).forEach((e=>e.filter((e=>e.sample==s.sample)).attr("font-weight","bold")))})).on("mouseout",((e,s)=>{t.tip.hide();Object.values(T).forEach((e=>e.filter((e=>e.sample==s.sample)).attr("font-weight","normal")))}));F=O.selectAll().data(t.dots_user).enter().append("g").attr("class","userlabelg");T.userlabel_borders=F.append("text").attr("fill","#fff").attr("font-size",k).attr("stroke","white").attr("stroke-width","3px").text((e=>e.sample)).attr("text-anchor","end");T.userlabels=F.append("text").attr("fill",(e=>e.color)).attr("font-size",k).text((e=>e.sample)).on("mouseover",((e,s)=>{M.filter((e=>e.sample==s.sample)).attr("r",q*2);w.style("cursor","move");const a=[{k:"Sample",v:s.sample}];if(t.sample_attributes){for(const e in t.sample_attributes){const l=t.sample_attributes[e];if(s[e])a.push({k:l.label,v:s[e]})}}n(t.tip.clear().d,a);t.tip.show(e.clientX,e.clientY)})).on("mouseout",((e,s)=>{M.filter((e=>e.sample==s.sample)).attr("r",q);w.style("cursor","auto");t.tip.hide()})).on("mousedown",((s,a)=>{s.preventDefault();s.stopPropagation();const l=e(document.body);const o=s.clientX;const n=s.clientY;p=t.zoomed_scale&&t.zoomed_scale>1?t.new_xscale:t.xscale;d=t.zoomed_scale&&t.zoomed_scale>1?t.new_yscale:t.yscale;const i=F.filter((e=>e.sample==a.sample));const[r,c]=i.attr("transform").match(/[\d\.]+/g).map(Number);l.on("mousemove",(e=>{i.attr("transform","translate("+(r+e.clientX-o)+","+(c+e.clientY-n)+")")}));l.on("mouseup",(e=>{l.on("mousemove",null).on("mouseup",null);a.x_=p.invert(r+e.clientX-o);a.y_=d.invert(c+e.clientY-n)}))})).on("dblclick",((e,s)=>{t.menu2.clear().show(e.clientX-90,e.clientY);t.menu2.d.append("input").attr("type","text").property("value",s.sample).style("display","block").style("margin-bottom","5px").on("keyup",(e=>{if(!i(e))return;const a=e.target.value;Object.values(T).forEach((e=>e.filter((e=>e.sample==s.sample)).text(a)));s.sample=a;t.menu2.hide()}));t.menu2.d.append("input").attr("type","color").property("value",s.color).on("change",(e=>{const t=e.target.value;Object.values(T).forEach((e=>e.filter((e=>e.sample==s.sample)).attr("fill",t)));M.filter((e=>e.sample==s.sample)).attr("fill",t);s.color=t}))}));T.userlabels.append("title").text("Double-click to edit")}W(t);function C(){b=h/20+20;w.attr("width",v+g+h+x).attr("height",y+_+g+b);const e=t.zoomed_scale&&t.zoomed_scale>1?t.new_xscale:p;const a=t.zoomed_scale&&t.zoomed_scale>1?t.new_yscale:d;e.range([0,h]);a.range([_,0]);j.attr("transform",(t=>"translate("+e(t.x)+","+a(t.y)+")"));if(A){A.attr("transform",(t=>"translate("+e(t.x)+","+a(t.y)+")"));F.attr("transform",(t=>{const s=t.x_?e(t.x_):e(t.x),l=t.y_?a(t.y_):a(t.y);let o;Object.values(T).forEach((e=>e.filter((e=>e.sample==t.sample)).each((function(){o=this.getBBox().width})).attr("text-anchor",s+o>=h?"end":"start")));return"translate("+s+","+l+")"}))}m=s.getBoundingClientRect();if(t.userlabel_grp&&F&&F.size()){z(F,{waitTime:0,nameKey:"sample"})}}C();t.scattersvg_resizehandle.style("position","absolute").style("right","0px").style("bottom","0px").attr("class","sja_clbtext").text("drag to resize").on("mousedown",(t=>{t.preventDefault();const s=e(document.body);const a=t.clientX;const l=t.clientY;const o=h;const n=_;s.on("mousemove",(e=>{h=o+e.clientX-a;_=n+e.clientY-l;C()}));s.on("mouseup",(()=>{s.on("mousemove",null).on("mouseup",null)}))}));function B(){const e=s.getBoundingClientRect();const a=h*e.width/m.width;h=t.dimensions.minWidth?Math.max(t.dimensions.minWidth,a):a;const l=_*e.height/m.height;_=t.dimensions.minHeight?Math.max(t.dimensions.minHeight,l):l;m=e;C()}let R;if(t.dimensions.autoResize){window.addEventListener("resize",(()=>{if(R)clearTimeout(R);R=setTimeout(B,50)}))}H(t)}function H(e){const t=e.scattersvg;e.scattersvg_buttons.style("position","absolute").style("right","0px").style("top","0px");e.zoom_active=false;const s=e.scattersvg_buttons.append("div").style("padding","2px 5px").style("border","1px solid #999").style("color","#999").style("background-color","#fff").style("cursor","pointer").style("font-weight","300").style("border-radius","5px").style("text-align","center").text("Pan / Zoom").on("click",d);const a=e.scattersvg_buttons.append("div").style("margin-top","2px").style("padding","2px 5px").style("border-radius","5px").style("text-align","center").style("display",e.zoom_active?"block":"none").style("background-color","#ddd");const l=a.append("div").style("margin","5px 2px");l.append("div").style("display","block").style("padding","2px 4px").style("font-size","80%").text("Zoom");l.append("div").style("display","block").style("padding","2px").style("font-size","70%").html('<p style="margin:1px;">Mouse wheel </br>or use these buttons</p>');const o=l.append("button").style("margin","1px").style("padding","2px 7px").text("+");const n=l.append("button").style("margin","1px").style("padding","2px 8px").text("-");const i=a.append("div").style("margin","5px 2px");i.append("div").style("display","block").style("padding","2px").style("font-size","80%").text("Pan");i.append("div").style("display","block").style("padding","2px").style("font-size","70%").html('<p style="margin:1px;">Mouse click </br>+ Mouse move</p>');const c=a.append("div").style("margin","5px 2px");const p=c.append("button").style("margin","1px").style("padding","2px 8px").text("Reset");function d(){e.zoom_active=e.zoom_active?false:true;s.style("border",e.zoom_active?"2px solid #000":"1px solid #999").style("color",e.zoom_active?"#000":"#999").style("background-color",e.zoom_active?"#eee":"#fff").style("font-weight",e.zoom_active?"400":"300");m.style("pointer-events",e.zoom_active?"none":"auto");a.style("display",e.zoom_active?"block":"none");const l=_().scaleExtent([1,5]).on("zoom",e.zoom_active?i:null);function i(t){e.new_xscale=t.transform.rescaleX(e.xscale);e.new_yscale=t.transform.rescaleY(e.yscale);e.zoomed_scale=t.transform.k;const s=e.dotg.selectAll(".sample_dot");s.attr("transform",(t=>"translate("+e.new_xscale(t.x)+","+e.new_yscale(t.y)+")"));const a=e.dotg.selectAll(".userlabelg");a.attr("transform",(t=>"translate("+e.new_xscale(t.x_||t.x)+","+e.new_yscale(t.y_||t.y)+")"))}if(e.zoom_active)t.call(l);else t.on(".zoom",null);o.on("click",(()=>{l.scaleBy(t.transition().duration(750),1.5)}));n.on("click",(()=>{l.scaleBy(t.transition().duration(750),.5)}));p.on("click",(()=>{t.transition().duration(750).call(l.transform,r)}))}const m=e.scattersvg_buttons.append("div").style("display","block").style("padding","2px 5px").style("margin-top","5px").style("border","1px solid #999").style("color","#999").style("background-color","#fff").style("cursor","pointer").style("font-weight","300").style("border-radius","5px").style("text-align","center").text("Lasso select").on("click",y);const f=e.scattersvg_buttons.append("div").style("margin-top","2px").style("padding","2px 5px").style("border-radius","5px").style("text-align","center").style("display",e.lasso_active?"block":"none").style("background-color","#ddd");const u=f.append("div").style("margin","5px 2px");u.append("div").style("display","block").style("padding","2px").style("font-size","80%").text("Lasso usage");u.append("div").style("display","block").style("padding","2px").style("font-size","70%").html('<p style="margin:1px;">Mouse click </br>+ Mouse move <br>'+"TIP: Release the mouse <br> when desired dots <br> are selected, without <br>closing the loop. </p>");function y(){const t=e.dotg.selectAll("g");e.lasso_active=e.lasso_active?false:true;s.style("pointer-events",e.lasso_active?"none":"auto");f.style("display",e.lasso_active?"block":"none");m.style("border",e.lasso_active?"2px solid #000":"1px solid #999").style("color",e.lasso_active?"#000":"#999").style("background-color",e.lasso_active?"#eee":"#fff").style("font-weight",e.lasso_active?"400":"300");te(e,t);if(e.lasso_active)return;t.selectAll("circle").classed("not_possible",false).classed("possible",false).attr("r",q).style("fill-opacity","1")}}function W(e){let t;if(e.colorbygeneexpression&&e.colorbygeneexpression.__inuse);else if(e.attr_levels){t={key:e.attr_levels[1].key};t.values=e.sample_attributes[t.key].values}else if(e.colorbyattributes){t={key:(e.colorbyattributes.find((e=>e.__inuse))||e.colorbyattributes[0]).key};t.values=e.sample_attributes[t.key].values}e.dotselection.transition().attr("fill",(e=>{if(t){const s=e.s[t.key];return t.values[s]?t.values[s].color:"black"}return"#ccc"}))}function G(e){if(e.attr_levels){K(e);return}if(e.colorbyattributes){J(e);return}if(e.colorbygeneexpression);}function K(e){const t=e.legendtable.append("tr").append("td").append("div").style("position","relative");const s=t.append("div");const a=e.attr_levels[0];a.v2c=new Map;a.unannotated=0;for(const t of e.dots){const e=t.s[a.key];if(e==undefined||e==null){a.unannotated++;continue}if(!a.v2c.has(e))a.v2c.set(e,{dots:[]});a.v2c.get(e).dots.push(t);if(a.label){a.v2c.get(e).label=t.s[a.label]}}for(const t of Z(a,e)){const l=a.v2c.get(t);const o=s.append("div").style("margin-top","20px").attr("class","sja_lb_div");o.append("div").attr("class","sja_l1lb").html((l.label||t)+' <span style="font-size:.8em">n='+l.dots.length+"</span>").style("margin-top","15px");const n=e.attr_levels[1];if(n){const t=e.sample_attributes[n.key].values;n.v2c=new Map;n.unannotated=0;for(const e of l.dots){const s=e.s[n.key];if(s==undefined||s==null){n.unannotated++;continue}if(!n.v2c.has(s)){const e=t[s];if(e){e.dots=[];n.v2c.set(s,e)}}if(n.v2c.has(s)){n.v2c.get(s).dots.push(e);if(n.label){n.v2c.get(s).label=e.s[n.label]}}}if(!e.hide_subtype_legend){for(const s of Z(n,e)){const a=n.v2c.get(s);const l=o.append("div").style("display","inline-block").style("white-space","nowrap").attr("class","sja_clb").on("click",(()=>{if(a.selected){a.selected=false;l.style("border","");let o=true;for(const e in t){if(t[e].selected)o=false}if(o){e.dotselection.transition().attr("r",q)}else{e.dotselection.filter((e=>e.s[n.key]==s)).transition().attr("r",L)}return}let o=true;for(const e in t){if(t[e].selected)o=false}a.selected=true;l.style("border","solid 1px #858585");if(o){e.dotselection.transition().attr("r",(e=>e.s[n.key]==s?q:L))}else{e.dotselection.filter((e=>e.s[n.key]==s)).transition().attr("r",q)}}));l.append("div").style("display","inline-block").attr("class","sja_mcdot").style("background",a.color).style("margin-right","3px").text(a.dots.length);l.append("div").style("display","inline-block").style("color",a.color).text(a.label||s);a.cell=l}}if(n.unannotated){const e=o.append("div").style("margin-top","20px");e.append("div").text('Unannotated for "'+n.key+'": '+n.unannotated)}}}if(a.unannotated){const e=s.append("div").style("margin-top","20px");e.append("div").html('Unannotated for "'+a.key+'": '+a.unannotated)}if(a.v2c.size>10){s.style("overflow-y","scroll").style("height","800px").style("resize","vertical")}}function Z(e,t){const s=t.sample_attributes[e.key];if(!s.values||s.orderByCount){return[...e.v2c].sort(((e,t)=>t[1].dots.length-e[1].dots.length)).map((e=>e[0]))}const a=[];for(const t in s.values){if(e.v2c.has(t))a.push(t)}return a}function J(e){if(!e.colorbyattributes.find((e=>e.__inuse)))e.colorbyattributes[0].__inuse=true;for(const t of e.colorbyattributes){const s=e.legendtable.append("tr");t.labelhandle=s.append("td").append("div").style("white-space","nowrap").text(t.label).attr("class","sja_clb").on("click",(()=>{for(const t of e.colorbyattributes){t.__inuse=false;t.labelhandle.style("background","").style("border-bottom","")}t.__inuse=true;t.labelhandle.style("background","#ededed").style("border-bottom","solid 2px #858585");W(e)}));if(t.__inuse){t.labelhandle.style("background","#ededed").style("border-bottom","solid 2px #858585")}for(const s of e.dots){const e=s.s[t.key];if(e==undefined||e==null)continue;if(!t.values[e])t.values[e]={color:"black"};t.values[e].count=1+(t.values[e].count||0)}const a=s.append("td");for(const s in t.values){const l=t.values[s];if(l.count==0||l.count==undefined)continue;const o=a.append("div").style("display","inline-block").attr("class","sja_clb").on("click",(()=>{if(l.selected){l.selected=false;o.style("border","");let a=true;for(const e in t.values){if(t.values[e].selected)a=false}if(a){e.dotselection.transition().attr("r",q)}else{e.dotselection.filter((e=>e.s[t.key]==s)).transition().attr("r",L)}return}let a=true;for(const e in t.values){if(t.values[e].selected)a=false}l.selected=true;o.style("border","solid 1px #858585");if(a){e.dotselection.transition().attr("r",(e=>e.s[t.key]==s?q:L))}else{e.dotselection.filter((e=>e.s[t.key]==s)).transition().attr("r",q)}}));o.append("div").style("display","inline-block").attr("class","sja_mcdot").style("background",l.color).style("margin-right","3px").text(l.count);o.append("div").style("display","inline-block").style("color",l.color).text(l.name||s);l.cell=o}}}function V(t){const s=t.dots.filter((e=>t.filteredSamples.has(e.sample)));const a=Array.from(s,(e=>e.s));const l=t.attr_levels?.[0].label||t.attr_levels?.[0].key;const o=[...new Set(Array.from(a,(e=>e[l])))];const n=t.attr_levels?.[1].label||t.attr_levels?.[1].key;const i=[...new Set(Array.from(a,(e=>e[n])))];const r=t.legendtable.node().querySelectorAll(".sja_lb_div");for(const t of r){const s=e(t).select(".sja_l1lb").node().innerText.split(/\s{2}n=/)[0];if(!o.includes(s))e(t).style("display","none");else{e(t).style("display","block");const s=e(t).node().querySelectorAll(".sja_clb");for(const t of s){const s=e(t).node().querySelectorAll("div")[1];if(!i.includes(s.innerText))e(t).style("display","none");else e(t).style("display","inline-block")}}}}function Q(e,t,s){if(t.dslabel){ee(e,t,s);return}if(t.mds){$(e,t,s);return}}async function $(e,t,s){const a=c({x:s.clientX,y:s.clientY});a.header.text(e.sample);const l=p(a.body);try{const s=await d();const o={genome:t.genome.name,dslabel:t.mds.label,querykey:t.mds.querykey,getsample4disco:e.sample};const n=await m("/mdssvcnv",o);if(n.error)throw n.error;if(!n.text)throw".text missing";const i=a.body.append("div");const r=await s.dtDisco({holderSelector:i,chromosomeType:t.genome.name,majorchr:t.genome.majorchr,settings:{showControls:false,selectedSamples:[]},callbacks:{geneLabelClick:{type:"genomepaint",hostURL:sessionStorage.getItem("hostURL")||"",genome:t.genome.name,dslabel:t.mds.label,sample:e.sample}}});const c={sampleName:e.sample,data:JSON.parse(n.text)};r.main(c);l.remove()}catch(e){l.text("Error: "+(e.message||e));if(e.stack)console.log(e.stack)}}function ee(e,t,s){const a=c({x:s.clientX,y:s.clientY});a.header.text(e.sample);const l=a.body.append("div").style("margin","20px").text("Loading ...");m("/mdssvcnv",{genome:t.genome.name,dslabel:t.dslabel,querykey:t.querykey,gettrack4singlesample:e.sample}).then((s=>{l.remove();ie({obj:t,dot:e,sampletracks:s.tracks,holder:a.body})}))}function te(e,t){const s=e.scattersvg;let a;if(e.lasso_active){a=h().items(t.selectAll("circle")).targetArea(s);a.on("start",l).on("draw",o).on("end",n);s.call(a)}else{s.selectAll(".lasso").remove();s.on("mousedown.drag",null)}function l(){if(!e.lasso_active)return;a.items().attr("r",2).style("fill-opacity",".5").classed("not_possible",true).classed("selected",false)}function o(){if(!e.lasso_active)return;a.possibleItems().attr("r",q).style("fill-opacity","1").classed("not_possible",false).classed("possible",true)}function n(t){if(!e.lasso_active)return;const l=s.selectAll(".possible").data().map((e=>e.sample));if(l.length)i(t,l);else e.menu.hide();a.items().classed("not_possible",false).classed("possible",false);a.selectedItems().attr("r",q);a.notSelectedItems().attr("r",l.length==0?q:L).style("fill-opacity","1")}function i(t,s){e.menu.clear().show(t.sourceEvent.clientX-90,t.sourceEvent.clientY);if(e.mds&&e.mds.gene2mutcount){e.menu.d.append("div").attr("class","sja_menuoption").text("Recurrently mutated genes").on("click",(async()=>{e.menu.hide();await ae(e,s)}))}for(const t of e.lasso.postSelectMenuOptions){e.menu.d.append("div").attr("class","sja_menuoption").text(t.label).on("click",(async()=>{e.menu.hide();const a={samples:s,sample_attributes:e.sample_attributes,sample2dot:e.sample2dot};if(t.callback=="listSamples")se(a);else t.callback(a)}))}e.menu.d.append("div").attr("class","sja_menuoption").text("Cancel").on("click",(()=>{a.items().classed("not_possible",false).classed("possible",false).attr("r",q).style("fill-opacity","1");e.menu.hide()}));e.menu.d.append("div").style("padding","10px").style("font-size",".8em").style("width","150px").text(s.length+" samples selected")}}function se(e){const{samples:t,sample_attributes:s,sample2dot:a}=e;const l=Object.keys(s);let o=l.map((e=>s[e].label?s[e].label:e));o.unshift("Sample");const n=o.join("\t");const i=[n];for(const e of t){if(a.get(e).s){let t=[];t.push(e);for(const s of l)t.push(a.get(e).s[s]);i.push(t.join("\t"))}}f("List of selected samples",[{text:i.join("\n")}])}function ae(e,t){e.pane=c({x:event.clientX,y:event.clientY});e.pane.header.text("Recurrently Mutated Genes");e.pane.wait=p(e.pane.body);e.pane.matrix_criteria_div=e.pane.body.append("div");e.pane.sample_matrix_div=e.pane.body.append("div");le(e,t)}function le(e,t){let s=[],a=[],l=[],o,n=15;const i=e.pane.matrix_criteria_div;if(e.mds.mutCountType){s=e.mds.mutCountType;const r=s.filter((e=>!e.db_col.includes("cnv")));const c=s.filter((e=>e.db_col.includes("cnv")));const p=c.find((e=>e.default));o=p;a=s.filter((e=>e.default)).map((e=>e.db_col));l=[...a];const d=i.append("div").style("margin","5px 20px");const m=i.append("div").style("margin","5px 20px").style("padding","5px").style("border-top","solid 1px #ededed").style("border-bottom","solid 1px #ededed").style("background-color","#FCFBF7").style("font-size",".8em");d.append("span").style("margin-right","20px").style("font-size",".8em").text("MUTATION COUNT & NO. OF GENE CRITERIA").attr("class","sja_clbtext").on("click",(()=>{if(m.style("display")=="none"){u(m)}else{y(m)}}));const f=m.append("div");const b=f.append("div").style("display","table-cell").style("width","110px");b.append("div").text("Consequences").style("padding-right","15px");const v=f.append("div").style("display","table-cell").style("border-left","solid 1px #ededed");r.forEach((e=>{const t=v.append("div");const s=t.append("input").attr("type","checkbox").attr("name","mut_type").attr("value",e.db_col).style("margin","3px").style("margin-left","4px").property("checked",e.default);s.on("change",(()=>{if(s.node().checked){l.push(s.node().value)}else{l=l.filter((e=>e!==s.node().value))}}));t.append("label").attr("for",e.db_col).html(e.label)}));const x=v.append("input").attr("type","checkbox").attr("name","noncnv").attr("value","cnv").style("margin","3px").style("margin-left","4px").property("checked",p?true:false).on("change",(()=>{if(x.node().checked){k.property("disabled",false);w.property("disabled",false)}else{k.property("disabled",true);w.property("disabled",true)}}));v.append("label").attr("for","cnv").text("CNV");const g=v.append("div").style("display","block").style("padding","3px 15px");const h=[...new Set(c.map((e=>e.sizecutoff)))];const _=[...new Set(c.map((e=>e.log2cutoff)))];g.append("label").attr("for","cnv_size").style("margin","2px 10px").text("Size cutoff");const k=g.append("select").attr("name","cnv_size");h.forEach((e=>{k.append("option").attr("value",e).text(e)}));k.property("selectedIndex",p.sizecutoff=="1Mb"?0:p.sizecutoff=="2Mb"?1:2);g.append("label").attr("for","log2_ratio").style("margin","2px 10px").text("log2(ratio) cutoff");const w=g.append("select").attr("name","log2_ratio");_.forEach((e=>{w.append("option").attr("value",e.toFixed(1)).text(e.toFixed(1))}));w.property("selectedIndex",p.log2cutoff==.1?0:p.log2cutoff==.2?1:2);const O=m.append("div").style("padding-top","10px");const j=O.append("div").style("display","table-cell").style("width","110px");j.append("div").text("No. of Genes").style("padding-right","15px");const z=O.append("div").style("display","table-cell").style("padding","3px").style("border-left","solid 1px #ededed");const S=[10,15,20,30,40];const A=z.append("select").attr("name","gene_n");S.forEach((e=>{A.append("option").attr("value",e).text(e)}));A.property("selectedIndex",S.findIndex((e=>e==n)));m.append("button").style("margin","10px").style("padding","3px 10px").text("Calculate").on("click",(()=>{const s=v.node().querySelectorAll("input:checked");l=[];s.forEach((e=>{if(e.value!=="cnv"&&!l.includes(e.value))l.push(e.value);else if(e.value=="cnv"){const e=k.node().value;const t=w.node().value;o=c.find((s=>s.sizecutoff==e&&s.log2cutoff==t));l.push(o.db_col)}}));n=A.node().value;oe(e,t,l,n);a=[...l]}))}else a=["total"];oe(e,t,a,n)}async function oe(e,t,s,l){try{const o={genome:e.genome.name,dslabel:e.mds.label,samples:t,selectedMutTypes:s,nGenes:l};const n=await a("mdsgenecount",{method:"POST",body:JSON.stringify(o)});if(n.error)throw n.error;if(!n.genes)throw".genes missing";if(!n.genes.length){e.pane.wait.html("No gene retrived with mutations.");e.pane.matrix_criteria_div.style("display","none");return}ne({obj:e,genes:n.genes,samples:t,holder:e.pane.body});e.pane.wait.remove()}catch(t){e.pane.wait.text("Error: "+(t.message||t));if(t.stack)console.log(t.stack)}}function ne(e){const{obj:t,genes:s,samples:a}=e;const l=t.pane.sample_matrix_div;l.selectAll("*").remove();for(const e of s){e.ismutation=true;e.genename=e.gene;e.label=e.gene;delete e.gene;e.querykeylst=["svcnv","snvindel"];t.features_on_rows?e.height=50:e.width=50}const o={genome:t.genome,dslabel:t.mds.label,features:s,features_on_rows:t.features_on_rows,ismutation_allsymbolic:true,hostURL:sessionStorage.getItem("hostURL")||"",limitbysamplesetgroup:{samples:a},jwt:sessionStorage.getItem("jwt")||"",holder:l.append("div").style("margin","20px")};import("./samplematrix-2b137a05.js").then((e=>{const t=new e.Samplematrix(o);t._pane=l}))}function ie(e){const{obj:t,dot:s,sampletracks:a,holder:l}=e;const o={genome:t.genome,hostURL:sessionStorage.getItem("hostURL")||"",jwt:sessionStorage.getItem("jwt")||"",holder:l,chr:t.genome.defaultcoord.chr,start:t.genome.defaultcoord.start,stop:t.genome.defaultcoord.stop,nobox:1,tklst:[]};if(t.tracks){for(const e of t.tracks)o.tklst.push(e)}const n=t.mds.queries[t.querykey];if(n){const e={singlesample:{name:s.sample},mds:t.mds,querykey:t.querykey};for(const t in n){e[t]=n[t]}o.tklst.push(e);if(n.checkexpressionrank){const e={type:b.mdsexpressionrank,name:s.sample+" gene expression rank",dslabel:t.mds.label,querykey:n.checkexpressionrank.querykey,sample:s.sample};if(n.groupsamplebyattr){const t=n.groupsamplebyattr.attrlst;if(t&&t.length){e.attributes=[];for(const a of t){e.attributes.push({k:a.k,label:a.label,kvalue:s.s[a.k]})}}}o.tklst.push(e)}}if(a){for(const e of a)o.tklst.push(e)}v(t.genome,o.tklst);g(o)}export{X as init};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{M as e,j as t,U as s,q as n,ae as a,a8 as l,af as p,I as o,d as i,ag as r}from"./app-a8c4854a.js";import{b as d,a as u}from"./axis-747c801e.js";async function c(n,a,l){if(l){window.obj=n}n.plots=[];n.menu=new e({padding:"5px"});n.tip=new e({padding:"5px"});n.errordiv=a.append("div").style("margin","10px");n.sayerror=e=>{t(n.errordiv,typeof e=="string"?e:e.message);if(e.stack)console.log(e.stack)};n.uidiv=a.append("div").style("margin","20px");n.plotdiv=a.append("div").style("margin","20px");n.legendtable=a.append("table").style("border-spacing","5px");a.append("button").text("SVG").on("click",(()=>{s(n.plotlist[0].svg.node(),"Survival")}));try{await m(n);if(!n.plotlist){n.plotlist=[]}if(!Array.isArray(n.plotlist))throw".plotlist should be array";if(n.plotlist.length==0){const e={type:n.plottypes[0].key};n.plotlist.push(e)}for(const e of n.plotlist){f(e,n)}}catch(e){if(e.stack)console.log(e.stack);n.sayerror("Cannot make plot: "+(e.message||e))}}function m(e){const t={genome:e.genome.name,dslabel:e.mds.label,init:1};return n("mdssurvivalplot",t).then((t=>{if(t.error)throw t.error;if(!t.plottypes)throw"plottypes[] missing";e.plottypes=t.plottypes;e.samplegroupings=t.samplegroupings}))}function f(e,t){y(e,t);const s=t.uidiv.append("div").style("margin","20px");if(t.plottypes.length>1){const n=s.append("div").style("margin-bottom","10px").append("select").on("change",(t=>{e.type=t.target.options[t.target.selectedIndex].value}));for(const[s,a]of t.plottypes.entries()){n.append("option").text(a.name).property("value",a.key);if(a.key==e.type){n.node().selectedIndex=s}}}if(t.samplegroupings&&!e.samplerule.full.immutable){const n=s.append("div").style("margin-bottom","20px");const a=s.append("div").style("display","none");n.append("span").html("Choose samples from ").style("opacity",.5);const l={};const p=n.append("select").style("margin-right","5px").on("change",(t=>{for(const e in l){l[e].style("display","none")}const s=t.target.options[t.target.selectedIndex];a.style("display",s.usesampleset?"block":"none");if(s.useall){e.samplerule.full.useall=1;delete e.samplerule.full.byattr;return}if(s.usesampleset){delete e.samplerule.full.byattr;delete e.samplerule.full.useall;e.samplerule.full.usesampleset=1;v(e,a);return}delete e.samplerule.full.useall;e.samplerule.full.byattr=1;e.samplerule.key=s.key;const n=l[s.key];n.style("display","inline");e.samplerule.full.value=n.node().options[n.node().selectedIndex].value}));for(const[s,a]of t.samplegroupings.entries()){p.append("option").text(a.label).property("key",a.key);const t=e.samplerule.full.byattr&&e.samplerule.full.key==a.key;if(t){p.node().selectedIndex=s}const o=n.append("select").on("change",(t=>{e.samplerule.full.value=t.target.options[t.target.selectedIndex].value}));l[a.key]=o;o.style("display",t?"inline":"none");for(const[s,n]of a.values.entries()){o.append("option").text(n.value+" (n="+n.count+")").property("value",n.value);if(t&&n.value==e.samplerule.full.value){o.node().selectedIndex=s}}}p.append("option").text("all samples").property("useall",1);if(e.samplerule.full.useall){p.node().selectedIndex=t.samplegroupings.length}p.append("option").text("custom sampleset").property("usesampleset",1)}x(e,s);e.button=s.append("button").text("Make plot").on("click",(()=>{h(e,t)}));e.d=t.plotdiv.append("div").style("margin","20px"),e.legend={d_pvalue:e.d.append("div").style("margin","10px"),d_samplefull:e.d.append("div").style("margin","10px"),d_curves:e.d.append("div").style("margin","10px")};e.svg=e.d.append("svg");e.resize_handle=e.d.append("div").append("div").attr("class","sja_clbtext").text("drag to resize").style("float","right");if(e.renderplot){h(e,t)}}function y(e,t){if(!e.type){e.type=t.plottypes[0].key}if(!e.samplerule){e.samplerule={}}if(!e.samplerule.full){e.samplerule.full={}}if(t.samplegroupings){if(!e.samplerule.full.useall){e.samplerule.full.byattr=1;if(!e.samplerule.full.key){e.samplerule.full.key=t.samplegroupings[0].key;e.samplerule.full.value=t.samplegroupings[0].values[0].value}}}else{e.samplerule.full.useall=1}if(e.samplerule.set){const t=e.samplerule.set;if(t.geneexpression){if(!t.bymedian&&!t.byquartile){t.bymedian=1}}}if(!e.width)e.width=500;if(!e.height)e.height=500;if(!e.toppad)e.toppad=10;if(!e.rightpad)e.rightpad=10;if(!e.xaxispad)e.xaxispad=10;if(!e.yaxispad)e.yaxispad=10;if(!e.xaxish)e.xaxish=40;if(!e.yaxisw)e.yaxisw=65;if(!e.censorticksize)e.censorticksize=6;if(!e.tickfontsize)e.tickfontsize=14;if(!e.labfontsize)e.labfontsize=15}function g(e,t){const s=l(p);const n=0;let a=0;for(const t of e.samplesets){t.color=s(t.name);for(const e of t.steps){a=Math.max(a,e.x)}}e.svg.selectAll("*").remove();const c=e.svg.append("g");for(const t of e.samplesets){t.path=c.append("path").attr("stroke",t.color).attr("fill","none");t.ticks=c.append("path").attr("stroke",t.color).attr("fill","none")}const m=e.svg.append("g");const f=o().domain([0,1]);const y=e.svg.append("g");const g=y.append("text").text("Survival").attr("transform","rotate(-90)");const h=e.svg.append("g");const x=o().domain([n,a]);const v=e.svg.append("text").attr("font-size",e.labfontsize).text(t.plottypes.find((t=>t.key==e.type)).timelabel).attr("x",e.yaxisw+e.yaxispad+e.width/2).attr("y",e.toppad+e.height+e.xaxispad+e.xaxish-3);function b(){c.attr("transform","translate("+(e.yaxisw+e.yaxispad)+","+e.toppad+")");for(const t of e.samplesets){const s=[];const n=["M 0 0"];for(const l of t.steps){n.push("H "+e.width*l.x/a);const t=e.height*(l.y+l.drop);n.push("V "+t);if(l.censored){const t=e.height*l.y;for(const n of l.censored){const l=e.width*n/a;s.push("M "+(l-e.censorticksize/2)+" "+(t-e.censorticksize/2)+" l "+e.censorticksize+" "+e.censorticksize+" M "+(l+e.censorticksize/2)+" "+(t-e.censorticksize/2)+" l -"+e.censorticksize+" "+e.censorticksize)}}}t.path.attr("d",n.join(" "));if(s.length){t.ticks.attr("d",s.join(" "))}}m.attr("transform","translate("+e.yaxisw+","+e.toppad+")");r({axis:m.call(d().scale(f.range([e.height,0])).ticks(Math.floor(e.height/(e.tickfontsize+20)))),showline:1,fontsize:e.tickfontsize});y.attr("transform","translate("+e.labfontsize+","+(e.toppad+e.height/2)+")");g.attr("font-size",e.labfontsize);h.attr("transform","translate("+(e.yaxisw+e.yaxispad)+","+(e.toppad+e.height+e.xaxispad)+")");let t;h.append("text").text(a).attr("font-size",e.tickfontsize).each((function(){t=Math.floor(e.width/(this.getBBox().width+30))})).remove();r({axis:h.call(u().scale(x.range([0,e.width])).ticks(t)),showline:1,fontsize:e.tickfontsize});v.attr("font-size",e.labfontsize).attr("x",e.yaxisw+e.yaxispad+e.width/2).attr("y",e.toppad+e.height+e.xaxispad+e.xaxish-3);e.svg.attr("width",e.yaxisw+e.yaxispad+e.width+e.rightpad).attr("height",e.toppad+e.height+e.xaxispad+e.xaxish)}b();e.resize_handle.on("mousedown",(t=>{t.preventDefault();const s=i(document.body);const n=t.clientX;const a=t.clientY;const l=e.width;const p=e.height;s.on("mousemove",(()=>{e.width=l+t.clientX-n;e.height=p+t.clientY-a;b()}));s.on("mouseup",(()=>{s.on("mousemove",null).on("mouseup",null)}))}));if(Number.isFinite(e.pvalue)){e.legend.d_pvalue.style("display","block").text("P-value: "+e.pvalue)}else{e.legend.d_pvalue.style("display","none")}e.legend.d_curves.selectAll("*").remove();for(const t of e.samplesets){e.legend.d_curves.append("div").style("margin","3px").html('<span style="background:'+t.color+'"> </span> '+t.name+(t.pvalue==undefined?"":", P-value: "+t.pvalue))}}function h(e,t){e.button.text("Loading...").attr("disabled",1);const s={genome:t.genome.name,dslabel:t.mds.label,type:e.type,samplerule:e.samplerule};n("mdssurvivalplot",s).then((s=>{if(s.error)throw s.error;if(!s.samplesets)throw"samplesets[] missing";e.samplesets=s.samplesets;e.pvalue=s.pvalue;g(e,t);if(e.samplerule.set&&e.samplerule.set.mutation){if(e.mutation_count.cnv)e.mutation_count.cnv.html("(n="+s.count_cnv+") ");if(e.mutation_count.loh)e.mutation_count.loh.html("(n="+s.count_loh+") ");if(e.mutation_count.snvindel)e.mutation_count.snvindel.html("(n="+s.count_snvindel+") ");if(e.mutation_count.sv)e.mutation_count.sv.html("(n="+s.count_sv+") ");if(e.mutation_count.fusion)e.mutation_count.fusion.html("(n="+s.count_fusion+") ");if(e.mutation_count.itd)e.mutation_count.itd.html("(n="+s.count_itd+") ")}})).catch((e=>{t.sayerror(e)})).then((()=>{e.button.text("Update plot").attr("disabled",null)}))}function x(e,t){if(!e.samplerule.set)return;const s=e.samplerule.set;if(s.geneexpression){if(!s.bymedian&&!s.byquartile){s.bymedian=1}const n=t.append("div").style("margin-bottom","10px");n.append("span").style("opacity",.5).html("Divide samples by "+s.gene+" expression with ");const a=n.append("select").on("change",(t=>{const s=t.target.options[t.target.selectedIndex];if(s.median){e.samplerule.set.bymedian=1;delete e.samplerule.set.byquartile;l.style("display","none")}else if(s.quartile){e.samplerule.set.byquartile=1;delete e.samplerule.set.bymedian;l.style("display","inline")}}));a.append("option").text("median (group=2)").property("median",1);a.append("option").text("quartile (group=4)").property("quartile",1);const l=n.append("span").style("margin-left","10px");l.append("span").html("Compare each quartile against ").style("opacity",.5);{const t=l.append("select").on("change",(t=>{delete e.samplerule.set.against1st;delete e.samplerule.set.against4th;switch(t.target.selectedIndex){case 0:break;case 1:e.samplerule.set.against1st=1;break;case 2:e.samplerule.set.against4th=1;break}}));t.append("option").text("none");t.append("option").text("first quartile");t.append("option").text("fourth quartile");if(s.against1st){t.node().selectedIndex=1}else if(t.against4th){t.node().selectedIndex=2}}if(s.bymedian){a.node().selectedIndex=0;l.style("display","none")}else if(s.byquartile){a.node().selectedIndex=1;l.style("display","inline")}}if(s.mutation){e.mutation_count={};if(s.snvindel){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.snvindel=n.append("span");if(s.snvindel.name){n.append("span").html("SNV/indel ");const e=n.append("select");e.append("option").text(s.snvindel.name).property("named",1);e.append("option").text("any mutation at "+s.chr+":"+s.start)}else{n.append("span").text("SNV/indel at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop))}}if(s.cnv){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.cnv=n.append("span");n.append("span").html("Copy number variation over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}if(s.loh){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.loh=n.append("span");n.append("span").html("LOH over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}if(s.sv){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.sv=n.append("span");n.append("span").html("SV at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop)+" ")}if(s.fusion){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.fusion=n.append("span");n.append("span").html("Fusion at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop)+" ")}if(s.itd){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.itd=n.append("span");n.append("span").html("ITD over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}}}function v(e,t){let s=t.selectAll("div").size();if(s)return;const n=t.append("div").style("margin-bottom","10px");const a=n.append("div").style("margin-left","20px");a.append("div").style("vertical-align","top").style("display","inline-block").style("opacity",.5).html("Enter sample names<br>(one sample per line) ");const l=a.append("textarea").style("display","inline-block").attr("cols","20").attr("rows","10").on("change",(()=>{let t=e.samplerule.full.sampleset=[];const s=l.property("value").trim();if(!s)return;for(const e of s.split("\n")){t.push(e)}}))}export{c as init};
|
|
1
|
+
import{M as e,j as t,U as s,q as n,ae as a,a8 as l,af as p,I as o,d as i,ag as r}from"./app-b369b169.js";import{b as d,a as u}from"./axis-747c801e.js";async function c(n,a,l){if(l){window.obj=n}n.plots=[];n.menu=new e({padding:"5px"});n.tip=new e({padding:"5px"});n.errordiv=a.append("div").style("margin","10px");n.sayerror=e=>{t(n.errordiv,typeof e=="string"?e:e.message);if(e.stack)console.log(e.stack)};n.uidiv=a.append("div").style("margin","20px");n.plotdiv=a.append("div").style("margin","20px");n.legendtable=a.append("table").style("border-spacing","5px");a.append("button").text("SVG").on("click",(()=>{s(n.plotlist[0].svg.node(),"Survival")}));try{await m(n);if(!n.plotlist){n.plotlist=[]}if(!Array.isArray(n.plotlist))throw".plotlist should be array";if(n.plotlist.length==0){const e={type:n.plottypes[0].key};n.plotlist.push(e)}for(const e of n.plotlist){f(e,n)}}catch(e){if(e.stack)console.log(e.stack);n.sayerror("Cannot make plot: "+(e.message||e))}}function m(e){const t={genome:e.genome.name,dslabel:e.mds.label,init:1};return n("mdssurvivalplot",t).then((t=>{if(t.error)throw t.error;if(!t.plottypes)throw"plottypes[] missing";e.plottypes=t.plottypes;e.samplegroupings=t.samplegroupings}))}function f(e,t){y(e,t);const s=t.uidiv.append("div").style("margin","20px");if(t.plottypes.length>1){const n=s.append("div").style("margin-bottom","10px").append("select").on("change",(t=>{e.type=t.target.options[t.target.selectedIndex].value}));for(const[s,a]of t.plottypes.entries()){n.append("option").text(a.name).property("value",a.key);if(a.key==e.type){n.node().selectedIndex=s}}}if(t.samplegroupings&&!e.samplerule.full.immutable){const n=s.append("div").style("margin-bottom","20px");const a=s.append("div").style("display","none");n.append("span").html("Choose samples from ").style("opacity",.5);const l={};const p=n.append("select").style("margin-right","5px").on("change",(t=>{for(const e in l){l[e].style("display","none")}const s=t.target.options[t.target.selectedIndex];a.style("display",s.usesampleset?"block":"none");if(s.useall){e.samplerule.full.useall=1;delete e.samplerule.full.byattr;return}if(s.usesampleset){delete e.samplerule.full.byattr;delete e.samplerule.full.useall;e.samplerule.full.usesampleset=1;v(e,a);return}delete e.samplerule.full.useall;e.samplerule.full.byattr=1;e.samplerule.key=s.key;const n=l[s.key];n.style("display","inline");e.samplerule.full.value=n.node().options[n.node().selectedIndex].value}));for(const[s,a]of t.samplegroupings.entries()){p.append("option").text(a.label).property("key",a.key);const t=e.samplerule.full.byattr&&e.samplerule.full.key==a.key;if(t){p.node().selectedIndex=s}const o=n.append("select").on("change",(t=>{e.samplerule.full.value=t.target.options[t.target.selectedIndex].value}));l[a.key]=o;o.style("display",t?"inline":"none");for(const[s,n]of a.values.entries()){o.append("option").text(n.value+" (n="+n.count+")").property("value",n.value);if(t&&n.value==e.samplerule.full.value){o.node().selectedIndex=s}}}p.append("option").text("all samples").property("useall",1);if(e.samplerule.full.useall){p.node().selectedIndex=t.samplegroupings.length}p.append("option").text("custom sampleset").property("usesampleset",1)}x(e,s);e.button=s.append("button").text("Make plot").on("click",(()=>{h(e,t)}));e.d=t.plotdiv.append("div").style("margin","20px"),e.legend={d_pvalue:e.d.append("div").style("margin","10px"),d_samplefull:e.d.append("div").style("margin","10px"),d_curves:e.d.append("div").style("margin","10px")};e.svg=e.d.append("svg");e.resize_handle=e.d.append("div").append("div").attr("class","sja_clbtext").text("drag to resize").style("float","right");if(e.renderplot){h(e,t)}}function y(e,t){if(!e.type){e.type=t.plottypes[0].key}if(!e.samplerule){e.samplerule={}}if(!e.samplerule.full){e.samplerule.full={}}if(t.samplegroupings){if(!e.samplerule.full.useall){e.samplerule.full.byattr=1;if(!e.samplerule.full.key){e.samplerule.full.key=t.samplegroupings[0].key;e.samplerule.full.value=t.samplegroupings[0].values[0].value}}}else{e.samplerule.full.useall=1}if(e.samplerule.set){const t=e.samplerule.set;if(t.geneexpression){if(!t.bymedian&&!t.byquartile){t.bymedian=1}}}if(!e.width)e.width=500;if(!e.height)e.height=500;if(!e.toppad)e.toppad=10;if(!e.rightpad)e.rightpad=10;if(!e.xaxispad)e.xaxispad=10;if(!e.yaxispad)e.yaxispad=10;if(!e.xaxish)e.xaxish=40;if(!e.yaxisw)e.yaxisw=65;if(!e.censorticksize)e.censorticksize=6;if(!e.tickfontsize)e.tickfontsize=14;if(!e.labfontsize)e.labfontsize=15}function g(e,t){const s=l(p);const n=0;let a=0;for(const t of e.samplesets){t.color=s(t.name);for(const e of t.steps){a=Math.max(a,e.x)}}e.svg.selectAll("*").remove();const c=e.svg.append("g");for(const t of e.samplesets){t.path=c.append("path").attr("stroke",t.color).attr("fill","none");t.ticks=c.append("path").attr("stroke",t.color).attr("fill","none")}const m=e.svg.append("g");const f=o().domain([0,1]);const y=e.svg.append("g");const g=y.append("text").text("Survival").attr("transform","rotate(-90)");const h=e.svg.append("g");const x=o().domain([n,a]);const v=e.svg.append("text").attr("font-size",e.labfontsize).text(t.plottypes.find((t=>t.key==e.type)).timelabel).attr("x",e.yaxisw+e.yaxispad+e.width/2).attr("y",e.toppad+e.height+e.xaxispad+e.xaxish-3);function b(){c.attr("transform","translate("+(e.yaxisw+e.yaxispad)+","+e.toppad+")");for(const t of e.samplesets){const s=[];const n=["M 0 0"];for(const l of t.steps){n.push("H "+e.width*l.x/a);const t=e.height*(l.y+l.drop);n.push("V "+t);if(l.censored){const t=e.height*l.y;for(const n of l.censored){const l=e.width*n/a;s.push("M "+(l-e.censorticksize/2)+" "+(t-e.censorticksize/2)+" l "+e.censorticksize+" "+e.censorticksize+" M "+(l+e.censorticksize/2)+" "+(t-e.censorticksize/2)+" l -"+e.censorticksize+" "+e.censorticksize)}}}t.path.attr("d",n.join(" "));if(s.length){t.ticks.attr("d",s.join(" "))}}m.attr("transform","translate("+e.yaxisw+","+e.toppad+")");r({axis:m.call(d().scale(f.range([e.height,0])).ticks(Math.floor(e.height/(e.tickfontsize+20)))),showline:1,fontsize:e.tickfontsize});y.attr("transform","translate("+e.labfontsize+","+(e.toppad+e.height/2)+")");g.attr("font-size",e.labfontsize);h.attr("transform","translate("+(e.yaxisw+e.yaxispad)+","+(e.toppad+e.height+e.xaxispad)+")");let t;h.append("text").text(a).attr("font-size",e.tickfontsize).each((function(){t=Math.floor(e.width/(this.getBBox().width+30))})).remove();r({axis:h.call(u().scale(x.range([0,e.width])).ticks(t)),showline:1,fontsize:e.tickfontsize});v.attr("font-size",e.labfontsize).attr("x",e.yaxisw+e.yaxispad+e.width/2).attr("y",e.toppad+e.height+e.xaxispad+e.xaxish-3);e.svg.attr("width",e.yaxisw+e.yaxispad+e.width+e.rightpad).attr("height",e.toppad+e.height+e.xaxispad+e.xaxish)}b();e.resize_handle.on("mousedown",(t=>{t.preventDefault();const s=i(document.body);const n=t.clientX;const a=t.clientY;const l=e.width;const p=e.height;s.on("mousemove",(()=>{e.width=l+t.clientX-n;e.height=p+t.clientY-a;b()}));s.on("mouseup",(()=>{s.on("mousemove",null).on("mouseup",null)}))}));if(Number.isFinite(e.pvalue)){e.legend.d_pvalue.style("display","block").text("P-value: "+e.pvalue)}else{e.legend.d_pvalue.style("display","none")}e.legend.d_curves.selectAll("*").remove();for(const t of e.samplesets){e.legend.d_curves.append("div").style("margin","3px").html('<span style="background:'+t.color+'"> </span> '+t.name+(t.pvalue==undefined?"":", P-value: "+t.pvalue))}}function h(e,t){e.button.text("Loading...").attr("disabled",1);const s={genome:t.genome.name,dslabel:t.mds.label,type:e.type,samplerule:e.samplerule};n("mdssurvivalplot",s).then((s=>{if(s.error)throw s.error;if(!s.samplesets)throw"samplesets[] missing";e.samplesets=s.samplesets;e.pvalue=s.pvalue;g(e,t);if(e.samplerule.set&&e.samplerule.set.mutation){if(e.mutation_count.cnv)e.mutation_count.cnv.html("(n="+s.count_cnv+") ");if(e.mutation_count.loh)e.mutation_count.loh.html("(n="+s.count_loh+") ");if(e.mutation_count.snvindel)e.mutation_count.snvindel.html("(n="+s.count_snvindel+") ");if(e.mutation_count.sv)e.mutation_count.sv.html("(n="+s.count_sv+") ");if(e.mutation_count.fusion)e.mutation_count.fusion.html("(n="+s.count_fusion+") ");if(e.mutation_count.itd)e.mutation_count.itd.html("(n="+s.count_itd+") ")}})).catch((e=>{t.sayerror(e)})).then((()=>{e.button.text("Update plot").attr("disabled",null)}))}function x(e,t){if(!e.samplerule.set)return;const s=e.samplerule.set;if(s.geneexpression){if(!s.bymedian&&!s.byquartile){s.bymedian=1}const n=t.append("div").style("margin-bottom","10px");n.append("span").style("opacity",.5).html("Divide samples by "+s.gene+" expression with ");const a=n.append("select").on("change",(t=>{const s=t.target.options[t.target.selectedIndex];if(s.median){e.samplerule.set.bymedian=1;delete e.samplerule.set.byquartile;l.style("display","none")}else if(s.quartile){e.samplerule.set.byquartile=1;delete e.samplerule.set.bymedian;l.style("display","inline")}}));a.append("option").text("median (group=2)").property("median",1);a.append("option").text("quartile (group=4)").property("quartile",1);const l=n.append("span").style("margin-left","10px");l.append("span").html("Compare each quartile against ").style("opacity",.5);{const t=l.append("select").on("change",(t=>{delete e.samplerule.set.against1st;delete e.samplerule.set.against4th;switch(t.target.selectedIndex){case 0:break;case 1:e.samplerule.set.against1st=1;break;case 2:e.samplerule.set.against4th=1;break}}));t.append("option").text("none");t.append("option").text("first quartile");t.append("option").text("fourth quartile");if(s.against1st){t.node().selectedIndex=1}else if(t.against4th){t.node().selectedIndex=2}}if(s.bymedian){a.node().selectedIndex=0;l.style("display","none")}else if(s.byquartile){a.node().selectedIndex=1;l.style("display","inline")}}if(s.mutation){e.mutation_count={};if(s.snvindel){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.snvindel=n.append("span");if(s.snvindel.name){n.append("span").html("SNV/indel ");const e=n.append("select");e.append("option").text(s.snvindel.name).property("named",1);e.append("option").text("any mutation at "+s.chr+":"+s.start)}else{n.append("span").text("SNV/indel at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop))}}if(s.cnv){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.cnv=n.append("span");n.append("span").html("Copy number variation over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}if(s.loh){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.loh=n.append("span");n.append("span").html("LOH over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}if(s.sv){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.sv=n.append("span");n.append("span").html("SV at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop)+" ")}if(s.fusion){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.fusion=n.append("span");n.append("span").html("Fusion at "+s.chr+":"+(s.start==s.stop?s.start:s.start+"-"+s.stop)+" ")}if(s.itd){const n=t.append("div").style("margin-bottom","20px");e.mutation_count.itd=n.append("span");n.append("span").html("ITD over "+s.chr+":"+s.start+"-"+s.stop+' <span style="font-size:.7em">'+a(s.stop-s.start)+"</span> ")}}}function v(e,t){let s=t.selectAll("div").size();if(s)return;const n=t.append("div").style("margin-bottom","10px");const a=n.append("div").style("margin-left","20px");a.append("div").style("vertical-align","top").style("display","inline-block").style("opacity",.5).html("Enter sample names<br>(one sample per line) ");const l=a.append("textarea").style("display","inline-block").attr("cols","20").attr("rows","10").on("change",(()=>{let t=e.samplerule.full.sampleset=[];const s=l.property("value").trim();if(!s)return;for(const e of s.split("\n")){t.push(e)}}))}export{c as init};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{_ as e}from"./tslib.es6-
|
|
1
|
+
import{_ as e}from"./tslib.es6-c3c2d88f.js";import{P as n}from"./app-b369b169.js";function i(e){switch(e){case"./numeric.binary.ts":return import("./numeric.binary-1f9e93f2.js");case"./numeric.continuous.ts":return import("./numeric.continuous-ebcd0567.js");case"./numeric.discrete.ts":return import("./numeric.discrete-7b97044a.js");case"./numeric.spline.ts":return import("./numeric.spline-1be88f3d.js");case"./numeric.toggle.ts":return import("./numeric.toggle-7fa2a770.js");default:return new Promise((function(n,i){(typeof queueMicrotask==="function"?queueMicrotask:setTimeout)(i.bind(null,new Error("Unknown variable dynamic import: "+e)))}))}}function t(n){return e(this,void 0,void 0,(function*(){const e=n.opts.numericEditMenuVersion;const i=e.length>1?"toggle":e[0];const t=yield o(i);return yield t.getHandler(n)}))}function r(i,t,r=null){var o;return e(this,void 0,void 0,(function*(){if(!((o=i.q)===null||o===void 0?void 0:o.mode))i.q={mode:"continuous"};if(r)n(i.q,r);if(i.q.mode!="continuous"&&!i.term.bins){yield t.setTermBins(i)}return i}))}function o(n){return e(this,void 0,void 0,(function*(){try{return yield i(`./numeric.${n}.ts`)}catch(e){if(e.stack)console.log(e.stack);throw`Type numeric.${n} does not exist [handlers/numeric.ts importSubtype()]`}}))}export{r as fillTW,t as getHandler};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{j as t}from"./termsetting-33ea66f1.js";function n(n){const o=n.sort(((t,n)=>t-n));const s=Math.abs(o[0]-o[o.length-1]);const e=t(s);const r=s>=10?0:s>=1?1:e+2;return n.map((t=>Number(t.toFixed(r))))}export{n};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{d as e}from"./app-
|
|
1
|
+
import{d as e}from"./app-b369b169.js";const t={passive:false};const n={capture:true,passive:false};function s(e){e.stopImmediatePropagation()}function a(e){e.preventDefault();e.stopImmediatePropagation()}function o(t){var s=t.document.documentElement,o=e(t).on("dragstart.drag",a,n);if("onselectstart"in s){o.on("selectstart.drag",a,n)}else{s.__noselect=s.style.MozUserSelect;s.style.MozUserSelect="none"}}function l(t,s){var o=t.document.documentElement,l=e(t).on("dragstart.drag",null);if(s){l.on("click.drag",a,n);setTimeout((function(){l.on("click.drag",null)}),0)}if("onselectstart"in o){l.on("selectstart.drag",null)}else{o.style.MozUserSelect=o.__noselect;delete o.__noselect}}export{n as a,s as b,a as c,o as d,t as n,l as y};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{d as e}from"./app-
|
|
1
|
+
import{d as e}from"./app-b369b169.js";const t=e("body").append("div").style("position","fixed").style("top",`16px`).style("right","10px").style("font-size","1.2em").style("background-color","rgba(250, 250, 250, 0.75)").style("z-index",1e4);let o,i=0;const s=sessionStorage.getItem("hostURL")||window.testHost||"";const n=s.endsWith("/")?`${s}sse`:`${s}/sse`;a();function a(){o=new EventSource(n);let s=0;o.onmessage=o=>{if(i===0)i=o.timeStamp;if(s===0)s=o.timeStamp;const n=JSON.parse(o.data);if(o.timeStamp>s&&n.find((e=>e.reload)));const a=n;const r=t.selectAll(`:scope>div`).data(a,(e=>e.key));r.exit().remove();r.style("color",(e=>e.color||(e.status=="ok"?"green":"red"))).style("border",(e=>`1px solid ${e.color||"#000"}`)).html((e=>`${e.key}: ${e.message}`)).each((function(t){if(t.reload&&o.timeStamp>s)window.location.reload();else if(t.duration){setTimeout((()=>e(this).transition().duration(t.duration).style("opacity",0).remove()),t.duration)}}));r.enter().append("div").style("margin","5px").style("padding","5px").style("border",(e=>`1px solid ${e.color||"#000"}`)).style("color",(e=>e.color||(e.status=="ok"?"green":"red"))).html((e=>`${e.key}: ${e.message}`)).on("click",(function(){})).each((function(t){if(t.reload&&o.timeStamp>s)window.location.reload();else if(t.duration){setTimeout((()=>e(this).transition().duration(t.duration).style("opacity",0).remove()),t.duration)}}))};o.onerror=e=>console.log(e)}document.addEventListener("visibilitychange",(()=>{if(document.hidden)o.close();else if(!o||o.readyState===2)a()}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{_ as e}from"./tslib.es6-
|
|
1
|
+
import{_ as e}from"./tslib.es6-c3c2d88f.js";function t(e){switch(e){case"./numeric.binary.ts":return import("./numeric.binary-1f9e93f2.js");case"./numeric.continuous.ts":return import("./numeric.continuous-ebcd0567.js");case"./numeric.discrete.ts":return import("./numeric.discrete-7b97044a.js");case"./numeric.spline.ts":return import("./numeric.spline-1be88f3d.js");case"./numeric.toggle.ts":return import("./numeric.toggle-7fa2a770.js");default:return new Promise((function(t,n){(typeof queueMicrotask==="function"?queueMicrotask:setTimeout)(n.bind(null,new Error("Unknown variable dynamic import: "+e)))}))}}function n(t){return e(this,void 0,void 0,(function*(){const e=t.opts.numericEditMenuVersion;const n=e.length>1?"toggle":e[0];const i=yield r(n);return yield i.getHandler(t)}))}function i(t,n,i=null){return e(this,void 0,void 0,(function*(){if(!t.q.mode){if(!i||i.mode)t.q.mode="discrete"}const e=t.term.type=="float"||t.term.type=="integer"?"toggle":t.q.mode;const o=yield r(e);return yield o.fillTW(t,n,i)}))}function r(n){return e(this,void 0,void 0,(function*(){try{return yield t(`./numeric.${n}.ts`)}catch(e){if(e.stack)console.log(e.stack);throw`Type numeric.${n} does not exist [handlers/numeric.ts importSubtype()]`}}))}export{i as fillTW,n as getHandler};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{_ as e}from"./tslib.es6-c3c2d88f.js";import{setDensityPlot as t}from"./density-a82a8b1c.js";import{renderBoundaryInclusionInput as i,renderBoundaryInputDivs as n}from"./numeric.discrete-7b97044a.js";import{g as o,a as r}from"./termdb.bins-8b656cc3.js";import{m as d}from"./checkbox-96437f4d.js";import{o as s}from"./termsetting-33ea66f1.js";import{convertViolinData as a}from"./tvs.numeric-0260a825.js";import{v as l}from"./violinRenderer-f7c96a60.js";import"./app-b369b169.js";import"./drag-7b30ba17.js";import"./nodrag-16ad4b03.js";import"./pointer-c7475677.js";import"./toggleButtons-dbdbad01.js";import"./radiobutton-09bff425.js";import"path";import"./tvs.density-f6128793.js";import"./brush-aa175142.js";import"./niceNumLabels-238aabce.js";import"./axis-747c801e.js";import"./line-264f8f9e.js";import"./constant-426a1483.js";import"./basis-3870f5ba.js";function u(o){return{getPillName(e){return s(o,e)},getPillStatus(){var e;return{text:((e=o.usecase)===null||e===void 0?void 0:e.target)=="regression"?o.data.q.lst.find((e=>e.label!=o.data.refGrp)).label:"binary"}},showEditMenu(r){var d,s,f,y;return e(this,void 0,void 0,(function*(){o.num_obj={};o.num_obj.plot_size={width:500,height:100,xpad:10,ypad:20};r.selectAll("*").remove();r.append("div").style("padding","10px").style("text-align","center").html("Getting distribution data ...<br/>");const v=yield o.vocabApi.getViolinPlotData({tw:{term:o.term,q:o.q},filter:o.filter,filter0:(s=(d=o.vocabApi.state)===null||d===void 0?void 0:d.termfilter)===null||s===void 0?void 0:s.filter0,svgw:o.num_obj.plot_size.width/window.devicePixelRatio},(y=(f=o.opts).getBodyParams)===null||y===void 0?void 0:y.call(f));o.num_obj.density_data=a(v);o.dom.num_holder=r;r.selectAll("*").remove();o.dom.density_div=r.append("div");o.vr=new l(o.dom.density_div,o.num_obj.density_data,o.num_obj.plot_size.width,o.num_obj.plot_size.height);o.num_obj.svg=o.vr.svg;o.dom.bins_div=r.append("div").style("padding","4px");m(o);t(o);i(o);o.dom.cutoff_div=o.dom.bins_div.append("div").style("margin","10px");p(o);o.dom.bins_table=o.dom.bins_div.append("div").style("display","flex").style("color","rgb(136, 136, 136)").style("margin","10px").style("width","100%");o.dom.rangeAndLabelDiv=o.dom.bins_table.append("div");n(o,o.q.lst);const b=r.append("div").style("padding","3px 10px");b.append("button").style("margin","5px").html("Apply").on("click",(()=>e(this,void 0,void 0,(function*(){delete o.q.startinclusive;delete o.q.stopinclusive;delete o.q.bin_size;delete o.q.first_bin;delete o.q.last_bin;o.q.lst=c(o);o.numqByTermIdModeType[o.term.id].binary=JSON.parse(JSON.stringify(o.q));o.q.mode="binary";o.runCallback()}))));b.append("button").style("margin","5px").html("Reset").on("click",(()=>{o.q={};delete o.numqByTermIdModeType[o.term.id];u(o).showEditMenu(o.dom.num_holder)}))}))}}}function m(e){const t=e.num_obj.density_data;const i=e.q&&e.q.lst&&e.q.lst.length?e.q.lst[0].stop:undefined;const n=e.numqByTermIdModeType;if(!e.term)throw`Missing .term{} [numeric.binary, setqDefaults()]`;const d=e.term;if(!n[d.id])n[d.id]={};if(!n[d.id].binary){const o=i!==undefined?Number(i):t.maxvalue!=t.minvalue?t.minvalue+(t.maxvalue-t.minvalue)/2:t.maxvalue;n[d.id].binary={mode:"binary",type:"custom-bin",modeBinaryCutoffType:"normal",modeBinaryCutoffPercentile:50,lst:[{startunbounded:true,stopinclusive:true,stop:o.toFixed(e.term.type=="integer"?0:2)},{stopunbounded:true,start:o.toFixed(e.term.type=="integer"?0:2)}]}}if(!e.q||e.q.mode!=="binary")e.q={};const s=JSON.parse(JSON.stringify(n[d.id].binary));e.q=Object.assign(s,e.q);if(e.q.lst){e.q.lst.forEach((t=>{if(!("label"in t))t.label=o(t,e.q);if(!("range"in t))t.range=r(t,e.q)}))}}function p(i){return e(this,void 0,void 0,(function*(){i.dom.cutoff_div.append("span").style("margin-right","5px").style("opacity",.5).text("Boundary value");i.dom.customBinBoundaryInput=i.dom.cutoff_div.append("input").style("width","100px").attr("type","number").style("margin-right","10px").attr("value",i.q.modeBinaryCutoffType=="normal"?i.q.lst[0].stop:i.q.modeBinaryCutoffPercentile).on("change",s);i.dom.customBinBoundaryPercentileCheckbox=d({holder:i.dom.cutoff_div,labeltext:"Use percentile",checked:i.q.modeBinaryCutoffType=="percentile",divstyle:{display:"inline-block"},callback:l});function s(){return e(this,void 0,void 0,(function*(){const e=+this.value;if(i.q.modeBinaryCutoffType=="normal"){a(e)}else if(i.q.modeBinaryCutoffType=="percentile"){if(e<1||e>99){window.alert("Invalid percentile value: enter integer between 1 and 99");return}i.q.modeBinaryCutoffPercentile=e;yield u()}else{throw"invalid modeBinaryCutoffType value"}}))}function a(e){i.q.lst[0].stop=e;i.q.lst[1].start=e;i.q.lst.forEach((e=>{e.label=o(e,i.q);e.range=r(e,i.q)}));if(!i.num_obj)throw`Missing density data [numeric.binary updateUI()]`;t(i);n(i,i.q.lst)}function l(){return e(this,void 0,void 0,(function*(){i.q.modeBinaryCutoffType=i.q.modeBinaryCutoffType=="percentile"?"normal":"percentile";if(i.q.modeBinaryCutoffType=="normal"){const e=i.q.lst[0].stop;i.dom.customBinBoundaryInput.property("value",e);a(e)}else if(i.q.modeBinaryCutoffType=="percentile"){i.dom.customBinBoundaryInput.property("value",i.q.modeBinaryCutoffPercentile);yield u()}else{throw"invalid modeBinaryCutoffType value"}}))}function u(){return e(this,void 0,void 0,(function*(){const e=yield i.opts.vocabApi.getPercentile(i.term.id,[i.q.modeBinaryCutoffPercentile],i.filter);a(e.values[0])}))}}))}function c(e){const t=e.dom.boundaryInput.property("value")=="startinclusive";const i=e.dom.boundaryInput.property("value")=="stopinclusive";const n=e.dom.bins_table.node().querySelectorAll("input");const r=e.q.lst[0].stop;const d=[{startunbounded:true,stop:r,startinclusive:t,stopinclusive:i},{start:r,startinclusive:t,stopinclusive:i,stopunbounded:true}];d.forEach(((t,i)=>{const r=n[i].value;t.label=r?r:o(t,e.q)}));return d}export{u as getHandler};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{_ as t}from"./tslib.es6-c3c2d88f.js";import{o as e}from"./termsetting-33ea66f1.js";import{convertViolinData as i}from"./tvs.numeric-0260a825.js";import{v as o}from"./violinRenderer-f7c96a60.js";import{m as l}from"./checkbox-96437f4d.js";import"./app-b369b169.js";import"path";import"./tvs.density-f6128793.js";import"./brush-aa175142.js";import"./pointer-c7475677.js";import"./nodrag-16ad4b03.js";import"./niceNumLabels-238aabce.js";import"./axis-747c801e.js";import"./line-264f8f9e.js";import"./constant-426a1483.js";import"./basis-3870f5ba.js";function n(n){return{getPillName(t){return e(n,t)},getPillStatus(){return{text:"continuous"}},showEditMenu(e){var a,r,p,c,d;return t(this,void 0,void 0,(function*(){s(n);e.style("padding","5px").selectAll("*").remove();const t=e.append("div");const m={width:500,height:100,xpad:10,ypad:20};const u=yield n.vocabApi.getViolinPlotData({tw:{term:n.term,q:n.q},filter:n.filter,filter0:(r=(a=n.vocabApi.state)===null||a===void 0?void 0:a.termfilter)===null||r===void 0?void 0:r.filter0,svgw:m.width/window.devicePixelRatio},(c=(p=n.opts).getBodyParams)===null||c===void 0?void 0:c.call(p));const v=i(u);const f=new o(t,v,m.width,m.height);f.render();let h;if(((d=n.usecase)===null||d===void 0?void 0:d.target)=="matrix"){h=l({holder:e,labeltext:"Convert to z-score",checked:n.q.convert2ZScore?true:false,divstyle:{display:"inline-block",padding:"3px 10px"},callback:t=>{n.q.convert2ZScore=t;if(t){g.property("value",1);delete n.q.scale}}})}const y=e.append("div").style("display","inline-block");y.append("div").style("display","inline-block").style("padding","3px 10px").html("Scale values");const g=y.append("select").on("change",(t=>{if(!n.q)throw`Missing .q{} [numeric.continuous getHandler()]`;if(t.target.value!="1"){if(h)h.property("checked",false);n.q.scale=Number(t.target.value)}else delete n.q.scale}));g.selectAll("option").data([{html:"No Scaling",value:1},{html:"Per 10",value:10},{html:"Per 100",value:100},{html:"Per 1000",value:1e3}]).enter().append("option").attr("value",(t=>t.value)).html((t=>t.html)).property("selected",(t=>"scale"in n.q&&t.value==n.q.scale));const b=e.append("div").style("padding","3px 10px");if(n.term.type=="survival"){b.append("div").style("font-size",".8em").style("margin","20px 5px 5px 5px").html(`\n\t\t\t\t\t\tDisplay survival outcomes as time to event (${n.term.unit})\n\t\t\t\t\t`)}b.append("button").style("margin","5px").html("Apply").on("click",(()=>{n.q.mode="continuous";n.runCallback()}))}))}}}function s(t){const e=t.numqByTermIdModeType;const i=t.term;if(!e[i.id])e[i.id]={};if(!e[i.id].continuous){e[i.id].continuous={mode:"continuous"}}const o=JSON.parse(JSON.stringify(e[i.id].continuous));t.q=Object.assign(o,t.q)}export{n as getHandler};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{_ as t}from"./tslib.es6-c3c2d88f.js";import{W as e,k as n}from"./app-b369b169.js";import{setDensityPlot as i}from"./density-a82a8b1c.js";import{g as s,a}from"./termdb.bins-8b656cc3.js";import{T as r}from"./toggleButtons-dbdbad01.js";import{m as o}from"./radiobutton-09bff425.js";import{o as l}from"./termsetting-33ea66f1.js";import{convertViolinData as d}from"./tvs.numeric-0260a825.js";import{v as u}from"./violinRenderer-f7c96a60.js";import"./drag-7b30ba17.js";import"./nodrag-16ad4b03.js";import"./pointer-c7475677.js";import"path";import"./tvs.density-f6128793.js";import"./brush-aa175142.js";import"./niceNumLabels-238aabce.js";import"./axis-747c801e.js";import"./line-264f8f9e.js";import"./constant-426a1483.js";import"./basis-3870f5ba.js";function p(e){return{getPillName(t){return l(e,t)},getPillStatus(){var t,n;if(!e.q)throw`Missing .q{} [numeric.discrete getPillStatus()]`;const i=((t=e.q)===null||t===void 0?void 0:t.name)||((n=e.q)===null||n===void 0?void 0:n.reuseId);if(i)return{text:i};if(e.q.type=="regular-bin")return{text:"bin size="+e.q.bin_size};return{text:e.q.lst.length+" bins"}},showEditMenu(n){return t(this,void 0,void 0,(function*(){m(e,n)}))}}}function m(e,n){var s,a,r,o;return t(this,void 0,void 0,(function*(){e.num_obj={};e.num_obj.plot_size={width:500,height:100,xpad:10,ypad:20};n.selectAll("*").remove();n.append("div").style("padding","10px").style("text-align","center").html("Getting distribution data ...<br/>");try{const t=yield e.vocabApi.getViolinPlotData({tw:{term:e.term,q:{mode:"continuous"}},filter:e.filter,filter0:(a=(s=e.vocabApi.state)===null||s===void 0?void 0:s.termfilter)===null||a===void 0?void 0:a.filter0,svgw:e.num_obj.plot_size.width/window.devicePixelRatio,strokeWidth:.2},(o=(r=e.opts).getBodyParams)===null||o===void 0?void 0:o.call(r));e.num_obj.density_data=d(t)}catch(t){console.log(t)}n.selectAll("*").remove();if(e.term.type=="survival"){e.dom.discreteSur_div=n.append("div").style("padding","4px");w(e);return}e.dom.num_holder=n;e.dom.density_div=n.append("div");e.vr=new u(e.dom.density_div,e.num_obj.density_data,e.num_obj.plot_size.width,e.num_obj.plot_size.height);e.num_obj.svg=e.vr.svg;e.dom.bins_div=n.append("div").style("padding","4px");y(e);i(e);v(e);f(e);I(e)}))}function c(t){var e;if(t.q.type=="regular-bin"){if(!t.q.first_bin){t.q.first_bin={stop:Number(t.dom.first_stop_input.property("value"))}}t.q.startinclusive=t.dom.boundaryInput.property("value")=="startinclusive";t.q.stopinclusive=t.dom.boundaryInput.property("value")=="stopinclusive";const n=t.dom.bin_size_input.property("value");t.q.bin_size=Number(n);if(n.includes(".")&&!n.endsWith(".")){t.q.rounding="."+n.split(".")[1].length+"f"}else{t.q.rounding=".0f"}if(t.q.scale)delete t.q.scale;if(Number.isFinite((e=t.q.last_bin)===null||e===void 0?void 0:e.start));else{delete t.q.last_bin}t.numqByTermIdModeType[t.term.id].discrete["regular-bin"]=JSON.parse(JSON.stringify(t.q))}else if(t.term.type!=="survival"){if(t.dom.bins_table.selectAll("input").node().value){t.q.lst=b(t);t.numqByTermIdModeType[t.term.id].discrete["custom-bin"]=JSON.parse(JSON.stringify(t.q))}}t.q.mode="discrete";t.dom.tip.hide();t.runCallback()}function b(t){var e;const n=t.dom.boundaryInput.property("value")=="startinclusive";const i=t.dom.boundaryInput.property("value")=="stopinclusive";const r=t.dom.bins_table.node().querySelectorAll("input");let o;const l=t.dom.customBinBoundaryInput.property("value").split("\n").filter((t=>t!=""&&!isNaN(t)));const d=new Set(l);const u=Array.from(d).map((t=>+t)).sort(((t,e)=>t-e)).map(((e,l)=>{const d={start:+e,startinclusive:n,stopinclusive:i};if(o){delete o.stopunbounded;o.stop=d.start;const e=r[l].value;o.label=e?e:s(o,t.q,t.term.valueConversion);o.range=a(o,t.q)}o=d;return d}));if(u.length==0)return;o.stopunbounded=true;const p=(e=r[u.length])===null||e===void 0?void 0:e.value;o.label=p?p:s(o,t.q,t.term.valueConversion);o.range=a(o,t.q);u.unshift({startunbounded:true,stop:u[0].start,startinclusive:n,stopinclusive:i,label:r[0].value});if(!u[0].label)u[0].label=s(u[0],t.q,t.term.valueConversion);if(!u[0].range)u[0].range=a(u[0],t.q);return u}function y(t){var e,n;const i=t.num_obj.density_data;const r=t.numqByTermIdModeType;const o=t.term;if(!r[o.id])r[o.id]={};if(!r[o.id].discrete){const e=!Number.isFinite(i.minvalue)||!Number.isFinite(i.maxvalue)?0:i.maxvalue!=i.minvalue?i.minvalue+(i.maxvalue-i.minvalue)/2:i.maxvalue;r[o.id].discrete={"regular-bin":t.q&&t.q.type=="regular-bin"?JSON.parse(JSON.stringify(t.q)):t.opts.use_bins_less&&o.bins.less?JSON.parse(JSON.stringify(o.bins.less)):JSON.parse(JSON.stringify(o.bins.default)),"custom-bin":t.q&&t.q.type=="custom-bin"?t.q:{type:"custom-bin",mode:"discrete",lst:[{startunbounded:true,startinclusive:true,stopinclusive:false,stop:+e.toFixed(o.type=="integer"?0:2)},{stopunbounded:true,startinclusive:true,stopinclusive:false,start:+e.toFixed(o.type=="integer"?0:2)}]}};if(!r[o.id].discrete["regular-bin"].type){r[o.id].discrete["regular-bin"].type="regular-bin"}}if(t.q&&!t.q.mode)t.q.mode="discrete";if(!t.q||t.q.mode!=="discrete")t.q={};if(!t.q.type){t.q.type=((n=(e=t.term.bins)===null||e===void 0?void 0:e.default)===null||n===void 0?void 0:n.type)||"regular-bin"}const l=JSON.parse(JSON.stringify(r[o.id].discrete[t.q.type]));t.q=Object.assign(l,t.q);const d="bin_size"in t.q&&t.q.bin_size.toString();if(!t.q.rounding&&typeof d=="string"&&d.includes(".")&&!d.endsWith(".")){const e=d.split(".")[1].length;t.q.rounding="."+e+"f"}if(t.q.lst){t.q.lst.forEach((e=>{if(!("label"in e))e.label=s(e,t.q,t.term.valueConversion);if(!("range"in e))e.range=a(e,t.q)}))}}function v(t){t.dom.boundaryInclusionDiv=t.dom.bins_div.append("div").style("margin-left","5px");t.dom.boundaryInclusionDiv.append("span").style("padding","5px").style("color","rgb(136, 136, 136)").html("Boundary Inclusion");const e='<span style="font-family:Times;font-style:italic">x</span>';t.dom.boundaryInput=t.dom.boundaryInclusionDiv.append("select").style("margin-left","10px").on("change",(function(){const e=t.q.mode=="binary"?t.numqByTermIdModeType[t.term.id].binary:t.numqByTermIdModeType[t.term.id].discrete[t.q.type];e.lst=t.q.lst;if(e.type=="regular-bin"){n(e)}else{e.lst.forEach((e=>{n(e);e.label=s(e,t.q,t.term.valueConversion);e.range=a(e,t.q)}));z(t,e.lst)}function n(e){e.startinclusive=t.dom.boundaryInput.node().selectedIndex==1;e.stopinclusive=t.dom.boundaryInput.node().selectedIndex==0}}));t.dom.boundaryInput.selectAll("option").data([{value:"stopinclusive",html:"start < "+e+" ≤ end"},{value:"startinclusive",html:"start ≤ "+e+" < end"}]).enter().append("option").property("value",(t=>t.value)).property("selected",(e=>{if(t.q.type=="regular-bin")return t.q[e.value]==true;else return t.q.lst[0][e.value]==true})).html((t=>t.html))}function f(e){const n=e.dom.bins_div.append("div").style("margin","10px");if(e.term.bins.default.type=="custom-bin"){e.q.type="custom-bin";y(e);i(e);j(e,n);return}if(e.term.bins.default.type!="regular-bin")throw"self.bins.default.type is neither regular-bin or custom-bin, cannot render ui";const s=[{active:e.q.type=="regular-bin",label:"Same bin size",callback:(n,a)=>t(this,void 0,void 0,(function*(){e.q.type="regular-bin";y(e);i(e);if(!s[0].isInitialized){q(e,a.contentHolder);s[0].isInitialized=true}}))},{active:e.q.type=="custom-bin",label:"Varying bin sizes",callback:(n,a)=>t(this,void 0,void 0,(function*(){e.q.type="custom-bin";y(e);i(e);if(!s[1].isInitialized){j(e,a.contentHolder);s[1].isInitialized=true}}))}];new r({holder:n,tabs:s}).main()}function g(t,e){if(!t.term.valueConversion)return;e.append("div").style("margin-bottom","5px").style("opacity",.6).text(`Note: using values by the unit of ${t.term.valueConversion.fromUnit}.`)}function q(t,e){g(t,e);t.dom.bins_table=e.append("table");_(t,t.dom.bins_table.append("tr"));h(t,t.dom.bins_table.append("tr"));x(t,t.dom.bins_table.append("tr"))}function _(t,n){n.append("td").style("margin","5px").style("opacity",.5).text("Bin Size");const s=t.num_obj.density_data;const a=t.q.bin_size;t.dom.bin_size_input=n.append("td").append("input").attr("type","number").attr("value","rounding"in t.q?e(t.q.rounding)(t.q.bin_size):t.q.bin_size).style("margin-left","15px").style("width","100px").style("color",(()=>t.q.bin_size>Math.abs(s.maxvalue-s.minvalue)?"red":"")).on("change",(e=>{const n=Number(e.target.value);if(n<=0){window.alert("Please enter non-negative bin size.");e.target.value=a;return}if((s.maxvalue-s.minvalue)/n>100){window.alert("Bin size too small. Try setting a bigger value.");e.target.value=a;return}t.q.bin_size=n;t.dom.bin_size_input.style("color",t.q.bin_size>s.maxvalue-s.minvalue?"red":n!=a?"green":"");i(t)}))}function h(t,e){if(!t.q.first_bin)throw"missing q.first_bin";e.append("td").style("margin","5px").style("opacity",.5).text("First Bin Stop");const n=t.num_obj.density_data;const i=t.q.first_bin.stop;t.dom.first_stop_input=e.append("td").append("input").attr("type","number").property("value",i).style("width","100px").style("margin-left","15px").on("change",(e=>{const s=Number(e.target.value);if(s<n.minvalue||s>n.maxvalue){window.alert("First bin stop value out of bound.");e.target.value=i;return}if(t.q.first_bin)t.q.first_bin.stop=s;t.renderBinLines(t,t.q)}));e.append("td").append("div").style("font-size",".6em").style("opacity",.5).style("display",t.num_obj.no_density_data?"none":"block").text("Indicated by left-most red line. Drag to change.")}function x(t,e){const n=!t.q.last_bin||!Number.isFinite(t.q.last_bin.start);e.append("td").style("margin","5px").style("opacity",.5).text("Last Bin Start");const s=t.num_obj.density_data;const a=e.append("td").style("padding-left","15px").style("vertical-align","top");const r=a.append("div");o({holder:r,options:[{label:"Automatic",value:"auto",checked:n},{label:"Fixed",value:"fixed",checked:!n}],callback:e=>{if(e=="auto"){delete t.q.last_bin;l.style("display","none");t.renderBinLines(t,t.q);i(t);return}l.style("display","inline-block");if(!t.q.last_bin)t.q.last_bin={};if(t.dom.last_start_input.property("value")==""){t.dom.last_start_input.property("value",s.maxvalue)}d();i(t)}});const l=e.append("td").append("div").style("display",n?"none":"inline-block");t.dom.last_start_input=l.append("input").attr("type","number").property("value",t.q.last_bin?t.q.last_bin.start:"").style("width","100px").on("change",d);l.append("div").style("font-size",".6em").style("opacity",.5).style("display",t.num_obj.no_density_data?"none":"block").text("Indicated by right-most red line. Drag to change.");function d(){const e=Number(t.dom.last_start_input.property("value"));if(t.q.first_bin&&e<=t.q.first_bin.stop){window.alert("Last bin start cannot be smaller than first bin stop.");t.dom.last_start_input.property("value",s.maxvalue);return}if(e>s.maxvalue){window.alert("Last bin start value out of bound.");t.dom.last_start_input.property("value",s.maxvalue);return}if(!t.q.last_bin)t.q.last_bin={};t.q.last_bin.start=e;t.renderBinLines(t,t.q)}}function j(e,i){g(e,i);e.dom.bins_table=i.append("div").style("display","flex").style("width","100%");const s=e.dom.bins_table.append("div").style("margin-right","20px");e.dom.rangeAndLabelDiv=e.dom.bins_table.append("div");s.append("div").style("margin-bottom","5px").style("color","rgb(136, 136, 136)").text("Bin boundaries");e.dom.customBinBoundaryInput=s.append("textarea").style("width","100px").style("height","70px").text(e.q.lst.slice(1).map((t=>t.start)).join("\n")).on("change",a).on("keyup",(function(i){return t(this,void 0,void 0,(function*(){if(!n(i)&&i.key!=8)return;if(!e.dom.bins_table.selectAll("input").node().value)return;a.call(this)}))}));s.append("div").style("font-size",".6em").style("margin-left","1px").style("color","#858585").html("Enter numeric values </br>seperated by ENTER");function a(){const t=e.dom.bins_table.selectAll("input");t.property("value","");const n=b(e);if(n==undefined){return}const i=e.numqByTermIdModeType[e.term.id].discrete[e.q.type];if(e.q.hiddenValues)i.hiddenValues=e.q.hiddenValues;if(r(n,i.lst)){i.lst=n;e.renderBinLines(e,i)}z(e,i.lst);e.q.lst=i.lst}function r(t,e){if(t.length!=e.length)return true;if(Object.keys(t[0]).length!==Object.keys(e[0]).length)return true;for(const[n,i]of e.entries()){for(const e of Object.keys(i)){if(i[e]&&i[e]!==t[n][e]){return true}}}return false}z(e,e.q.lst)}function z(t,e){const n=t.dom.rangeAndLabelDiv;n.selectAll("*").remove();const i=n.append("div").style("display","grid").style("grid-template-columns","auto auto").style("column-gap","20px").style("align-items","center");i.append("div").style("margin-bottom","3px").style("color","rgb(136, 136, 136)").text("Range");i.append("div").style("margin-bottom","3px").style("color","rgb(136, 136, 136)").text("Bin label");for(const[t,n]of e.entries()){i.append("div").attr("name","range").html(n.range);i.append("div").append("input").attr("type","text").style("margin","2px 0px").property("value",n.label).on("change",(function(){e[t].label=this.value}))}t.dom.customBinRanges=t.dom.bins_table.selectAll('div[name="range"]').data(e);t.dom.customBinLabelInput=t.dom.bins_table.selectAll("input").data(e)}function I(t){const e=t.dom.bins_div.append("div");e.append("button").style("margin","5px").html("Apply").on("click",(()=>c(t)));e.append("button").style("margin","5px").html("Reset").on("click",(()=>{t.q={};delete t.numqByTermIdModeType[t.term.id];m(t,t.dom.num_holder)}))}function w(t){const e=t.dom.discreteSur_div.append("div");e.append("div").style("font-size",".8em").style("margin","5px").html(`\n\t\t\tDisplay survival outcomes as exit codes <br>\n\t\t`);const n=t.dom.discreteSur_div.append("div");n.append("button").style("margin","5px").html("Apply").on("click",(()=>c(t)))}export{p as getHandler,v as renderBoundaryInclusionInput,z as renderBoundaryInputDivs};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{_ as t}from"./tslib.es6-c3c2d88f.js";import{setDensityPlot as e}from"./density-a82a8b1c.js";import{k as n}from"./app-b369b169.js";import{o}from"./termsetting-33ea66f1.js";import{convertViolinData as i}from"./tvs.numeric-0260a825.js";import{v as s}from"./violinRenderer-f7c96a60.js";import"./termdb.bins-8b656cc3.js";import"./drag-7b30ba17.js";import"./nodrag-16ad4b03.js";import"./pointer-c7475677.js";import"path";import"./tvs.density-f6128793.js";import"./brush-aa175142.js";import"./niceNumLabels-238aabce.js";import"./axis-747c801e.js";import"./line-264f8f9e.js";import"./constant-426a1483.js";import"./basis-3870f5ba.js";function l(n){return{getPillName(t){return o(n,t)},getPillStatus(){return{text:"cubic spline"}},showEditMenu(o){var l,p,a,m;return t(this,void 0,void 0,(function*(){n.num_obj={};n.num_obj.plot_size={width:500,height:100,xpad:10,ypad:20};o.selectAll("*").remove();o.append("div").style("padding","10px").style("text-align","center").html("Getting distribution data ...<br/>");try{const t=yield n.vocabApi.getViolinPlotData({tw:{term:n.term,q:n.q},filter:n.filter,filter0:(p=(l=n.vocabApi.state)===null||l===void 0?void 0:l.termfilter)===null||p===void 0?void 0:p.filter0,svgw:n.num_obj.plot_size.width/window.devicePixelRatio},(m=(a=n.opts).getBodyParams)===null||m===void 0?void 0:m.call(a));n.num_obj.density_data=i(t)}catch(t){console.log(t)}o.selectAll("*").remove();n.dom.density_div=o.append("div");n.vr=new s(n.dom.density_div,n.num_obj.density_data,n.num_obj.plot_size.width,n.num_obj.plot_size.height);n.num_obj.svg=n.vr.svg;n.dom.num_holder=o;n.dom.knots_div=o.append("div").style("padding","5px");yield d(n);e(n);r(n);y(n)}))}}}function d(e){return t(this,void 0,void 0,(function*(){const t=e.numqByTermIdModeType;const n=e.term;if(!t[n.id])t[n.id]={};if(!t[n.id]["spline"]){t[n.id]["spline"]={mode:"spline",knots:[]}}const o=JSON.parse(JSON.stringify(t[n.id]["spline"]));e.q=Object.assign(o,e.q);if(!e.q.knots.length){const t=4;yield u(e,t);e.numqByTermIdModeType[e.term.id]["spline"].knots=e.q.knots}}))}function r(t){const e=t.dom.knots_div;p(t,e);c(t,e)}function p(e,o){e.dom.custom_knots_div=o.append("div");e.dom.custom_knots_div.append("div").style("display","inline-block").style("vertical-align","top").style("padding","3px 15px").style("font-weight","normal").style("color","rgb(136, 136, 136)").html("Knots");e.dom.customKnotsInput=e.dom.custom_knots_div.append("div").style("display","inline-block").style("padding","3px 15px").style("padding-left","5px").append("textarea").style("height","100px").style("width","100px").text(e.q.knots.map((t=>t.value)).join("\n")).on("change",i).on("keyup",(function(e){return t(this,void 0,void 0,(function*(){if(!n(e)&&e.key!=8)return;i.call(this)}))}));e.dom.custom_knots_div.append("div").style("display","inline-block").style("vertical-align","top").style("font-size",".7em").style("padding","3px 15px").style("padding-left","5px").style("color","rgb(136, 136, 136)").html(`Enter knot values, one knot per line.</br> \n\t\t\tAdjust knot by dragging on the vertical line.</br>\n\t\t \tOr autocompute knots from below.`);function i(){const t=m(e);const n=e.q;if(s(t,n.knots)){n.knots=t;e.renderBinLines(e,n)}e.q=n}function s(t,e){if(t.length!=e.length)return true;if(Object.keys(t[0]).length!==Object.keys(e[0]).length)return true;for(const[n,o]of e.entries()){for(const e of Object.keys(o)){if(o[e]&&o[e]!==t[n][e]){return true}}}return false}}function a(t){t.dom.customKnotsInput.property("value",t.q.knots.map((t=>t.value)).join("\n"))}function m(t){const e=t.dom.customKnotsInput.property("value").split("\n").filter((t=>t!="")).map((t=>+t)).sort(((t,e)=>t-e)).map((t=>{const e={value:+t};return e}));return e}function c(n,o){const i=4;const s=i;n.dom.knot_select_div=o.append("div");n.dom.knot_select_div.append("div").style("display","inline-block").style("margin-left","15px").style("color","rgb(136, 136, 136)").html("Autocompute");const l=n.dom.knot_select_div.append("select").style("margin-left","10px").style("margin-bottom","7px");for(let t=s-1;t<s+5;t++){l.append("option").attr("value",t).html(t)}const d=n.q.knots&&n.q.knots.length?n.q.knots.length:s;l.node().value=d;n.dom.knot_select_div.append("div").style("display","inline-block").style("margin-left","10px").style("color","rgb(136, 136, 136)").html("knots");n.dom.knot_select_div.append("button").style("margin","15px").html("Compute").on("click",(()=>t(this,void 0,void 0,(function*(){const t=Number.parseInt(l.node().value);let o=Number.parseInt(l.node().value);while(n.q.knots.length!=t){yield u(n,o);o=o+1}a(n);e(n)}))));n.dom.knot_select_div.append("div").style("display","inline-block").style("font-size",".7em").style("padding","3px 15px").style("padding-left","5px").style("color","rgb(136, 136, 136)").html("Will overwrite existing values.")}function u(e,n){return t(this,void 0,void 0,(function*(){const t=n-2;const o=e.term;const i=e.q.knots=[];const s=[5];const l=(90/(t+1)).toFixed(0);for(let e=1;e<t+1;e++){s.push(e*l)}s.push(95);const d=yield v(e,s);for(const t of d){i.push({value:t.toFixed(o.type=="integer"?0:2)})}}))}function v(e,n){return t(this,void 0,void 0,(function*(){const t=yield e.vocabApi.getPercentile(e.term.id,n,e.filter);if(t.error||!t.values.length||!t.values.every((t=>Number.isFinite(t))))throw"cannot get median value: "+(t.error||"no data");const o=[...new Set(t.values)];return o}))}function y(t){const e=t.dom.knots_div.append("div");e.append("button").style("margin","5px").html("Apply").on("click",(()=>f(t)));e.append("button").style("margin","5px").html("Reset").on("click",(()=>{t.q={};delete t.numqByTermIdModeType[t.term.id];t.handler=l(t);t.handler.showEditMenu(t.dom.num_holder)}))}function f(t){t.q.mode="spline";t.dom.tip.hide();t.runCallback()}export{l as getHandler};
|