support uri field which is not dc.identifier.uri

Replacing item-page-uri-field instead of introducing item-page-generic-uri-field
This commit is contained in:
Ben Bosman
2020-02-04 15:10:10 +01:00
parent cc1cc08d8e
commit 4a46780d85
8 changed files with 17 additions and 97 deletions

View File

@@ -10,7 +10,6 @@ import { MetadataUriValuesComponent } from './field-components/metadata-uri-valu
import { ItemPageAuthorFieldComponent } from './simple/field-components/specific-field/author/item-page-author-field.component';
import { ItemPageDateFieldComponent } from './simple/field-components/specific-field/date/item-page-date-field.component';
import { ItemPageAbstractFieldComponent } from './simple/field-components/specific-field/abstract/item-page-abstract-field.component';
import { ItemPageGenericUriFieldComponent } from './simple/field-components/specific-field/generic-uri/item-page-generic-uri-field.component';
import { ItemPageUriFieldComponent } from './simple/field-components/specific-field/uri/item-page-uri-field.component';
import { ItemPageTitleFieldComponent } from './simple/field-components/specific-field/title/item-page-title-field.component';
import { ItemPageFieldComponent } from './simple/field-components/specific-field/item-page-field.component';
@@ -48,7 +47,6 @@ import { AbstractIncrementalListComponent } from './simple/abstract-incremental-
ItemPageDateFieldComponent,
ItemPageAbstractFieldComponent,
ItemPageUriFieldComponent,
ItemPageGenericUriFieldComponent,
ItemPageTitleFieldComponent,
ItemPageFieldComponent,
FileSectionComponent,
@@ -68,7 +66,6 @@ import { AbstractIncrementalListComponent } from './simple/abstract-incremental-
MetadataValuesComponent,
MetadataFieldWrapperComponent,
GenericItemPageFieldComponent,
ItemPageGenericUriFieldComponent,
RelatedEntitiesSearchComponent,
RelatedItemsComponent,
MetadataRepresentationListComponent,

View File

@@ -1,3 +0,0 @@
<div class="item-page-field">
<ds-metadata-uri-values [mdValues]="item?.allMetadata(fields)" [separator]="separator" [label]="label"></ds-metadata-uri-values>
</div>

View File

@@ -1,44 +0,0 @@
import { TranslateLoader, TranslateModule } from '@ngx-translate/core';
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { MockTranslateLoader } from '../../../../../shared/testing/mock-translate-loader';
import { mockItemWithMetadataFieldAndValue } from '../item-page-field.component.spec';
import { ItemPageGenericUriFieldComponent } from './item-page-generic-uri-field.component';
import { MetadataUriValuesComponent } from '../../../../field-components/metadata-uri-values/metadata-uri-values.component';
let comp: ItemPageGenericUriFieldComponent;
let fixture: ComponentFixture<ItemPageGenericUriFieldComponent>;
const mockField = 'dc.relation.haspart';
const mockValue = 'test value';
const mockLabel = 'test label';
describe('ItemPageGenericUriFieldComponent', () => {
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useClass: MockTranslateLoader
}
})],
declarations: [ItemPageGenericUriFieldComponent, MetadataUriValuesComponent],
schemas: [NO_ERRORS_SCHEMA]
}).overrideComponent(ItemPageGenericUriFieldComponent, {
set: {changeDetection: ChangeDetectionStrategy.Default}
}).compileComponents();
}));
beforeEach(async(() => {
fixture = TestBed.createComponent(ItemPageGenericUriFieldComponent);
comp = fixture.componentInstance;
comp.item = mockItemWithMetadataFieldAndValue(mockField, mockValue);
comp.fields = [mockField];
comp.label = mockLabel;
fixture.detectChanges();
}));
it('should display display the correct metadata value', () => {
expect(fixture.nativeElement.innerHTML).toContain(mockValue);
});
});

View File

@@ -1,37 +0,0 @@
import { Component, Input } from '@angular/core';
import {ItemPageFieldComponent} from '../item-page-field.component';
import {Item} from '../../../../../core/shared/item.model';
@Component({
selector: 'ds-item-page-generic-uri-field',
templateUrl: './item-page-generic-uri-field.component.html'
})
/**
* This component can be used to represent any uri on a simple item page.
* It is the most generic way of displaying uris
* It expects 4 parameters: The item, a separator, the metadata keys and an i18n key
*/
export class ItemPageGenericUriFieldComponent extends ItemPageFieldComponent {
/**
* The item to display metadata for
*/
@Input() item: Item;
/**
* Separator string between multiple values of the metadata fields defined
* @type {string}
*/
@Input() separator: string;
/**
* Fields (schema.element.qualifier) used to render their values.
*/
@Input() fields: string[];
/**
* Label i18n key for the rendered metadata
*/
@Input() label: string;
}

View File

@@ -11,6 +11,7 @@ let fixture: ComponentFixture<ItemPageUriFieldComponent>;
const mockField = 'dc.identifier.uri';
const mockValue = 'test value';
const mockLabel = 'test label';
describe('ItemPageUriFieldComponent', () => {
beforeEach(async(() => {
@@ -32,6 +33,8 @@ describe('ItemPageUriFieldComponent', () => {
fixture = TestBed.createComponent(ItemPageUriFieldComponent);
comp = fixture.componentInstance;
comp.item = mockItemWithMetadataFieldAndValue(mockField, mockValue);
comp.fields = [mockField];
comp.label = mockLabel;
fixture.detectChanges();
}));

View File

@@ -8,7 +8,8 @@ import { ItemPageFieldComponent } from '../item-page-field.component';
templateUrl: './item-page-uri-field.component.html'
})
/**
* This component is used for displaying the uri (dc.identifier.uri) metadata of an item
* This component can be used to represent any uri on a simple item page.
* It expects 4 parameters: The item, a separator, the metadata keys and an i18n key
*/
export class ItemPageUriFieldComponent extends ItemPageFieldComponent {
@@ -21,19 +22,16 @@ export class ItemPageUriFieldComponent extends ItemPageFieldComponent {
* Separator string between multiple values of the metadata fields defined
* @type {string}
*/
separator: string;
@Input() separator: string;
/**
* Fields (schema.element.qualifier) used to render their values.
* In this component, we want to display values for metadata 'dc.identifier.uri'
*/
fields: string[] = [
'dc.identifier.uri'
];
@Input() fields: string[];
/**
* Label i18n key for the rendered metadata
*/
label = 'item.page.uri';
@Input() label: string;
}

View File

@@ -63,7 +63,10 @@
[fields]="['dc.identifier.citation']"
[label]="'item.page.citation'">
</ds-generic-item-page-field>
<ds-item-page-uri-field [item]="object"></ds-item-page-uri-field>
<ds-item-page-uri-field [item]="object"
[fields]="['dc.identifier.uri']"
[label]="'item.page.uri'">
</ds-item-page-uri-field>
<ds-item-page-collections [item]="object"></ds-item-page-collections>
<div>
<a class="btn btn-outline-primary" [routerLink]="['/items/' + object.id + '/full']">

View File

@@ -50,7 +50,10 @@ a<div class="top-item-page">
[fields]="['dc.identifier.citation']"
[label]="'item.page.citation'">
</ds-generic-item-page-field>
<ds-item-page-uri-field [item]="object"></ds-item-page-uri-field>
<<ds-item-page-uri-field [item]="object"
[fields]="['dc.identifier.uri']"
[label]="'item.page.uri'">
</ds-item-page-uri-field>
<ds-item-page-collections [item]="object"></ds-item-page-collections>
</div>
</div>