diff --git a/client/src/app/gene/components/gene.component.ts b/client/src/app/gene/components/gene.component.ts index d9984d0b..462b762e 100644 --- a/client/src/app/gene/components/gene.component.ts +++ b/client/src/app/gene/components/gene.component.ts @@ -13,6 +13,7 @@ import { LegendComponent } from './legend.component'; import { MacroComponent } from './macro.component'; import { MicroComponent } from './micro.component'; import { PlotComponent } from './plot.component'; +import { TrackDetailComponent } from './track-detail.component'; @Component({ selector: 'gene', @@ -33,7 +34,8 @@ export class GeneComponent implements AfterViewInit, OnDestroy { {component: LegendComponent, name: 'legend'}, {component: MacroComponent, name: 'macro'}, {component: MicroComponent, name: 'micro'}, - {component: PlotComponent, name: 'plot'} + {component: PlotComponent, name: 'plot'}, + {component: TrackDetailComponent, name: 'track'} ]; layoutConfig = { content: [{ @@ -123,6 +125,19 @@ export class GeneComponent implements AfterViewInit, OnDestroy { }; } + private _trackDetailConfigFactory(track) { + const first = track.genes[0]; + const last = track.genes[track.genes.length-1]; + const id = `track:${track.name}:${first}:${last}:${track.source}`; + return { + type: 'component', + componentName: 'track', + id: id, + title: `Track: ${track.name}`, + componentState: {inputs: {track}}, + }; + } + private _legendConfigFactory(elements, colors) { const id = 'microlegend'; const options = {autoResize: true}; @@ -182,8 +197,9 @@ export class GeneComponent implements AfterViewInit, OnDestroy { this._geneDetailConfigFactory(gene, family, source); this.goldenLayoutDirective.stackItem(geneConfig, id); }, - nameClick: (track) => { - console.log(track); + nameClick: ({track}) => { + const trackConfig = this._trackDetailConfigFactory(track); + this.goldenLayoutDirective.stackItem(trackConfig, id); } }, }, diff --git a/client/src/app/gene/components/index.ts b/client/src/app/gene/components/index.ts index c16c49e2..c4b06480 100644 --- a/client/src/app/gene/components/index.ts +++ b/client/src/app/gene/components/index.ts @@ -29,5 +29,6 @@ export * from './legend.component'; export * from './macro.component'; export * from './micro.component'; export * from './plot.component'; +export * from './track-detail.component'; export * from './shared'; export * from './viewers'; diff --git a/client/src/app/gene/components/micro.component.ts b/client/src/app/gene/components/micro.component.ts index 6fae286f..80443802 100644 --- a/client/src/app/gene/components/micro.component.ts +++ b/client/src/app/gene/components/micro.component.ts @@ -63,7 +63,7 @@ export class MicroComponent implements AfterViewInit, OnDestroy { } emitName(track) { - this.nameClick.emit(track); + this.nameClick.emit({track}); } // private diff --git a/client/src/app/gene/components/track-detail.component.ts b/client/src/app/gene/components/track-detail.component.ts index 9353269a..a8f8eff8 100644 --- a/client/src/app/gene/components/track-detail.component.ts +++ b/client/src/app/gene/components/track-detail.component.ts @@ -1,50 +1,49 @@ // Angular -import { Component, Input, OnChanges, SimpleChanges } from '@angular/core'; +import { Component, Input, OnInit } from '@angular/core'; // App import { AppConfig } from '@gcv/app.config'; import { Server } from '@gcv/core/models'; -import { Gene, Group } from '@gcv/gene/models'; +import { Gene, Track } from '@gcv/gene/models'; @Component({ selector: 'track-detail', styles: [ '' ], template: ` -

{{track.genus[0]}}.{{track.species}} - {{track.chromosome_name}}

+

{{ track.genus[0] }}.{{ track.species }} - {{ track.name }}

Search for similar contexts

Genes: