mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-18 15:33:04 +00:00
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:
@@ -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 { 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 { 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 { 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 { 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 { 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';
|
import { ItemPageFieldComponent } from './simple/field-components/specific-field/item-page-field.component';
|
||||||
@@ -48,7 +47,6 @@ import { AbstractIncrementalListComponent } from './simple/abstract-incremental-
|
|||||||
ItemPageDateFieldComponent,
|
ItemPageDateFieldComponent,
|
||||||
ItemPageAbstractFieldComponent,
|
ItemPageAbstractFieldComponent,
|
||||||
ItemPageUriFieldComponent,
|
ItemPageUriFieldComponent,
|
||||||
ItemPageGenericUriFieldComponent,
|
|
||||||
ItemPageTitleFieldComponent,
|
ItemPageTitleFieldComponent,
|
||||||
ItemPageFieldComponent,
|
ItemPageFieldComponent,
|
||||||
FileSectionComponent,
|
FileSectionComponent,
|
||||||
@@ -68,7 +66,6 @@ import { AbstractIncrementalListComponent } from './simple/abstract-incremental-
|
|||||||
MetadataValuesComponent,
|
MetadataValuesComponent,
|
||||||
MetadataFieldWrapperComponent,
|
MetadataFieldWrapperComponent,
|
||||||
GenericItemPageFieldComponent,
|
GenericItemPageFieldComponent,
|
||||||
ItemPageGenericUriFieldComponent,
|
|
||||||
RelatedEntitiesSearchComponent,
|
RelatedEntitiesSearchComponent,
|
||||||
RelatedItemsComponent,
|
RelatedItemsComponent,
|
||||||
MetadataRepresentationListComponent,
|
MetadataRepresentationListComponent,
|
||||||
|
@@ -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>
|
|
@@ -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);
|
|
||||||
});
|
|
||||||
});
|
|
@@ -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;
|
|
||||||
|
|
||||||
}
|
|
@@ -11,6 +11,7 @@ let fixture: ComponentFixture<ItemPageUriFieldComponent>;
|
|||||||
|
|
||||||
const mockField = 'dc.identifier.uri';
|
const mockField = 'dc.identifier.uri';
|
||||||
const mockValue = 'test value';
|
const mockValue = 'test value';
|
||||||
|
const mockLabel = 'test label';
|
||||||
|
|
||||||
describe('ItemPageUriFieldComponent', () => {
|
describe('ItemPageUriFieldComponent', () => {
|
||||||
beforeEach(async(() => {
|
beforeEach(async(() => {
|
||||||
@@ -32,6 +33,8 @@ describe('ItemPageUriFieldComponent', () => {
|
|||||||
fixture = TestBed.createComponent(ItemPageUriFieldComponent);
|
fixture = TestBed.createComponent(ItemPageUriFieldComponent);
|
||||||
comp = fixture.componentInstance;
|
comp = fixture.componentInstance;
|
||||||
comp.item = mockItemWithMetadataFieldAndValue(mockField, mockValue);
|
comp.item = mockItemWithMetadataFieldAndValue(mockField, mockValue);
|
||||||
|
comp.fields = [mockField];
|
||||||
|
comp.label = mockLabel;
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
@@ -8,7 +8,8 @@ import { ItemPageFieldComponent } from '../item-page-field.component';
|
|||||||
templateUrl: './item-page-uri-field.component.html'
|
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 {
|
export class ItemPageUriFieldComponent extends ItemPageFieldComponent {
|
||||||
|
|
||||||
@@ -21,19 +22,16 @@ export class ItemPageUriFieldComponent extends ItemPageFieldComponent {
|
|||||||
* Separator string between multiple values of the metadata fields defined
|
* Separator string between multiple values of the metadata fields defined
|
||||||
* @type {string}
|
* @type {string}
|
||||||
*/
|
*/
|
||||||
separator: string;
|
@Input() separator: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fields (schema.element.qualifier) used to render their values.
|
* Fields (schema.element.qualifier) used to render their values.
|
||||||
* In this component, we want to display values for metadata 'dc.identifier.uri'
|
|
||||||
*/
|
*/
|
||||||
fields: string[] = [
|
@Input() fields: string[];
|
||||||
'dc.identifier.uri'
|
|
||||||
];
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Label i18n key for the rendered metadata
|
* Label i18n key for the rendered metadata
|
||||||
*/
|
*/
|
||||||
label = 'item.page.uri';
|
@Input() label: string;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -63,7 +63,10 @@
|
|||||||
[fields]="['dc.identifier.citation']"
|
[fields]="['dc.identifier.citation']"
|
||||||
[label]="'item.page.citation'">
|
[label]="'item.page.citation'">
|
||||||
</ds-generic-item-page-field>
|
</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>
|
<ds-item-page-collections [item]="object"></ds-item-page-collections>
|
||||||
<div>
|
<div>
|
||||||
<a class="btn btn-outline-primary" [routerLink]="['/items/' + object.id + '/full']">
|
<a class="btn btn-outline-primary" [routerLink]="['/items/' + object.id + '/full']">
|
||||||
|
@@ -50,7 +50,10 @@ a<div class="top-item-page">
|
|||||||
[fields]="['dc.identifier.citation']"
|
[fields]="['dc.identifier.citation']"
|
||||||
[label]="'item.page.citation'">
|
[label]="'item.page.citation'">
|
||||||
</ds-generic-item-page-field>
|
</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>
|
<ds-item-page-collections [item]="object"></ds-item-page-collections>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
Reference in New Issue
Block a user