Attila Cseh 24 hours ago
committed by GitHub
parent
commit
56497d307c
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 1
      CHANGELOG.md
  2. 18
      libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts
  3. 44
      libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts
  4. 13
      libs/ui/src/lib/entity-logo/entity-logo.component.ts
  5. 22
      libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts

1
CHANGELOG.md

@ -19,6 +19,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Set up the language localization for the static portfolio analysis rule: _Economic Market Cluster Risks_ (Developed Markets)
- Set up the language localization for the static portfolio analysis rule: _Economic Market Cluster Risks_ (Emerging Markets)
- Added stories for the entity logo image component
### Changed

18
libs/ui/src/lib/entity-logo/entity-logo-image-source.service.ts

@ -0,0 +1,18 @@
import { Injectable } from '@angular/core';
import { DataSource } from '@prisma/client';
@Injectable({
providedIn: 'root'
})
export class EntityLogoImageSourceService {
public getLogoUrlByDataSourceAndSymbol(
dataSource: DataSource,
symbol: string
) {
return `../api/v1/logo/${dataSource}/${symbol}`;
}
public getLogoUrlByUrl(url: string) {
return `../api/v1/logo?url=${url}`;
}
}

44
libs/ui/src/lib/entity-logo/entity-logo.component.stories.ts

@ -0,0 +1,44 @@
import { CommonModule } from '@angular/common';
import { importProvidersFrom } from '@angular/core';
import { provideNoopAnimations } from '@angular/platform-browser/animations';
import { applicationConfig, Meta, StoryObj } from '@storybook/angular';
import { EntityLogoImageSourceServiceMock } from '../mocks/entity-logo-image-source.service.mock';
import { EntityLogoImageSourceService } from './entity-logo-image-source.service';
import { GfEntityLogoComponent } from './entity-logo.component';
export default {
title: 'Entity Logo',
component: GfEntityLogoComponent,
decorators: [
applicationConfig({
providers: [
provideNoopAnimations(),
importProvidersFrom(CommonModule),
{
provide: EntityLogoImageSourceService,
useValue: new EntityLogoImageSourceServiceMock()
}
]
})
]
} as Meta<GfEntityLogoComponent>;
type Story = StoryObj<GfEntityLogoComponent>;
export const LogoByDataSourceAndSymbol: Story = {
args: {
dataSource: 'YAHOO',
size: 'large',
symbol: 'AAPL',
tooltip: 'Apple Inc.'
}
};
export const LogoByUrl: Story = {
args: {
size: 'large',
tooltip: 'Ghostfolio',
url: 'https://ghostfol.io'
}
};

13
libs/ui/src/lib/entity-logo/entity-logo.component.ts

@ -1,3 +1,5 @@
import { EntityLogoImageSourceService } from '@ghostfolio/ui/entity-logo/entity-logo-image-source.service';
import { CommonModule } from '@angular/common';
import {
CUSTOM_ELEMENTS_SCHEMA,
@ -25,11 +27,18 @@ export class GfEntityLogoComponent implements OnChanges {
public src: string;
public constructor(
private readonly imageSourceService: EntityLogoImageSourceService
) {}
public ngOnChanges() {
if (this.dataSource && this.symbol) {
this.src = `../api/v1/logo/${this.dataSource}/${this.symbol}`;
this.src = this.imageSourceService.getLogoUrlByDataSourceAndSymbol(
this.dataSource,
this.symbol
);
} else if (this.url) {
this.src = `../api/v1/logo?url=${this.url}`;
this.src = this.imageSourceService.getLogoUrlByUrl(this.url);
}
}
}

22
libs/ui/src/lib/mocks/entity-logo-image-source.service.mock.ts

@ -0,0 +1,22 @@
import { DataSource } from '@prisma/client';
export class EntityLogoImageSourceServiceMock {
public getLogoUrlByDataSourceAndSymbol(
dataSource: DataSource,
symbol: string
) {
if (dataSource === DataSource.YAHOO && symbol === 'AAPL') {
return '';
}
return '';
}
public getLogoUrlByUrl(url: string) {
if (url === 'https://ghostfol.io') {
return '';
}
return '';
}
}
Loading…
Cancel
Save