From b911e03f60544f29d5025c663f105a99b3a2b6b1 Mon Sep 17 00:00:00 2001 From: Tobias Kohr Date: Mon, 13 Nov 2023 10:20:11 +0100 Subject: [PATCH 1/2] fix(metadata-info): display UpdateFrequencyCustom correctly --- .../metadata-info.component.html | 10 ++-- .../metadata-info.component.spec.ts | 47 ++++++++++++++++++- .../metadata-info/metadata-info.component.ts | 25 +++++++++- translations/de.json | 8 ++-- translations/en.json | 8 ++-- translations/fr.json | 8 ++-- 6 files changed, 89 insertions(+), 17 deletions(-) diff --git a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html index 440e1ddee3..d34373ba16 100644 --- a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +++ b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html @@ -45,10 +45,14 @@ {{ metadata.recordUpdated && metadata.recordUpdated.toLocaleString() }}

-
+

record.metadata.updateFrequency

-

- domain.record.updateFrequency.{{ metadata.updateFrequency }} +

+ {{ updateFrequency }}

diff --git a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.spec.ts b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.spec.ts index eaba09c8d0..eb1bc28a3a 100644 --- a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.spec.ts +++ b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.spec.ts @@ -4,6 +4,8 @@ import { TranslateModule } from '@ngx-translate/core' import { ContentGhostComponent } from '../content-ghost/content-ghost.component' import { MetadataInfoComponent } from './metadata-info.component' import { DATASET_RECORDS } from '@geonetwork-ui/common/fixtures' +import { TranslateTestingModule } from '@geonetwork-ui/util/i18n' +import { TranslateMessageFormatCompiler } from 'ngx-translate-messageformat-compiler' describe('MetadataInfoComponent', () => { let component: MetadataInfoComponent @@ -11,7 +13,19 @@ describe('MetadataInfoComponent', () => { beforeEach(async () => { await TestBed.configureTestingModule({ - imports: [TranslateModule.forRoot(), UtilSharedModule], + imports: [ + TranslateModule.forRoot(), + UtilSharedModule, + TranslateTestingModule.withTranslations({ + en: { + 'domain.record.updateFrequency.notPlanned': 'Not planned', + 'domain.record.updateFrequency.month': + '{count, plural, =0{0 times} one{once} other{{count} times}} per month', + }, + }) + .withDefaultLanguage('en') + .withCompiler(new TranslateMessageFormatCompiler()), + ], declarations: [MetadataInfoComponent, ContentGhostComponent], }).compileComponents() }) @@ -73,4 +87,35 @@ describe('MetadataInfoComponent', () => { expect(displayedElement).toBeTruthy() }) }) + describe('updateFrequency', () => { + describe('updateFrequency as UpdateFrequencyCode', () => { + beforeEach(() => { + fixture = TestBed.createComponent(MetadataInfoComponent) + component = fixture.componentInstance + component.metadata = { + ...DATASET_RECORDS[0], + updateFrequency: 'notPlanned', + } + fixture.detectChanges() + }) + it('should display the updateFrequency code correctly', () => { + const displayedElement = + fixture.nativeElement.querySelector('.updateFrequency') + expect(displayedElement.textContent).toEqual(' Not planned ') + }) + }) + describe('updateFrequency as UpdateFrequencyCustom', () => { + beforeEach(() => { + fixture = TestBed.createComponent(MetadataInfoComponent) + component = fixture.componentInstance + component.metadata = DATASET_RECORDS[0] + fixture.detectChanges() + }) + it('should display the updateFrequency object correctly', () => { + const displayedElement = + fixture.nativeElement.querySelector('.updateFrequency') + expect(displayedElement.textContent).toEqual(' 3 times per month ') + }) + }) + }) }) diff --git a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts index 98bcb397db..c32ecc9ed9 100644 --- a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts +++ b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts @@ -5,7 +5,11 @@ import { Input, Output, } from '@angular/core' -import { DatasetRecord } from '@geonetwork-ui/common/domain/record' +import { + DatasetRecord, + UpdateFrequencyCode, + UpdateFrequencyCustom, +} from '@geonetwork-ui/common/domain/record' @Component({ selector: 'gn-ui-metadata-info', @@ -17,6 +21,7 @@ export class MetadataInfoComponent { @Input() metadata: Partial @Input() incomplete: boolean @Output() keyword = new EventEmitter() + updatedTimes: number get hasUsage() { return ( @@ -37,6 +42,24 @@ export class MetadataInfoComponent { return array } + get updateFrequency(): string { + if ( + (this.metadata.updateFrequency as UpdateFrequencyCustom).updatedTimes !== + undefined + ) { + this.updatedTimes = ( + this.metadata.updateFrequency as UpdateFrequencyCustom + ).updatedTimes + return `domain.record.updateFrequency.${ + (this.metadata.updateFrequency as UpdateFrequencyCustom).per + }` + } else { + return `domain.record.updateFrequency.${ + this.metadata.updateFrequency as UpdateFrequencyCode + }` + } + } + fieldReady(propName: string) { return !this.incomplete || propName in this.metadata } diff --git a/translations/de.json b/translations/de.json index d4da8d0e2c..2752fc9fc9 100644 --- a/translations/de.json +++ b/translations/de.json @@ -121,14 +121,14 @@ "domain.record.status.under_development": "In Erstellung", "domain.record.updateFrequency.asNeeded": "Bei Bedarf", "domain.record.updateFrequency.continual": "Kontinuierlich", - "domain.record.updateFrequency.day": "Tag", + "domain.record.updateFrequency.day": "{count, plural, =0{0} one{Ein} other{{count}}} mal am Tag", "domain.record.updateFrequency.irregular": "Unregelmässig", - "domain.record.updateFrequency.month": "Monat", + "domain.record.updateFrequency.month": "{count, plural, =0{0} one{Ein} other{{count}}} mal im Monat", "domain.record.updateFrequency.notPlanned": "Nicht geplant", "domain.record.updateFrequency.periodic": "Regelmässig", "domain.record.updateFrequency.unknown": "Unbekannt", - "domain.record.updateFrequency.week": "Woche", - "domain.record.updateFrequency.year": "Jahr", + "domain.record.updateFrequency.week": "{count, plural, =0{0} one{Ein} other{{count}}} mal in der Woche", + "domain.record.updateFrequency.year": "{count, plural, =0{0} one{Ein} other{{count}}} mal im Jahr", "downloads.format.unknown": "unbekannt", "downloads.wfs.featuretype.not.found": "Die Schicht wurde nicht gefunden", "dropFile": "Datei ablegen", diff --git a/translations/en.json b/translations/en.json index a5161f5937..cfd5d2ed7c 100644 --- a/translations/en.json +++ b/translations/en.json @@ -121,14 +121,14 @@ "domain.record.status.under_development": "Under development", "domain.record.updateFrequency.asNeeded": "As needed", "domain.record.updateFrequency.continual": "Continual", - "domain.record.updateFrequency.day": "day", + "domain.record.updateFrequency.day": "{count, plural, =0{0 times} one{Once} other{{count} times}} per day", "domain.record.updateFrequency.irregular": "Irregular", - "domain.record.updateFrequency.month": "month", + "domain.record.updateFrequency.month": "{count, plural, =0{0 times} one{Once} other{{count} times}} per month", "domain.record.updateFrequency.notPlanned": "Not planned", "domain.record.updateFrequency.periodic": "Periodic", "domain.record.updateFrequency.unknown": "Unknown", - "domain.record.updateFrequency.week": "week", - "domain.record.updateFrequency.year": "year", + "domain.record.updateFrequency.week": "{count, plural, =0{0 times} one{Once} other{{count} times}} per week", + "domain.record.updateFrequency.year": "{count, plural, =0{0 times} one{Once} other{{count} times}} per year", "downloads.format.unknown": "unknown", "downloads.wfs.featuretype.not.found": "The layer was not found", "dropFile": "drop file", diff --git a/translations/fr.json b/translations/fr.json index 3624304b54..7364274faf 100644 --- a/translations/fr.json +++ b/translations/fr.json @@ -121,14 +121,14 @@ "domain.record.status.under_development": "En cours de création", "domain.record.updateFrequency.asNeeded": "Lorsque nécessaire", "domain.record.updateFrequency.continual": "Continue", - "domain.record.updateFrequency.day": "jour", + "domain.record.updateFrequency.day": "{count, plural, =0{0} one{Une} other{{count}}} fois par jour", "domain.record.updateFrequency.irregular": "Irrégulière", - "domain.record.updateFrequency.month": "mois", + "domain.record.updateFrequency.month": "{count, plural, =0{0} one{Une} other{{count}}} fois par mois", "domain.record.updateFrequency.notPlanned": "Non planifiée", "domain.record.updateFrequency.periodic": "Récurrente", "domain.record.updateFrequency.unknown": "Inconnue", - "domain.record.updateFrequency.week": "semaine", - "domain.record.updateFrequency.year": "an", + "domain.record.updateFrequency.week": "{count, plural, =0{0} one{Une} other{{count}}} fois par semaine", + "domain.record.updateFrequency.year": "{count, plural, =0{0} one{Une} other{{count}}} fois par an", "downloads.format.unknown": "inconnu", "downloads.wfs.featuretype.not.found": "La couche n'a pas été retrouvée", "dropFile": "Faites glisser votre fichier", From ddb0857716aeb6b6ff4efe34d4f79663aa0d9649 Mon Sep 17 00:00:00 2001 From: Tobias Kohr Date: Mon, 13 Nov 2023 11:03:45 +0100 Subject: [PATCH 2/2] review(metadata-info): simplify updateFrequency getter --- .../metadata-info/metadata-info.component.ts | 23 ++++--------------- 1 file changed, 5 insertions(+), 18 deletions(-) diff --git a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts index c32ecc9ed9..18b1990b20 100644 --- a/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts +++ b/libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts @@ -5,11 +5,7 @@ import { Input, Output, } from '@angular/core' -import { - DatasetRecord, - UpdateFrequencyCode, - UpdateFrequencyCustom, -} from '@geonetwork-ui/common/domain/record' +import { DatasetRecord } from '@geonetwork-ui/common/domain/record' @Component({ selector: 'gn-ui-metadata-info', @@ -43,20 +39,11 @@ export class MetadataInfoComponent { } get updateFrequency(): string { - if ( - (this.metadata.updateFrequency as UpdateFrequencyCustom).updatedTimes !== - undefined - ) { - this.updatedTimes = ( - this.metadata.updateFrequency as UpdateFrequencyCustom - ).updatedTimes - return `domain.record.updateFrequency.${ - (this.metadata.updateFrequency as UpdateFrequencyCustom).per - }` + if (this.metadata.updateFrequency instanceof Object) { + this.updatedTimes = this.metadata.updateFrequency.updatedTimes + return `domain.record.updateFrequency.${this.metadata.updateFrequency.per}` } else { - return `domain.record.updateFrequency.${ - this.metadata.updateFrequency as UpdateFrequencyCode - }` + return `domain.record.updateFrequency.${this.metadata.updateFrequency}` } }