diff --git a/drugstone-test.html b/drugstone-test.html index 520fdfe8bcdfee95ec54526ffaf9f25eac11a0b7..d0db94ff7ccdb95df933d2973cf36ab3a361a499 100644 --- a/drugstone-test.html +++ b/drugstone-test.html @@ -1,17 +1,22 @@ <html lang="en"> <head> <link rel="stylesheet" type="text/css" href="src/stylesheets/theme.css"> - <script src="https://cdn.jsdelivr.net/gh/AndiMajore/drugstone-releases@0.7.9-rc3/uhh/drugsTone.js"></script> -<!-- <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/AndiMajore/drugstone-releases@0.7.9-rc3/uhh/styles.css">--> - <link rel="stylesheet" type="text/css" href="./drugsTone-build/styles.css"> + <script src="https://cdn.jsdelivr.net/gh/AndiMajore/drugstone-releases@0.8.2-rc2/remote/drugsTone.js"></script> + <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/AndiMajore/drugstone-releases@0.8.2-rc2/remote/styles.css"> +<!-- <link rel="stylesheet" type="text/css" href="./drugsTone-build/styles.css">--> </head> <body> <div style="height: 700px; width: 1300px;"> <network-expander - id='example-drugst.one' + id='drugstOne' config='{"nodeGroups":{"patient":{"type":"patient","color":"#000000","font":{"color":"#f0f0f0"},"groupName":"Patient","shape":"image","image":"https://static.thenounproject.com/png/22780-200.png","shadow":true},"condition":{"type":"condition","color":"#000000","font":{"color":"#f0f0f0"},"groupName":"Condition","shape":"text","shadow":false},"important":{"type":"gene","color":"#ff881f","font":{"color":"#f0f0f0"},"groupName":"Important Gene","shape":"star","shadow":true},"gene":{"type":"gene","color":"#4da300","font":{"color":"#f0f0f0"},"groupName":"Gene","shape":"circle","shadow":true}},"edgeGroups":{"genotype":{"color":"white","groupName":"Relevant Gene","shadow":false},"has-condition":{"color":"white","groupName":"Has Condition","dashes":[2,2],"shadow":false},"ggi":{"color":"#ffffff","groupName":"Interaction","dashes":[3,2],"shadow":false}},"identifier":"symbol","title":"Breast cancer example network","nodeShadow":false,"edgeShadow":false,"showLegend":true}' - network='{"nodes":[{"id":"patient-1","group":"patient","x":592,"y":446},{"id":"patient-2","group":"patient","x":235,"y":87},{"id":"patient-3","group":"patient","x":105,"y":369},{"id":"ATM","label":"ATM","group":"gene","x":289,"y":242},{"id":"BARD1","label":"BARD1","group":"gene","x":44,"y":250},{"id":"BRCA1","label":"BRCA1","group":"gene","x":466,"y":576},{"id":"BRCA2","label":"BRCA2","group":"gene","x":507,"y":285},{"id":"BRIP1","label":"BRIP1","group":"gene","x":54,"y":474},{"id":"CHEK2","label":"CHEK2","group":"gene","x":216,"y":590},{"id":"CDH1","label":"CDH1","group":"gene","x":320,"y":-57},{"id":"NF1","label":"NF1","group":"gene","x":481,"y":111},{"id":"NBN","label":"NBN","group":"gene","x":-57,"y":314},{"id":"PALB2","label":"PALB2","group":"gene","x":450,"y":190},{"id":"PTEN","label":"PTEN","group":"important","x":305,"y":494},{"id":"RAD51C","label":"RAD51C","group":"gene","x":182,"y":-90},{"id":"RAD51D","label":"RAD51D","group":"gene","x":368,"y":73},{"id":"STK11","label":"STK11","group":"gene","x":686,"y":330},{"id":"TP53","label":"TP53","group":"important","x":333,"y":316},{"id":"subtype-1","label":"Subtype 1","group":"condition","x":556,"y":171},{"id":"subtype-2","label":"Subtype 2","group":"condition","x":-87,"y":221}],"edges":[{"from":"BRCA1","to":"BRCA2","group":"ggi"},{"from":"ATM","to":"BARD1","group":"ggi"},{"from":"BRCA1","to":"CHEK2","group":"ggi"},{"from":"RAD51C","to":"RAD51D","group":"ggi"},{"from":"STK11","to":"TP53","group":"ggi"},{"from":"TP53","to":"PALB2","group":"ggi"},{"from":"TP53","to":"RAD51D","group":"ggi"},{"from":"TP53","to":"NF1","group":"ggi"},{"from":"TP53","to":"BRCA1","group":"ggi"},{"from":"TP53","to":"BRCA2","group":"ggi"},{"from":"PTEN","to":"BRCA1","group":"ggi"},{"from":"PTEN","to":"BRCA2","group":"ggi"},{"from":"TP53","to":"PTEN","group":"ggi"},{"from":"ATM","to":"PTEN","group":"ggi"},{"from":"CDH1","to":"RAD51D","group":"ggi"},{"from":"CDH1","to":"PALB2","group":"ggi"},{"from":"NBN","to":"BRIP1","group":"ggi"},{"from":"BRIP1","to":"PTEN","group":"ggi"},{"from":"patient-1","to":"BRCA1","group":"genotype"},{"from":"patient-1","to":"TP53","group":"genotype"},{"from":"patient-1","to":"BRCA2","group":"genotype"},{"from":"patient-1","to":"PTEN","group":"genotype"},{"from":"patient-2","to":"TP53","group":"genotype"},{"from":"patient-2","to":"NF1","group":"genotype"},{"from":"patient-2","to":"BARD1","group":"genotype"},{"from":"patient-3","to":"TP53","group":"genotype"},{"from":"patient-3","to":"PTEN","group":"genotype"},{"from":"patient-3","to":"NBN","group":"genotype"},{"from":"patient-1","to":"subtype-1","group":"has-condition"},{"from":"patient-2","to":"subtype-1","group":"has-condition"},{"from":"patient-3","to":"subtype-2","group":"has-condition"}]}'> + network='{"nodes":[{"id":"patient-1","group":"patient","x":592,"y":446},{"id":"patient-2","group":"patient","x":235,"y":87},{"id":"patient-3","group":"patient","x":105,"y":369},{"id":"ATM","label":"ATM","group":"gene","x":289,"y":242},{"id":"BARD1","label":"BARD1","group":"gene","x":44,"y":250},{"id":"BRCA1","label":"BRCA1","group":"gene","x":466,"y":576},{"id":"BRCA2","label":"BRCA2","group":"gene","x":507,"y":285},{"id":"BRIP1","label":"BRIP1","group":"gene","x":54,"y":474},{"id":"CHEK2","label":"CHEK2","group":"gene","x":216,"y":590},{"id":"CDH1","label":"CDH1","group":"gene","x":320,"y":-57},{"id":"NF1","label":"NF1","group":"gene","x":481,"y":111},{"id":"NBN","label":"NBN","group":"gene","x":-57,"y":314},{"id":"PALB2","label":"PALB2","group":"gene","x":450,"y":190},{"id":"PTEN","label":"PTEN","group":"important","x":305,"y":494},{"id":"RAD51C","label":"RAD51C","group":"gene","x":182,"y":-90},{"id":"RAD51D","label":"RAD51D","group":"gene","x":368,"y":73},{"id":"STK11","label":"STK11","group":"gene","x":686,"y":330},{"id":"TP53","label":"TP53","group":"important","x":333,"y":316},{"id":"subtype-1","label":"Subtype 1","group":"condition","x":556,"y":171},{"id":"subtype-2","label":"Subtype 2","group":"condition","x":-87,"y":221}],"edges":[{"from":"BRCA1","to":"BRCA2","group":"ggi"},{"from":"ATM","to":"BARD1","group":"ggi"},{"from":"BRCA1","to":"CHEK2","group":"ggi"},{"from":"RAD51C","to":"RAD51D","group":"ggi"},{"from":"STK11","to":"TP53","group":"ggi"},{"from":"TP53","to":"PALB2","group":"ggi"},{"from":"TP53","to":"RAD51D","group":"ggi"},{"from":"TP53","to":"NF1","group":"ggi"},{"from":"TP53","to":"BRCA1","group":"ggi"},{"from":"TP53","to":"BRCA2","group":"ggi"},{"from":"PTEN","to":"BRCA1","group":"ggi"},{"from":"PTEN","to":"BRCA2","group":"ggi"},{"from":"TP53","to":"PTEN","group":"ggi"},{"from":"ATM","to":"PTEN","group":"ggi"},{"from":"CDH1","to":"RAD51D","group":"ggi"},{"from":"CDH1","to":"PALB2","group":"ggi"},{"from":"NBN","to":"BRIP1","group":"ggi"},{"from":"BRIP1","to":"PTEN","group":"ggi"},{"from":"patient-1","to":"BRCA1","group":"genotype"},{"from":"patient-1","to":"TP53","group":"genotype"},{"from":"patient-1","to":"BRCA2","group":"genotype"},{"from":"patient-1","to":"PTEN","group":"genotype"},{"from":"patient-2","to":"TP53","group":"genotype"},{"from":"patient-2","to":"NF1","group":"genotype"},{"from":"patient-2","to":"BARD1","group":"genotype"},{"from":"patient-3","to":"TP53","group":"genotype"},{"from":"patient-3","to":"PTEN","group":"genotype"},{"from":"patient-3","to":"NBN","group":"genotype"},{"from":"patient-1","to":"subtype-1","group":"has-condition"},{"from":"patient-2","to":"subtype-1","group":"has-condition"},{"from":"patient-3","to":"subtype-2","group":"has-condition"}]}' + task-id='EkxzkoNW7KjWc7Kq9kLQClfnCy5GI1ht' + > </network-expander> + <script type="text/javascript"> + document.getElementById("drugstOne").addEventListener("taskEvent",(event)=>{console.log(event.detail)}) + </script> </div> </body> </html> diff --git a/releases/release_tag.sh b/releases/release_tag.sh index 1edfae826a9a6f22ba0068ba993b5a14e1a30a2c..9145eb4f34a3729129e361c7e76e3d339f5147b9 100755 --- a/releases/release_tag.sh +++ b/releases/release_tag.sh @@ -33,11 +33,11 @@ echo "Updating Repo..." #cd ../ #cp frontend/drugsTone-build/* drugstone-releases/dev/ # -#echo "Building remote..." -#cd frontend || exit -#npm run build:netex-remote -#cd ../ -#cp frontend/drugsTone-build/* drugstone-releases/remote/ +echo "Building remote..." +cd frontend || exit +npm run build:netex-remote +cd ../ +cp frontend/drugsTone-build/* drugstone-releases/remote/ echo "Building v-server..." diff --git a/src/app/components/analysis-panel/analysis-panel.component.ts b/src/app/components/analysis-panel/analysis-panel.component.ts index 504919c7c7583547f7acf9cc2444051a0eb91035..a92a38c3401040862957a29877edc271b9c06ca4 100644 --- a/src/app/components/analysis-panel/analysis-panel.component.ts +++ b/src/app/components/analysis-panel/analysis-panel.component.ts @@ -70,7 +70,6 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { for (const key of Object.keys(config)) { this.myConfig[key] = config[key]; } - console.log(this.myConfig) } @Output() tokenChange = new EventEmitter<string | null>(); @Output() showDetailsChange = new EventEmitter<Wrapper>(); @@ -166,7 +165,6 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { if (this.task && this.task.info.done) { this.result = await this.netex.getTaskResult(this.token); - console.log(this.result) const nodeAttributes = this.result.nodeAttributes || {}; this.seedMap = nodeAttributes.isSeed || {}; @@ -495,7 +493,6 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { nodeDetails.group = nodeDetails.group ? nodeDetails.group : 'default'; nodeDetails.label = nodeDetails.label ? nodeDetails.label : nodeDetails[identifier] } - // IMPORTANT we set seeds to "selected" and not to seeds. The user should be inspired to run // further analysis and the button function can be used to highlight seeds // option to use scores[node] as gradient, but sccores are very small nodes.push(NetworkSettings.getNodeStyle(nodeDetails as Node, config, false, false, 1)) @@ -517,7 +514,7 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { } else { this.legendContext = "drug"; } - + } else if (target === 'drug-target') { if (this.highlightSeeds) { this.legendContext = "drugTargetAndSeeds"; @@ -525,7 +522,7 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { this.legendContext = 'drugTarget' } } else { - throw `Could not set legend context based on ${target}.` + throw `Could not set legend context based on ${target}.` } } @@ -625,7 +622,6 @@ export class AnalysisPanelComponent implements OnInit, OnChanges { this.tableSelectedProteins = e; const addItems = []; const removeItems = []; - for (const i of this.tableSelectedProteins) { const wrapper = getWrapperFromNode(i); if (oldSelection.indexOf(i) === -1) { diff --git a/src/app/dialogs/launch-analysis/launch-analysis.component.ts b/src/app/dialogs/launch-analysis/launch-analysis.component.ts index 526c084f0e3c395c1bc328692f8a80fd14a97fc2..38ef3ecd0f03eec458368d5dba22a0e63ce6937e 100644 --- a/src/app/dialogs/launch-analysis/launch-analysis.component.ts +++ b/src/app/dialogs/launch-analysis/launch-analysis.component.ts @@ -28,6 +28,8 @@ export class LaunchAnalysisComponent implements OnInit, OnChanges { public config: IConfig; @Output() public showChange = new EventEmitter<boolean>(); + @Output() + public taskEvent = new EventEmitter<object>(); public algorithm: AlgorithmType | QuickAlgorithmType; @@ -173,7 +175,9 @@ export class LaunchAnalysisComponent implements OnInit, OnChanges { } parameters.hub_penalty = this.multisteinerHubPenalty; } - await this.analysis.startAnalysis(this.algorithm, this.target, parameters); + const token = await this.analysis.startAnalysis(this.algorithm, this.target, parameters); + const object = {taskId: token, algorithm: this.algorithm, target: this.target, params: parameters}; + this.taskEvent.emit(object); } } diff --git a/src/app/pages/explorer-page/explorer-page.component.html b/src/app/pages/explorer-page/explorer-page.component.html index 14720f3ded4a84fd2ecbb8a7dc5158b1b185a16c..e459358cb0b1f6b9544660c35f1bf15da205ed76 100644 --- a/src/app/pages/explorer-page/explorer-page.component.html +++ b/src/app/pages/explorer-page/explorer-page.component.html @@ -1,14 +1,14 @@ <div id="appWindow" - [style.color]="textColor" (window:resize)="onResize($event)" > - <div class="is-hidden-mobile fullheight"> + <div class="is-hidden-mobile fullheight" id="appContainer"> <app-launch-analysis [(show)]="showAnalysisDialog" [target]="analysisDialogTarget" [config]="myConfig" [inputNetwork]="{ nodes: proteins, edges: edges }" + (taskEvent)="emitTaskEvent($event)" > </app-launch-analysis> diff --git a/src/app/pages/explorer-page/explorer-page.component.ts b/src/app/pages/explorer-page/explorer-page.component.ts index 7e7c2ef1826d7a97b38999ef3c766531a680e778..b1bbb39dbb65b2a60ca9fbd97948a582b7f6ecb3 100644 --- a/src/app/pages/explorer-page/explorer-page.component.ts +++ b/src/app/pages/explorer-page/explorer-page.component.ts @@ -4,8 +4,9 @@ import { ElementRef, HostListener, Input, - OnInit, + OnInit, Output, ViewChild, + EventEmitter, ViewEncapsulation } from '@angular/core'; import { @@ -27,7 +28,7 @@ import {defaultConfig, EdgeGroup, IConfig, InteractionDatabase, NodeGroup} from import {NetexControllerService} from 'src/app/services/netex-controller/netex-controller.service'; import {downLoadFile, removeDuplicateObjectsFromList} from '../../utils' import * as merge from 'lodash/fp/merge'; -import { AnalysisPanelComponent } from 'src/app/components/analysis-panel/analysis-panel.component'; +import {AnalysisPanelComponent} from 'src/app/components/analysis-panel/analysis-panel.component'; // import * as 'vis' from 'vis-network'; // import {DataSet} from 'vis-data'; @@ -60,9 +61,9 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { return; } - // addd settings to config + // add settings to config const configObj = JSON.parse(config); - this.myConfig = merge(this.myConfig, configObj) + this.myConfig = merge(this.myConfig, configObj); // update Drugst.One according to the settings // check if config updates affect network @@ -115,6 +116,9 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { this.createNetwork(); } + @Output() + public taskEvent = new EventEmitter<object>(); + public get network() { return this.networkJSON; } @@ -159,6 +163,12 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { public selectedAnalysisToken: string | null = null; + @Input() set taskId(token: string | null) { + if(token ==null || token.length==0) + this.selectedAnalysisToken=null + this.selectedAnalysisToken = token; + } + public currentDataset = []; public currentViewProteins: Node[]; @@ -174,13 +184,10 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { // keys are node netexIds public expressionMap: NodeAttributeMap = undefined; - @Input() - public textColor = 'red'; - @ViewChild('network', {static: false}) networkEl: ElementRef; @ViewChild('networkWithLegend', {static: false}) networkWithLegendEl: ElementRef; - @ViewChild(AnalysisPanelComponent, { static: false }) + @ViewChild(AnalysisPanelComponent, {static: false}) private analysisPanel: AnalysisPanelComponent; constructor( @@ -216,7 +223,7 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { false, selected, 1.0 - ) + ) nodeStyled.x = pos[wrapper.id].x; nodeStyled.y = pos[wrapper.id].y; updatedNodes.push(nodeStyled); @@ -317,6 +324,7 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { this.smallStyle = this.windowWidth < 1250; } + private zoomToNode(id: string) { // get network object, depending on whether analysis is open or not const network = this.selectedAnalysisToken ? this.analysisPanel.network : this.networkInternal; @@ -467,18 +475,18 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { public updateAdjacentDrugs(bool: boolean) { this.adjacentDrugs = bool; if (this.adjacentDrugs) { - this.netex.adjacentDrugs(this.myConfig.interactionDrugProtein, this.nodeData.nodes).subscribe(response => { - for (const interaction of response.pdis) { - const edge = {from: interaction.protein, to: interaction.drug}; - this.adjacentDrugEdgesList.push(mapCustomEdge(edge, this.myConfig)); - } - for (const drug of response.drugs) { - drug.group = 'foundDrug'; - drug.id = getDrugNodeId(drug) - this.adjacentDrugList.push(mapCustomNode(drug, this.myConfig)) - } - this.nodeData.nodes.add(this.adjacentDrugList); - this.nodeData.edges.add(this.adjacentDrugEdgesList); + this.netex.adjacentDrugs(this.myConfig.interactionDrugProtein, this.nodeData.nodes).subscribe(response => { + for (const interaction of response.pdis) { + const edge = {from: interaction.protein, to: interaction.drug}; + this.adjacentDrugEdgesList.push(mapCustomEdge(edge, this.myConfig)); + } + for (const drug of response.drugs) { + drug.group = 'foundDrug'; + drug.id = getDrugNodeId(drug) + this.adjacentDrugList.push(mapCustomNode(drug, this.myConfig)) + } + this.nodeData.nodes.add(this.adjacentDrugList); + this.nodeData.edges.add(this.adjacentDrugEdgesList); }) this.legendContext = 'adjacentDrugs' } else { @@ -658,7 +666,7 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { false, this.analysis.inSelection(getWrapperFromNode(item)), 1.0 - ) + ) ) updatedNodes.push(node); } @@ -712,4 +720,7 @@ export class ExplorerPageComponent implements OnInit, AfterViewInit { this.currentViewSelectedTissue = this.selectedTissue; } + emitTaskEvent(eventObject: object) { + this.taskEvent.emit(eventObject); + } } diff --git a/src/app/services/analysis/analysis.service.ts b/src/app/services/analysis/analysis.service.ts index 541905eacdd6b0fcc773e5e74f6a870a46f4e8b4..86b584b1a3efaa7d5e7aeeafd542f6b562e002b9 100644 --- a/src/app/services/analysis/analysis.service.ts +++ b/src/app/services/analysis/analysis.service.ts @@ -289,7 +289,7 @@ export class AnalysisService { position: 'top-center', animate: {in: 'fadeIn', out: 'fadeOut'} }); - return; + return ''; } const resp = await this.http.post<any>(`${environment.backend}task/`, { algorithm, @@ -300,6 +300,7 @@ export class AnalysisService { this.tokens.push(resp.token); localStorage.setItem(`netex-tokens-${window.location.host}`, JSON.stringify(this.tokens)); this.startWatching(); + return resp.token; } public isLaunchingQuick(): boolean { diff --git a/src/index.html b/src/index.html index b7e2e5dd6f0f46146f612ccf5d3d1123a3de6a43..f8cd409dff8580f8152bb81890b5125f961abe1e 100644 --- a/src/index.html +++ b/src/index.html @@ -6,6 +6,7 @@ <base href="/"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <script type="text/javascript" src="https://unpkg.com/vis-network/standalone/umd/vis-network.min.js"></script> +<!-- <link rel="stylesheet" type="text/css" href="./stylesheets/theme.css">--> </head> <body> @@ -28,6 +29,10 @@ <button onclick=changeConfigStr('{"legendPos":"left"}') > Legend to Left </button> <br> <button onclick=changeConfigStr('{"legendPos":"right"}') > Legend to Right </button> <br> <button onclick=changeConfigStr('{"interactions":"omnipath"}') >Get Omnipath Interactions </button> <br> +<button onclick="initTaskEventListener()">Init Task-Eventlistener</button> <br> + +<input id="taskID" type="text" /> <button onclick=loadTaskID(document.getElementById("taskID").value) >Load TaskID</button> <br> + <!--<input type="checkbox" onclick=changeConfigStr('{"showSimpleAnalysis":'+this.checked+'}') checked /> Show SimpleAnalysis<br>--> @@ -35,7 +40,7 @@ <button onclick="setNetwork('netexp1')">Add nodes</button> -<div style="height: 700px; width: 1300px"> +<div style="width: 1300px"> <network-expander id="netexp1" config='{ @@ -53,7 +58,6 @@ ] }' - style="height: 100%; width: 100vw; display: block;" ></network-expander> </div> @@ -94,6 +98,11 @@ netexp.setAttribute('config', config); } + function initTaskEventListener(){ + document.getElementsByTagName("network-expander")[0].addEventListener("taskEvent",(event)=>{console.log(event.detail)}) + } + + function setNetwork(nw) { const netexp = document.getElementById(nw); @@ -123,6 +132,13 @@ } } + function loadTaskID(token){ + console.log("Trying to load "+token) + const netexp = document.getElementById('netexp1'); + netexp.setAttribute('task-id', token); + + } + </script> </body> </html> diff --git a/src/stylesheets/styles.scss b/src/stylesheets/styles.scss index 6a40599b3df5c14b56df45017d72d9fb3b265849..be9b0045fa46aec5ef903e70a6b6f77bbaf1aed9 100644 --- a/src/stylesheets/styles.scss +++ b/src/stylesheets/styles.scss @@ -7,7 +7,7 @@ @import "primeng"; #appWindow { - height: 100%; + height: var(--drgstn-height, 500px); margin: 0; font-family: Roboto, "Helvetica Neue", sans-serif; @@ -61,10 +61,8 @@ padding: 0; } - .tissue-dropdown { padding: 5px; - background-color: rgba(255.0, 255.0, 255.0, 0.85); .scroll-area { max-height: 600px; diff --git a/src/stylesheets/theme-styles.scss b/src/stylesheets/theme-styles.scss index 55967b6c8174a346f13780dd0f4a73f8eec46605..26b914fe4c8761a2c1801afc871631d2036d0790 100644 --- a/src/stylesheets/theme-styles.scss +++ b/src/stylesheets/theme-styles.scss @@ -106,6 +106,13 @@ color: var(--drgstn-primary) !important; } + a.dropdown-item:hover, button.dropdown-item:hover{ + background-color: var(--drgstn-panel-secondary) + } + + .tissue-dropdown { + background-color: var(--drgstn-panel); + } .button.is-primary.is-focused, .button.is-primary:focus { background-color: var(--drgstn-primary) !important; diff --git a/src/stylesheets/theme.css b/src/stylesheets/theme.css index e939fdc998f4defe14c51e39b885527866d638c1..167af160e32c31b5ea6864f1b720c1984475146e 100644 --- a/src/stylesheets/theme.css +++ b/src/stylesheets/theme.css @@ -12,4 +12,5 @@ --drgstn-border: rgba(0, 0, 0, 0.2); --drgstn-tooltip: rgba(74, 74, 74, 0.9); --drgstn-panel-secondary: #ffffff; + --drgstn-height: 500px; }