From d1019340049a4f4581a49517225fce079493dbb2 Mon Sep 17 00:00:00 2001 From: Thomas Kaul <4159106+dtslvr@users.noreply.github.com> Date: Sat, 13 Sep 2025 17:22:57 +0200 Subject: [PATCH] Refactoring --- .../entity-logo/entity-logo-image-source.service.ts | 11 ++++++----- .../lib/entity-logo/entity-logo.component.stories.ts | 2 +- libs/ui/src/lib/entity-logo/entity-logo.component.ts | 8 ++++---- .../mocks/entity-logo-image-source.service.mock.ts | 10 ++++++---- 4 files changed, 17 insertions(+), 14 deletions(-) diff --git a/libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts b/libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts index ba08b8d04..9cbea529b 100644 --- a/libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts +++ b/libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts @@ -1,15 +1,16 @@ +import { AssetProfileIdentifier } from '@ghostfolio/common/interfaces'; + import { Injectable } from '@angular/core'; -import { DataSource } from '@prisma/client'; @Injectable({ // Required to allow mocking in Storybook providedIn: 'root' }) export class EntityLogoImageSourceService { - public getLogoUrlByDataSourceAndSymbol( - dataSource: DataSource, - symbol: string - ) { + public getLogoUrlByAssetProfileIdentifier({ + dataSource, + symbol + }: AssetProfileIdentifier) { return `../api/v1/logo/${dataSource}/${symbol}`; } diff --git a/libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts b/libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts index 5d86da7f8..6c89718bd 100644 --- a/libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts +++ b/libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts @@ -26,7 +26,7 @@ export default { type Story = StoryObj; -export const LogoByDataSourceAndSymbol: Story = { +export const LogoByAssetProfileIdentifier: Story = { args: { dataSource: 'YAHOO', size: 'large', diff --git a/libs/ui/src/lib/entity-logo/entity-logo.component.ts b/libs/ui/src/lib/entity-logo/entity-logo.component.ts index d991ccc1c..212e232be 100644 --- a/libs/ui/src/lib/entity-logo/entity-logo.component.ts +++ b/libs/ui/src/lib/entity-logo/entity-logo.component.ts @@ -33,10 +33,10 @@ export class GfEntityLogoComponent implements OnChanges { public ngOnChanges() { if (this.dataSource && this.symbol) { - this.src = this.imageSourceService.getLogoUrlByDataSourceAndSymbol( - this.dataSource, - this.symbol - ); + this.src = this.imageSourceService.getLogoUrlByAssetProfileIdentifier({ + dataSource: this.dataSource, + symbol: this.symbol + }); } else if (this.url) { this.src = this.imageSourceService.getLogoUrlByUrl(this.url); } diff --git a/libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts b/libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts index 29d44745c..3f4dbbef7 100644 --- a/libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts +++ b/libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts @@ -1,10 +1,12 @@ +import { AssetProfileIdentifier } from '@ghostfolio/common/interfaces'; + import { DataSource } from '@prisma/client'; export class EntityLogoImageSourceServiceMock { - public getLogoUrlByDataSourceAndSymbol( - dataSource: DataSource, - symbol: string - ) { + public getLogoUrlByAssetProfileIdentifier({ + dataSource, + symbol + }: AssetProfileIdentifier) { if (dataSource === DataSource.YAHOO && symbol === 'AAPL') { return ''; }