From a21839bcf68f11187b902ddb5ff245c2aa1f8f4d Mon Sep 17 00:00:00 2001 From: sagely1 <114952739+sagely1@users.noreply.github.com> Date: Tue, 16 Apr 2024 14:01:15 -0700 Subject: [PATCH] AG-1399 fix invalid ensg in url from hanging --- src/app/core/services/api.service.ts | 2 +- .../gene-details/gene-details.component.ts | 65 ++++++++++--------- .../gene-similar/gene-similar.component.ts | 8 ++- .../features/genes/services/gene.service.ts | 8 ++- src/app/testing/api-service-stub.ts | 2 +- src/app/testing/gene-service-stub.ts | 2 +- 6 files changed, 48 insertions(+), 39 deletions(-) diff --git a/src/app/core/services/api.service.ts b/src/app/core/services/api.service.ts index 401098ef0..0420af619 100644 --- a/src/app/core/services/api.service.ts +++ b/src/app/core/services/api.service.ts @@ -50,7 +50,7 @@ export class ApiService { return url; } - getGene(id: string): Observable { + getGene(id: string): Observable { return this.http.get(this.getBaseUrl() + '/api/genes/' + id, { headers: new HttpHeaders(defaultHeaders), }); diff --git a/src/app/features/genes/components/gene-details/gene-details.component.ts b/src/app/features/genes/components/gene-details/gene-details.component.ts index d4b03a220..a37476d95 100644 --- a/src/app/features/genes/components/gene-details/gene-details.component.ts +++ b/src/app/features/genes/components/gene-details/gene-details.component.ts @@ -135,40 +135,45 @@ export class GeneDetailsComponent implements OnInit, AfterViewInit { if (params.get('id')) { this.geneService .getGene(params.get('id') as string) - .subscribe((gene: Gene) => { - this.gene = gene; - - this.panels.forEach((p: Panel) => { - if (p.name == 'nominations' && !this.gene?.total_nominations) { - p.disabled = true; - } else if ( - p.name == 'experimental-validation' && - !this.gene?.experimental_validation?.length - ) { - p.disabled = true; - } else { - p.disabled = false; + .subscribe((gene) => { + if (!gene) { + this.helperService.setLoading(false); + this.router.navigateByUrl('/404-not-found', { skipLocationChange: true }); + } else { + this.gene = gene; + + this.panels.forEach((p: Panel) => { + if (p.name == 'nominations' && !this.gene?.total_nominations) { + p.disabled = true; + } else if ( + p.name == 'experimental-validation' && + !this.gene?.experimental_validation?.length + ) { + p.disabled = true; + } else { + p.disabled = false; + } + }); + + const nominationsPanel = this.panels.find( + (p) => p.name == 'nominations' + ); + if (nominationsPanel) { + nominationsPanel.disabled = !this.gene.total_nominations ? true : false; } - }); - const nominationsPanel = this.panels.find( - (p) => p.name == 'nominations' - ); - if (nominationsPanel) { - nominationsPanel.disabled = !this.gene.total_nominations ? true : false; - } + const experimentalValidationPanel = this.panels.find( + (p) => p.name == 'experimental-validation' + ); + if (experimentalValidationPanel) { + experimentalValidationPanel.disabled = !this.gene + .experimental_validation?.length + ? true + : false; + } - const experimentalValidationPanel = this.panels.find( - (p) => p.name == 'experimental-validation' - ); - if (experimentalValidationPanel) { - experimentalValidationPanel.disabled = !this.gene - .experimental_validation?.length - ? true - : false; + this.helperService.setLoading(false); } - - this.helperService.setLoading(false); }); } diff --git a/src/app/features/genes/components/gene-similar/gene-similar.component.ts b/src/app/features/genes/components/gene-similar/gene-similar.component.ts index 8414a5ad5..0e0c01d8c 100644 --- a/src/app/features/genes/components/gene-similar/gene-similar.component.ts +++ b/src/app/features/genes/components/gene-similar/gene-similar.component.ts @@ -69,9 +69,11 @@ export class GeneSimilarComponent implements OnInit { this.helperService.setLoading(true); this.geneService .getGene(params.get('id') as string) - .subscribe((gene: Gene) => { - this.gene = gene; - this.init(); + .subscribe((gene: Gene | null) => { + if (gene) { + this.gene = gene; + this.init(); + } }); } }); diff --git a/src/app/features/genes/services/gene.service.ts b/src/app/features/genes/services/gene.service.ts index 01889bff2..d6ffc12eb 100644 --- a/src/app/features/genes/services/gene.service.ts +++ b/src/app/features/genes/services/gene.service.ts @@ -27,13 +27,15 @@ export class GeneService { // ------------------------------------------------------------------------ // - getGene(id: string): Observable { + getGene(id: string): Observable { if (this.genes[id]) { return of(this.genes[id]); } - + return this.apiService.getGene(id).pipe( - map((gene: Gene) => { + map((gene: Gene | null) => { + if (!gene) + return null; gene.similar_genes_network = this.getSimilarGenesNetwork(gene); return (this.genes[id] = gene); }) diff --git a/src/app/testing/api-service-stub.ts b/src/app/testing/api-service-stub.ts index cc94237d6..a7491cb5b 100644 --- a/src/app/testing/api-service-stub.ts +++ b/src/app/testing/api-service-stub.ts @@ -20,7 +20,7 @@ import { @Injectable() export class ApiServiceStub { - getGene(id: string): Observable { + getGene(id: string): Observable { return of(geneMock1); } diff --git a/src/app/testing/gene-service-stub.ts b/src/app/testing/gene-service-stub.ts index c70dbf189..295b37bd2 100644 --- a/src/app/testing/gene-service-stub.ts +++ b/src/app/testing/gene-service-stub.ts @@ -30,7 +30,7 @@ export class GeneServiceStub { this.geneService = new GeneService(new ApiServiceStub() as ApiService); } - getGene(id: string): Observable { + getGene(id: string): Observable { return this.geneService.getGene(id); }