diff --git a/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.html b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.html
new file mode 100644
index 0000000000..e4522398a6
--- /dev/null
+++ b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.scss b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.scss
similarity index 100%
rename from src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.scss
rename to src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.scss
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.spec.ts b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.spec.ts
similarity index 79%
rename from src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.spec.ts
rename to src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.spec.ts
index 5cbe9f6d79..953cc78535 100644
--- a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.spec.ts
+++ b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.spec.ts
@@ -1,6 +1,6 @@
import { Item } from '../../../../core/shared/item.model';
import { of as observableOf } from 'rxjs/internal/observable/of';
-import { OrgunitGridElementComponent } from './orgunit-grid-element.component';
+import { OrgUnitGridElementComponent } from './org-unit-grid-element.component';
import { createSuccessfulRemoteDataObject$ } from '../../../../shared/testing/utils';
import { PaginatedList } from '../../../../core/data/paginated-list';
import { PageInfo } from '../../../../core/shared/page-info.model';
@@ -41,7 +41,7 @@ const mockItem = Object.assign(new Item(), {
}
});
-describe('OrgunitGridElementComponent', () => {
+describe('OrgUnitGridElementComponent', () => {
let comp;
let fixture;
@@ -52,18 +52,18 @@ describe('OrgunitGridElementComponent', () => {
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [NoopAnimationsModule],
- declarations: [OrgunitGridElementComponent, TruncatePipe],
+ declarations: [OrgUnitGridElementComponent, TruncatePipe],
providers: [
{ provide: TruncatableService, useValue: truncatableServiceStub },
],
schemas: [NO_ERRORS_SCHEMA]
- }).overrideComponent(OrgunitGridElementComponent, {
+ }).overrideComponent(OrgUnitGridElementComponent, {
set: { changeDetection: ChangeDetectionStrategy.Default }
}).compileComponents();
}));
beforeEach(async(() => {
- fixture = TestBed.createComponent(OrgunitGridElementComponent);
+ fixture = TestBed.createComponent(OrgUnitGridElementComponent);
comp = fixture.componentInstance;
}));
@@ -73,9 +73,9 @@ describe('OrgunitGridElementComponent', () => {
fixture.detectChanges();
});
- it(`should contain a OrgunitGridElementComponent`, () => {
- const orgunitGridElement = fixture.debugElement.query(By.css(`ds-orgunit-search-result-grid-element`));
- expect(orgunitGridElement).not.toBeNull();
+ it(`should contain a OrgUnitGridElementComponent`, () => {
+ const orgUnitGridElement = fixture.debugElement.query(By.css(`ds-org-unit-search-result-grid-element`));
+ expect(orgUnitGridElement).not.toBeNull();
});
});
});
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.ts b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.ts
similarity index 75%
rename from src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.ts
rename to src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.ts
index 1bdcbdc370..05a7f6c8c5 100644
--- a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.ts
+++ b/src/app/entity-groups/research-entities/item-grid-elements/org-unit/org-unit-grid-element.component.ts
@@ -6,12 +6,12 @@ import { Item } from '../../../../core/shared/item.model';
@listableObjectComponent('OrgUnit', ViewMode.GridElement)
@Component({
- selector: 'ds-orgunit-grid-element',
- styleUrls: ['./orgunit-grid-element.component.scss'],
- templateUrl: './orgunit-grid-element.component.html',
+ selector: 'ds-org-unit-grid-element',
+ styleUrls: ['./org-unit-grid-element.component.scss'],
+ templateUrl: './org-unit-grid-element.component.html',
})
/**
* The component for displaying a grid element for an item of the type Organisation Unit
*/
-export class OrgunitGridElementComponent extends AbstractListableElementComponent- {
+export class OrgUnitGridElementComponent extends AbstractListableElementComponent
- {
}
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.html b/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.html
deleted file mode 100644
index f42ffb87e9..0000000000
--- a/src/app/entity-groups/research-entities/item-grid-elements/orgunit/orgunit-grid-element.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.html b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.html
similarity index 100%
rename from src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.html
rename to src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.html
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.scss b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.scss
similarity index 100%
rename from src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.scss
rename to src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.scss
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.spec.ts b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.spec.ts
similarity index 88%
rename from src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.spec.ts
rename to src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.spec.ts
index bb4cb93a70..36324ad627 100644
--- a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.spec.ts
+++ b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.spec.ts
@@ -3,7 +3,7 @@ import { Item } from '../../../../../core/shared/item.model';
import { createSuccessfulRemoteDataObject$ } from '../../../../../shared/testing/utils';
import { PaginatedList } from '../../../../../core/data/paginated-list';
import { PageInfo } from '../../../../../core/shared/page-info.model';
-import { OrgunitSearchResultGridElementComponent } from './orgunit-search-result-grid-element.component';
+import { OrgUnitSearchResultGridElementComponent } from './org-unit-search-result-grid-element.component';
import { getEntityGridElementTestComponent } from '../../../../../shared/object-grid/search-result-grid-element/item-search-result/publication/publication-search-result-grid-element.component.spec';
const mockItemWithMetadata: ItemSearchResult = new ItemSearchResult();
@@ -52,4 +52,4 @@ mockItemWithoutMetadata.indexableObject = Object.assign(new Item(), {
}
});
-describe('OrgunitSearchResultGridElementComponent', getEntityGridElementTestComponent(OrgunitSearchResultGridElementComponent, mockItemWithMetadata, mockItemWithoutMetadata, ['date', 'country', 'city']));
+describe('OrgUnitSearchResultGridElementComponent', getEntityGridElementTestComponent(OrgUnitSearchResultGridElementComponent, mockItemWithMetadata, mockItemWithoutMetadata, ['date', 'country', 'city']));
diff --git a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.ts b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.ts
similarity index 77%
rename from src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.ts
rename to src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.ts
index 71a435762a..64b4be4a11 100644
--- a/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component.ts
+++ b/src/app/entity-groups/research-entities/item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component.ts
@@ -8,13 +8,13 @@ import { Item } from '../../../../../core/shared/item.model';
@listableObjectComponent('OrgUnitSearchResult', ViewMode.GridElement)
@Component({
- selector: 'ds-orgunit-search-result-grid-element',
- styleUrls: ['./orgunit-search-result-grid-element.component.scss'],
- templateUrl: './orgunit-search-result-grid-element.component.html',
+ selector: 'ds-org-unit-search-result-grid-element',
+ styleUrls: ['./org-unit-search-result-grid-element.component.scss'],
+ templateUrl: './org-unit-search-result-grid-element.component.html',
animations: [focusShadow]
})
/**
* The component for displaying a grid element for an item search result of the type Organisation Unit
*/
-export class OrgunitSearchResultGridElementComponent extends SearchResultGridElementComponent {
+export class OrgUnitSearchResultGridElementComponent extends SearchResultGridElementComponent {
}
diff --git a/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.html b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.html
new file mode 100644
index 0000000000..03ef45c7a4
--- /dev/null
+++ b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.html
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.scss b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.scss
similarity index 100%
rename from src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.scss
rename to src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.scss
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.spec.ts b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.spec.ts
similarity index 82%
rename from src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.spec.ts
rename to src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.spec.ts
index 3009197e10..43ed9b0ec5 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.spec.ts
+++ b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.spec.ts
@@ -1,7 +1,7 @@
import { async, TestBed } from '@angular/core/testing';
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
import { By } from '@angular/platform-browser';
-import { OrgUnitListElementComponent } from './orgunit-list-element.component';
+import { OrgUnitListElementComponent } from './org-unit-list-element.component';
import { of as observableOf } from 'rxjs';
import { Item } from '../../../../core/shared/item.model';
import { TruncatePipe } from '../../../../shared/utils/truncate.pipe';
@@ -25,7 +25,7 @@ const mockItem: Item = Object.assign(new Item(), {
}
});
-describe('OrgunitListElementComponent', () => {
+describe('OrgUnitListElementComponent', () => {
let comp;
let fixture;
@@ -50,15 +50,15 @@ describe('OrgunitListElementComponent', () => {
comp = fixture.componentInstance;
}));
- describe(`when the orgunit is rendered`, () => {
+ describe(`when the org unit is rendered`, () => {
beforeEach(() => {
comp.object = mockItem;
fixture.detectChanges();
});
it(`should contain a OrgUnitListElementComponent`, () => {
- const orgunitListElement = fixture.debugElement.query(By.css(`ds-orgunit-search-result-list-element`));
- expect(orgunitListElement).not.toBeNull();
+ const orgUnitListElement = fixture.debugElement.query(By.css(`ds-org-unit-search-result-list-element`));
+ expect(orgUnitListElement).not.toBeNull();
});
});
});
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.ts b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.ts
similarity index 82%
rename from src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.ts
rename to src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.ts
index 7e25cf614d..32254595aa 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.ts
+++ b/src/app/entity-groups/research-entities/item-list-elements/org-unit/org-unit-list-element.component.ts
@@ -6,9 +6,9 @@ import { Item } from '../../../../core/shared/item.model';
@listableObjectComponent('OrgUnit', ViewMode.ListElement)
@Component({
- selector: 'ds-orgunit-list-element',
- styleUrls: ['./orgunit-list-element.component.scss'],
- templateUrl: './orgunit-list-element.component.html'
+ selector: 'ds-org-unit-list-element',
+ styleUrls: ['./org-unit-list-element.component.scss'],
+ templateUrl: './org-unit-list-element.component.html'
})
/**
* The component for displaying a list element for an item of the type Organisation Unit
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.html b/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.html
deleted file mode 100644
index ad0eec0313..0000000000
--- a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-list-element.component.html
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.html b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.html
similarity index 100%
rename from src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.html
rename to src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.html
diff --git a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.scss b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.scss
similarity index 100%
rename from src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.scss
rename to src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.scss
diff --git a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.spec.ts b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.spec.ts
similarity index 72%
rename from src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.spec.ts
rename to src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.spec.ts
index 6093b5c680..0597c0032d 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.spec.ts
+++ b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.spec.ts
@@ -2,14 +2,14 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
import { By } from '@angular/platform-browser';
import { of as observableOf } from 'rxjs';
-import { OrgunitSearchResultListElementComponent } from './orgunit-search-result-list-element.component';
+import { OrgUnitSearchResultListElementComponent } from './org-unit-search-result-list-element.component';
import { Item } from '../../../../../core/shared/item.model';
import { TruncatePipe } from '../../../../../shared/utils/truncate.pipe';
import { TruncatableService } from '../../../../../shared/truncatable/truncatable.service';
import { ItemSearchResult } from '../../../../../shared/object-collection/shared/item-search-result.model';
-let orgUnitListElementComponent: OrgunitSearchResultListElementComponent;
-let fixture: ComponentFixture;
+let orgUnitListElementComponent: OrgUnitSearchResultListElementComponent;
+let fixture: ComponentFixture;
const mockItemWithMetadata: ItemSearchResult = Object.assign(
new ItemSearchResult(),
@@ -51,44 +51,44 @@ const mockItemWithoutMetadata: ItemSearchResult = Object.assign(
describe('OrgUnitSearchResultListElementComponent', () => {
beforeEach(async(() => {
TestBed.configureTestingModule({
- declarations: [ OrgunitSearchResultListElementComponent , TruncatePipe],
+ declarations: [ OrgUnitSearchResultListElementComponent , TruncatePipe],
providers: [
{ provide: TruncatableService, useValue: {} }
],
schemas: [ NO_ERRORS_SCHEMA ]
- }).overrideComponent(OrgunitSearchResultListElementComponent, {
+ }).overrideComponent(OrgUnitSearchResultListElementComponent, {
set: { changeDetection: ChangeDetectionStrategy.Default }
}).compileComponents();
}));
beforeEach(async(() => {
- fixture = TestBed.createComponent(OrgunitSearchResultListElementComponent);
+ fixture = TestBed.createComponent(OrgUnitSearchResultListElementComponent);
orgUnitListElementComponent = fixture.componentInstance;
}));
- describe('When the item has an orgunit description', () => {
+ describe('When the item has an org unit description', () => {
beforeEach(() => {
orgUnitListElementComponent.object = mockItemWithMetadata;
fixture.detectChanges();
});
it('should show the description span', () => {
- const orgunitDescriptionField = fixture.debugElement.query(By.css('span.item-list-orgunit-description'));
- expect(orgunitDescriptionField).not.toBeNull();
+ const orgUnitDescriptionField = fixture.debugElement.query(By.css('span.item-list-org-unit-description'));
+ expect(orgUnitDescriptionField).not.toBeNull();
});
});
- describe('When the item has no orgunit description', () => {
+ describe('When the item has no org unit description', () => {
beforeEach(() => {
orgUnitListElementComponent.object = mockItemWithoutMetadata;
fixture.detectChanges();
});
it('should not show the description span', () => {
- const orgunitDescriptionField = fixture.debugElement.query(By.css('span.item-list-orgunit-description'));
- expect(orgunitDescriptionField).toBeNull();
+ const orgUnitDescriptionField = fixture.debugElement.query(By.css('span.item-list-org-unit-description'));
+ expect(orgUnitDescriptionField).toBeNull();
});
});
});
diff --git a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.ts b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.ts
similarity index 76%
rename from src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.ts
rename to src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.ts
index 5e3cdedd60..5b50e5a78c 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component.ts
+++ b/src/app/entity-groups/research-entities/item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component.ts
@@ -7,12 +7,12 @@ import { Item } from '../../../../../core/shared/item.model';
@listableObjectComponent('OrgUnitSearchResult', ViewMode.ListElement)
@Component({
- selector: 'ds-orgunit-search-result-list-element',
- styleUrls: ['./orgunit-search-result-list-element.component.scss'],
- templateUrl: './orgunit-search-result-list-element.component.html'
+ selector: 'ds-org-unit-search-result-list-element',
+ styleUrls: ['./org-unit-search-result-list-element.component.scss'],
+ templateUrl: './org-unit-search-result-list-element.component.html'
})
/**
* The component for displaying a list element for an item search result of the type Organisation Unit
*/
-export class OrgunitSearchResultListElementComponent extends SearchResultListElementComponent {
+export class OrgUnitSearchResultListElementComponent extends SearchResultListElementComponent {
}
diff --git a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.html b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.html
similarity index 100%
rename from src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.html
rename to src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.html
diff --git a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.scss b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.scss
similarity index 100%
rename from src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.scss
rename to src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.scss
diff --git a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.spec.ts b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.spec.ts
similarity index 94%
rename from src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.spec.ts
rename to src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.spec.ts
index a49105b2e3..28b014ddba 100644
--- a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.spec.ts
+++ b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.spec.ts
@@ -2,7 +2,7 @@ import { Item } from '../../../../core/shared/item.model';
import { RemoteData } from '../../../../core/data/remote-data';
import { PaginatedList } from '../../../../core/data/paginated-list';
import { PageInfo } from '../../../../core/shared/page-info.model';
-import { OrgunitComponent } from './orgunit.component';
+import { OrgUnitComponent } from './org-unit.component';
import { of as observableOf } from 'rxjs';
import {
createRelationshipsObservable,
@@ -47,4 +47,4 @@ const mockItem: Item = Object.assign(new Item(), {
relationships: createRelationshipsObservable()
});
-describe('OrgUnitComponent', getItemPageFieldsTest(mockItem, OrgunitComponent));
+describe('OrgUnitComponent', getItemPageFieldsTest(mockItem, OrgUnitComponent));
diff --git a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.ts b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.ts
similarity index 90%
rename from src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.ts
rename to src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.ts
index c63a1c8a53..2e5ea3fb9b 100644
--- a/src/app/entity-groups/research-entities/item-pages/orgunit/orgunit.component.ts
+++ b/src/app/entity-groups/research-entities/item-pages/org-unit/org-unit.component.ts
@@ -9,14 +9,14 @@ import { listableObjectComponent } from '../../../../shared/object-collection/sh
@listableObjectComponent('OrgUnit', ViewMode.StandalonePage)
@Component({
- selector: 'ds-orgunit',
- styleUrls: ['./orgunit.component.scss'],
- templateUrl: './orgunit.component.html'
+ selector: 'ds-org-unit',
+ styleUrls: ['./org-unit.component.scss'],
+ templateUrl: './org-unit.component.html'
})
/**
* The component for displaying metadata and relations of an item of the type Organisation Unit
*/
-export class OrgunitComponent extends ItemComponent implements OnInit {
+export class OrgUnitComponent extends ItemComponent implements OnInit {
/**
* The people related to this organisation unit
*/
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-item-page-list-element.component.html b/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.html
similarity index 100%
rename from src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-item-page-list-element.component.html
rename to src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.html
diff --git a/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.spec.ts b/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.spec.ts
new file mode 100644
index 0000000000..8616e4fa01
--- /dev/null
+++ b/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.spec.ts
@@ -0,0 +1,47 @@
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
+import { By } from '@angular/platform-browser';
+import { ItemMetadataRepresentation } from '../../../../core/shared/metadata-representation/item/item-metadata-representation.model';
+import { OrgUnitItemMetadataListElementComponent } from './org-unit-item-metadata-list-element.component';
+import { Item } from '../../../../core/shared/item.model';
+import { TooltipModule } from 'ngx-bootstrap';
+
+const description = 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua.';
+const organisation = 'Anonymous';
+const mockItem = Object.assign(new Item(), { metadata: { 'dc.description': [{ value: description }], 'organization.legalName': [{ value: organisation }] } });
+const mockItemMetadataRepresentation = Object.assign(new ItemMetadataRepresentation(), mockItem);
+
+describe('OrgUnitItemMetadataListElementComponent', () => {
+ let comp: OrgUnitItemMetadataListElementComponent;
+ let fixture: ComponentFixture;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ imports: [TooltipModule.forRoot()],
+ declarations: [OrgUnitItemMetadataListElementComponent],
+ schemas: [NO_ERRORS_SCHEMA]
+ }).overrideComponent(OrgUnitItemMetadataListElementComponent, {
+ set: { changeDetection: ChangeDetectionStrategy.Default }
+ }).compileComponents();
+ }));
+
+ beforeEach(async(() => {
+ fixture = TestBed.createComponent(OrgUnitItemMetadataListElementComponent);
+ comp = fixture.componentInstance;
+ comp.metadataRepresentation = mockItemMetadataRepresentation;
+ fixture.detectChanges();
+ }));
+
+ it('should show the name of the organisation as a link', () => {
+ const linkText = fixture.debugElement.query(By.css('a')).nativeElement.textContent;
+ expect(linkText).toBe(organisation);
+ });
+
+ it('should show the description on hover over the link in a tooltip', () => {
+ const link = fixture.debugElement.query(By.css('a'));
+ link.triggerEventHandler('mouseover', null);
+ fixture.detectChanges();
+ const tooltip = fixture.debugElement.query(By.css('.item-list-job-title')).nativeElement.textContent;
+ expect(tooltip).toBe(description);
+ });
+});
diff --git a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-item-page-list-element.component.ts b/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.ts
similarity index 78%
rename from src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-item-page-list-element.component.ts
rename to src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.ts
index 7121670b38..e0bb542241 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/orgunit/orgunit-item-page-list-element.component.ts
+++ b/src/app/entity-groups/research-entities/metadata-representations/org-unit/org-unit-item-metadata-list-element.component.ts
@@ -5,12 +5,12 @@ import { ItemMetadataRepresentation } from '../../../../core/shared/metadata-rep
@metadataRepresentationComponent('OrgUnit', MetadataRepresentationType.Item)
@Component({
- selector: 'ds-orgunit-item-page-list-element',
- templateUrl: './orgunit-item-page-list-element.component.html'
+ selector: 'ds-org-unit-item-metadata-list-element',
+ templateUrl: './org-unit-item-metadata-list-element.component.html'
})
/**
* The component for displaying an item of the type OrgUnit as a metadata field
*/
-export class OrgunitItemPageListElementComponent {
+export class OrgUnitItemMetadataListElementComponent {
metadataRepresentation: ItemMetadataRepresentation;
}
diff --git a/src/app/entity-groups/research-entities/item-list-elements/person/person-item-page-list-element.component.html b/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.html
similarity index 100%
rename from src/app/entity-groups/research-entities/item-list-elements/person/person-item-page-list-element.component.html
rename to src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.html
diff --git a/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.spec.ts b/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.spec.ts
new file mode 100644
index 0000000000..0d4786f37e
--- /dev/null
+++ b/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.spec.ts
@@ -0,0 +1,48 @@
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+import { ChangeDetectionStrategy, NO_ERRORS_SCHEMA } from '@angular/core';
+import { By } from '@angular/platform-browser';
+import { ItemMetadataRepresentation } from '../../../../core/shared/metadata-representation/item/item-metadata-representation.model';
+import { Item } from '../../../../core/shared/item.model';
+import { PersonItemMetadataListElementComponent } from './person-item-metadata-list-element.component';
+import { TooltipModule } from 'ngx-bootstrap';
+
+const jobTitle ='Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua.';
+const firstName = 'Joe';
+const lastName = 'Anonymous';
+const mockItem = Object.assign(new Item(), { metadata: { 'person.jobTitle': [{ value: jobTitle }], 'person.givenName': [{ value: firstName }], 'person.familyName': [{ value: lastName }] } });
+const mockItemMetadataRepresentation = Object.assign(new ItemMetadataRepresentation(), mockItem);
+
+describe('PersonItemMetadataListElementComponent', () => {
+ let comp: PersonItemMetadataListElementComponent;
+ let fixture: ComponentFixture;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ imports: [TooltipModule.forRoot()],
+ declarations: [PersonItemMetadataListElementComponent],
+ schemas: [NO_ERRORS_SCHEMA]
+ }).overrideComponent(PersonItemMetadataListElementComponent, {
+ set: { changeDetection: ChangeDetectionStrategy.Default }
+ }).compileComponents();
+ }));
+
+ beforeEach(async(() => {
+ fixture = TestBed.createComponent(PersonItemMetadataListElementComponent);
+ comp = fixture.componentInstance;
+ comp.metadataRepresentation = mockItemMetadataRepresentation;
+ fixture.detectChanges();
+ }));
+
+ it('should show the person\'s name as a link', () => {
+ const linkText = fixture.debugElement.query(By.css('a')).nativeElement.textContent;
+ expect(linkText).toBe(lastName + ', ' + firstName);
+ });
+
+ it('should show the description on hover over the link in a tooltip', () => {
+ const link = fixture.debugElement.query(By.css('a'));
+ link.triggerEventHandler('mouseover', null);
+ fixture.detectChanges();
+ const tooltip = fixture.debugElement.query(By.css('.item-list-job-title')).nativeElement.textContent;
+ expect(tooltip).toBe(jobTitle);
+ });
+});
diff --git a/src/app/entity-groups/research-entities/item-list-elements/person/person-item-page-list-element.component.ts b/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.ts
similarity index 54%
rename from src/app/entity-groups/research-entities/item-list-elements/person/person-item-page-list-element.component.ts
rename to src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.ts
index d7666237ad..e39eb05948 100644
--- a/src/app/entity-groups/research-entities/item-list-elements/person/person-item-page-list-element.component.ts
+++ b/src/app/entity-groups/research-entities/metadata-representations/person/person-item-metadata-list-element.component.ts
@@ -1,19 +1,16 @@
import { Component } from '@angular/core';
-import { AbstractListableElementComponent } from '../../../../shared/object-collection/shared/object-collection-element/abstract-listable-element.component';
-import { Item } from '../../../../core/shared/item.model';
import { metadataRepresentationComponent } from '../../../../shared/metadata-representation/metadata-representation.decorator';
import { MetadataRepresentationType } from '../../../../core/shared/metadata-representation/metadata-representation.model';
-import { MetadataRepresentationListElementComponent } from '../../../../shared/object-list/metadata-representation-list-element/metadata-representation-list-element.component';
import { ItemMetadataRepresentation } from '../../../../core/shared/metadata-representation/item/item-metadata-representation.model';
@metadataRepresentationComponent('Person', MetadataRepresentationType.Item)
@Component({
- selector: 'ds-person-item-page-list-element',
- templateUrl: './person-item-page-list-element.component.html'
+ selector: 'ds-person-item-metadata-list-element',
+ templateUrl: './person-item-metadata-list-element.component.html'
})
/**
* The component for displaying an item of the type Person as a metadata field
-*/
-export class PersonItemPageListElementComponent {
+ */
+export class PersonItemMetadataListElementComponent {
metadataRepresentation: ItemMetadataRepresentation;
}
diff --git a/src/app/entity-groups/research-entities/research-entities.module.ts b/src/app/entity-groups/research-entities/research-entities.module.ts
index 2d4d95dfbf..8829318f34 100644
--- a/src/app/entity-groups/research-entities/research-entities.module.ts
+++ b/src/app/entity-groups/research-entities/research-entities.module.ts
@@ -2,42 +2,42 @@ import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { SharedModule } from '../../shared/shared.module';
import { ItemPageModule } from '../../+item-page/item-page.module';
-import { OrgunitComponent } from './item-pages/orgunit/orgunit.component';
+import { OrgUnitComponent } from './item-pages/org-unit/org-unit.component';
import { PersonComponent } from './item-pages/person/person.component';
import { ProjectComponent } from './item-pages/project/project.component';
-import { OrgUnitListElementComponent } from './item-list-elements/orgunit/orgunit-list-element.component';
-import { OrgunitItemPageListElementComponent } from './item-list-elements/orgunit/orgunit-item-page-list-element.component';
-import { PersonItemPageListElementComponent } from './item-list-elements/person/person-item-page-list-element.component';
+import { OrgUnitListElementComponent } from './item-list-elements/org-unit/org-unit-list-element.component';
import { PersonListElementComponent } from './item-list-elements/person/person-list-element.component';
import { ProjectListElementComponent } from './item-list-elements/project/project-list-element.component';
import { TooltipModule } from 'ngx-bootstrap';
import { PersonGridElementComponent } from './item-grid-elements/person/person-grid-element.component';
-import { OrgunitGridElementComponent } from './item-grid-elements/orgunit/orgunit-grid-element.component';
+import { OrgUnitGridElementComponent } from './item-grid-elements/org-unit/org-unit-grid-element.component';
import { ProjectGridElementComponent } from './item-grid-elements/project/project-grid-element.component';
-import { OrgunitSearchResultListElementComponent } from './item-list-elements/search-result-list-elements/orgunit/orgunit-search-result-list-element.component';
+import { OrgUnitSearchResultListElementComponent } from './item-list-elements/search-result-list-elements/org-unit/org-unit-search-result-list-element.component';
import { PersonSearchResultListElementComponent } from './item-list-elements/search-result-list-elements/person/person-search-result-list-element.component';
import { ProjectSearchResultListElementComponent } from './item-list-elements/search-result-list-elements/project/project-search-result-list-element.component';
import { PersonSearchResultGridElementComponent } from './item-grid-elements/search-result-grid-elements/person/person-search-result-grid-element.component';
-import { OrgunitSearchResultGridElementComponent } from './item-grid-elements/search-result-grid-elements/orgunit/orgunit-search-result-grid-element.component';
+import { OrgUnitSearchResultGridElementComponent } from './item-grid-elements/search-result-grid-elements/org-unit/org-unit-search-result-grid-element.component';
import { ProjectSearchResultGridElementComponent } from './item-grid-elements/search-result-grid-elements/project/project-search-result-grid-element.component';
+import { PersonItemMetadataListElementComponent } from './metadata-representations/person/person-item-metadata-list-element.component';
+import { OrgUnitItemMetadataListElementComponent } from './metadata-representations/org-unit/org-unit-item-metadata-list-element.component';
const ENTRY_COMPONENTS = [
- OrgunitComponent,
+ OrgUnitComponent,
PersonComponent,
ProjectComponent,
OrgUnitListElementComponent,
- OrgunitItemPageListElementComponent,
+ OrgUnitItemMetadataListElementComponent,
PersonListElementComponent,
- PersonItemPageListElementComponent,
+ PersonItemMetadataListElementComponent,
ProjectListElementComponent,
PersonGridElementComponent,
- OrgunitGridElementComponent,
+ OrgUnitGridElementComponent,
ProjectGridElementComponent,
- OrgunitSearchResultListElementComponent,
+ OrgUnitSearchResultListElementComponent,
PersonSearchResultListElementComponent,
ProjectSearchResultListElementComponent,
PersonSearchResultGridElementComponent,
- OrgunitSearchResultGridElementComponent,
+ OrgUnitSearchResultGridElementComponent,
ProjectSearchResultGridElementComponent
];
diff --git a/src/app/shared/metadata-representation/metadata-representation-loader.component.spec.ts b/src/app/shared/metadata-representation/metadata-representation-loader.component.spec.ts
new file mode 100644
index 0000000000..4097fb99c4
--- /dev/null
+++ b/src/app/shared/metadata-representation/metadata-representation-loader.component.spec.ts
@@ -0,0 +1,63 @@
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+import { ChangeDetectionStrategy, ComponentFactoryResolver, NO_ERRORS_SCHEMA } from '@angular/core';
+import { Context } from '../../core/shared/context.model';
+import { MetadataRepresentation, MetadataRepresentationType } from '../../core/shared/metadata-representation/metadata-representation.model';
+import { MetadataRepresentationLoaderComponent } from './metadata-representation-loader.component';
+import { PlainTextMetadataListElementComponent } from '../object-list/metadata-representation-list-element/plain-text/plain-text-metadata-list-element.component';
+import { spyOnExported } from '../testing/utils';
+import { MetadataRepresentationDirective } from './metadata-representation.directive';
+import * as metadataRepresentationDecorator from './metadata-representation.decorator';
+
+const testType = 'TestType';
+const testContext = Context.Search;
+const testRepresentationType = MetadataRepresentationType.Item;
+
+class TestType implements MetadataRepresentation {
+ get itemType(): string {
+ return testType;
+ }
+
+ get representationType(): MetadataRepresentationType {
+ return testRepresentationType;
+ }
+
+ getValue(): string {
+ return '';
+ }
+}
+describe('MetadataRepresentationLoaderComponent', () => {
+ let comp: MetadataRepresentationLoaderComponent;
+ let fixture: ComponentFixture;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ imports: [],
+ declarations: [MetadataRepresentationLoaderComponent, PlainTextMetadataListElementComponent, MetadataRepresentationDirective],
+ schemas: [NO_ERRORS_SCHEMA],
+ providers: [ComponentFactoryResolver]
+ }).overrideComponent(MetadataRepresentationLoaderComponent, {
+ set: {
+ changeDetection: ChangeDetectionStrategy.Default,
+ entryComponents: [PlainTextMetadataListElementComponent]
+ }
+ }).compileComponents();
+ }));
+
+ beforeEach(async(() => {
+ fixture = TestBed.createComponent(MetadataRepresentationLoaderComponent);
+ comp = fixture.componentInstance;
+
+ comp.mdRepresentation = new TestType();
+ comp.context = testContext;
+
+ spyOnExported(metadataRepresentationDecorator, 'getMetadataRepresentationComponent').and.returnValue(PlainTextMetadataListElementComponent);
+ fixture.detectChanges();
+
+ }));
+
+ describe('When the component is rendered', () => {
+ it('should call the getMetadataRepresentationComponent function with the right entity type, representation type and context', () => {
+ expect(metadataRepresentationDecorator.getMetadataRepresentationComponent).toHaveBeenCalledWith(testType, testRepresentationType, testContext);
+ })
+ });
+});
diff --git a/src/app/shared/metadata-representation/metadata-representation.decorator.ts b/src/app/shared/metadata-representation/metadata-representation.decorator.ts
index 0903e05f56..a5ea26aa89 100644
--- a/src/app/shared/metadata-representation/metadata-representation.decorator.ts
+++ b/src/app/shared/metadata-representation/metadata-representation.decorator.ts
@@ -8,7 +8,6 @@ export const DEFAULT_ENTITY_TYPE = 'Publication';
export const DEFAULT_REPRESENTATION_TYPE = MetadataRepresentationType.PlainText;
export const DEFAULT_CONTEXT = Context.Undefined;
-
/**
* Decorator function to store metadata representation mapping
* @param entityType The entity type the component represents
diff --git a/src/app/shared/mydspace-actions/claimed-task/claimed-task-actions.component.ts b/src/app/shared/mydspace-actions/claimed-task/claimed-task-actions.component.ts
index 0ddb24ec2f..554becdb27 100644
--- a/src/app/shared/mydspace-actions/claimed-task/claimed-task-actions.component.ts
+++ b/src/app/shared/mydspace-actions/claimed-task/claimed-task-actions.component.ts
@@ -15,7 +15,7 @@ import { MyDSpaceActionsComponent } from '../mydspace-actions';
import { NotificationsService } from '../../notifications/notifications.service';
/**
- * This component represents mydspace actions related to ClaimedTask object.
+ * This component represents actions related to ClaimedTask object.
*/
@Component({
selector: 'ds-claimed-task-actions',
diff --git a/src/app/shared/mydspace-actions/workflowitem/workflowitem-actions.component.ts b/src/app/shared/mydspace-actions/workflowitem/workflowitem-actions.component.ts
index 71f854c5e7..453d875150 100644
--- a/src/app/shared/mydspace-actions/workflowitem/workflowitem-actions.component.ts
+++ b/src/app/shared/mydspace-actions/workflowitem/workflowitem-actions.component.ts
@@ -9,7 +9,7 @@ import { WorkflowItemDataService } from '../../../core/submission/workflowitem-d
import { NotificationsService } from '../../notifications/notifications.service';
/**
- * This component represents mydspace actions related to WorkflowItem object.
+ * This component represents actions related to WorkflowItem object.
*/
@Component({
selector: 'ds-workflowitem-actions',
diff --git a/src/app/shared/mydspace-actions/workspaceitem/workspaceitem-actions.component.ts b/src/app/shared/mydspace-actions/workspaceitem/workspaceitem-actions.component.ts
index 69214e800e..ca0b416b60 100644
--- a/src/app/shared/mydspace-actions/workspaceitem/workspaceitem-actions.component.ts
+++ b/src/app/shared/mydspace-actions/workspaceitem/workspaceitem-actions.component.ts
@@ -8,11 +8,10 @@ import { TranslateService } from '@ngx-translate/core';
import { WorkspaceItem } from '../../../core/submission/models/workspaceitem.model';
import { MyDSpaceActionsComponent } from '../mydspace-actions';
import { WorkspaceitemDataService } from '../../../core/submission/workspaceitem-data.service';
-import { ResourceType } from '../../../core/shared/resource-type';
import { NotificationsService } from '../../notifications/notifications.service';
/**
- * This component represents mydspace actions related to WorkspaceItem object.
+ * This component represents actions related to WorkspaceItem object.
*/
@Component({
selector: 'ds-workspaceitem-actions',
diff --git a/src/app/shared/object-collection/shared/listable-object/listable-object-component-loader.component.spec.ts b/src/app/shared/object-collection/shared/listable-object/listable-object-component-loader.component.spec.ts
new file mode 100644
index 0000000000..f470f566f0
--- /dev/null
+++ b/src/app/shared/object-collection/shared/listable-object/listable-object-component-loader.component.spec.ts
@@ -0,0 +1,58 @@
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+import { ChangeDetectionStrategy, ComponentFactoryResolver, NO_ERRORS_SCHEMA } from '@angular/core';
+import { ListableObjectComponentLoaderComponent } from './listable-object-component-loader.component';
+import { ListableObject } from '../listable-object.model';
+import { GenericConstructor } from '../../../../core/shared/generic-constructor';
+import { Context } from '../../../../core/shared/context.model';
+import { ViewMode } from '../../../../core/shared/view-mode.model';
+import * as listableObjectDecorators from './listable-object.decorator';
+import { PublicationListElementComponent } from '../../../object-list/item-list-element/item-types/publication/publication-list-element.component';
+import { ListableObjectDirective } from './listable-object.directive';
+import { spyOnExported } from '../../../testing/utils';
+
+const testType = 'TestType';
+const testContext = Context.Search;
+const testViewMode = ViewMode.StandalonePage;
+
+class TestType implements ListableObject {
+ getRenderTypes(): Array> {
+ return [testType];
+ }
+}
+
+describe('ListableObjectComponentLoaderComponent', () => {
+ let comp: ListableObjectComponentLoaderComponent;
+ let fixture: ComponentFixture;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ imports: [],
+ declarations: [ListableObjectComponentLoaderComponent, PublicationListElementComponent, ListableObjectDirective],
+ schemas: [NO_ERRORS_SCHEMA],
+ providers: [ComponentFactoryResolver]
+ }).overrideComponent(ListableObjectComponentLoaderComponent, {
+ set: {
+ changeDetection: ChangeDetectionStrategy.Default,
+ entryComponents: [PublicationListElementComponent]
+ }
+ }).compileComponents();
+ }));
+
+ beforeEach(async(() => {
+ fixture = TestBed.createComponent(ListableObjectComponentLoaderComponent);
+ comp = fixture.componentInstance;
+
+ comp.object = new TestType();
+ comp.viewMode = testViewMode;
+ comp.context = testContext;
+ spyOnExported(listableObjectDecorators, 'getListableObjectComponent').and.returnValue(PublicationListElementComponent);
+ fixture.detectChanges();
+
+ }));
+
+ describe('When the component is rendered', () => {
+ it('should call the getListableObjectComponent function with the right types, view mode and context', () => {
+ expect(listableObjectDecorators.getListableObjectComponent).toHaveBeenCalledWith([testType], testViewMode, testContext);
+ })
+ });
+});
diff --git a/src/app/shared/object-collection/shared/workflowitem-search-result.model.ts b/src/app/shared/object-collection/shared/workflow-item-search-result.model.ts
similarity index 100%
rename from src/app/shared/object-collection/shared/workflowitem-search-result.model.ts
rename to src/app/shared/object-collection/shared/workflow-item-search-result.model.ts
diff --git a/src/app/shared/object-collection/shared/workspaceitem-search-result.model.ts b/src/app/shared/object-collection/shared/workspace-item-search-result.model.ts
similarity index 100%
rename from src/app/shared/object-collection/shared/workspaceitem-search-result.model.ts
rename to src/app/shared/object-collection/shared/workspace-item-search-result.model.ts
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/claimed-task-search-result/claimed-task-search-result-detail-element.component.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/claimed-task-search-result/claimed-task-search-result-detail-element.component.ts
index fa51fa61f6..72ffca4b98 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/claimed-task-search-result/claimed-task-search-result-detail-element.component.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/claimed-task-search-result/claimed-task-search-result-detail-element.component.ts
@@ -1,4 +1,4 @@
-import { Component, Inject } from '@angular/core';
+import { Component } from '@angular/core';
import { Observable } from 'rxjs';
import { find } from 'rxjs/operators';
@@ -12,7 +12,6 @@ import { SearchResultDetailElementComponent } from '../search-result-detail-elem
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { listableObjectComponent } from '../../../object-collection/shared/listable-object/listable-object.decorator';
import { ClaimedTaskSearchResult } from '../../../object-collection/shared/claimed-task-search-result.model';
-import { Item } from '../../../../core/shared/item.model';
/**
* This component renders claimed task object for the search result in the detail view.
@@ -45,11 +44,12 @@ export class ClaimedTaskSearchResultDetailElementComponent extends SearchResultD
* Initialize all instance variables
*/
ngOnInit() {
+ super.ngOnInit();
this.initWorkflowItem(this.dso.workflowitem as Observable>);
}
/**
- * Retrieve workflowitem from result object
+ * Retrieve workflow item from result object
*/
initWorkflowItem(wfi$: Observable>) {
wfi$.pipe(
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/pool-search-result/pool-search-result-detail-element.component.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/pool-search-result/pool-search-result-detail-element.component.ts
index f0ffe0b44f..95de372713 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/pool-search-result/pool-search-result-detail-element.component.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/pool-search-result/pool-search-result-detail-element.component.ts
@@ -13,7 +13,7 @@ import { listableObjectComponent } from '../../../object-collection/shared/lista
import { PoolTaskSearchResult } from '../../../object-collection/shared/pool-task-search-result.model';
/**
- * This component renders pool task object for the mydspace result in the detail view.
+ * This component renders pool task object for the search result in the detail view.
*/
@Component({
selector: 'ds-pool-search-result-detail-element',
@@ -43,6 +43,7 @@ export class PoolSearchResultDetailElementComponent extends SearchResultDetailEl
* Initialize all instance variables
*/
ngOnInit() {
+ super.ngOnInit();
this.initWorkflowItem(this.dso.workflowitem as Observable>);
}
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.spec.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.spec.ts
index 0e1a3bd307..2e6ad0ef95 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.spec.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.spec.ts
@@ -9,7 +9,7 @@ import { WorkflowItemSearchResultDetailElementComponent } from './workflow-item-
import { WorkflowItem } from '../../../../core/submission/models/workflowitem.model';
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { createSuccessfulRemoteDataObject } from '../../../testing/utils';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
let component: WorkflowItemSearchResultDetailElementComponent;
let fixture: ComponentFixture;
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.ts
index 830c842223..23a8ad9e18 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/workflow-item-search-result/workflow-item-search-result-detail-element.component.ts
@@ -10,7 +10,7 @@ import { RemoteData } from '../../../../core/data/remote-data';
import { find } from 'rxjs/operators';
import { isNotUndefined } from '../../../empty.util';
import { listableObjectComponent } from '../../../object-collection/shared/listable-object/listable-object.decorator';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
/**
* This component renders workflowitem object for the search result in the detail view.
@@ -38,6 +38,7 @@ export class WorkflowItemSearchResultDetailElementComponent extends SearchResult
* Initialize all instance variables
*/
ngOnInit() {
+ super.ngOnInit();
this.initItem(this.dso.item as Observable>);
}
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.spec.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.spec.ts
index c841bf1dab..fb5793b3bb 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.spec.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.spec.ts
@@ -9,7 +9,7 @@ import { WorkspaceItemSearchResultDetailElementComponent } from './workspace-ite
import { WorkspaceItem } from '../../../../core/submission/models/workspaceitem.model';
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { createSuccessfulRemoteDataObject } from '../../../testing/utils';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
let component: WorkspaceItemSearchResultDetailElementComponent;
let fixture: ComponentFixture;
diff --git a/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.ts b/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.ts
index 0f8e1a65cb..746fd02889 100644
--- a/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.ts
+++ b/src/app/shared/object-detail/my-dspace-result-detail-element/workspace-item-search-result/workspace-item-search-result-detail-element.component.ts
@@ -11,7 +11,7 @@ import { SearchResultDetailElementComponent } from '../search-result-detail-elem
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { ViewMode } from '../../../../core/shared/view-mode.model';
import { listableObjectComponent } from '../../../object-collection/shared/listable-object/listable-object.decorator';
-import { WorkspaceItemSearchResult } from '../../../object-collection/shared/workspaceitem-search-result.model';
+import { WorkspaceItemSearchResult } from '../../../object-collection/shared/workspace-item-search-result.model';
/**
* This component renders workspace item object for the search result in the detail view.
@@ -39,6 +39,7 @@ export class WorkspaceItemSearchResultDetailElementComponent extends SearchResul
* Initialize all instance variables
*/
ngOnInit() {
+ super.ngOnInit();
this.initItem(this.dso.item as Observable>);
}
diff --git a/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.html b/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.html
index 4ecb8c0c51..91219c7189 100644
--- a/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.html
+++ b/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.html
@@ -1,2 +1 @@
-
-
+
diff --git a/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.spec.ts b/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.spec.ts
index fe2ada3aff..8c5cec4aba 100644
--- a/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.spec.ts
+++ b/src/app/shared/object-list/metadata-representation-list-element/item/item-metadata-list-element.component.spec.ts
@@ -27,9 +27,9 @@ describe('ItemMetadataListElementComponent', () => {
fixture.detectChanges();
}));
- it('should call an item-type-switcher component and pass the item-metadata-representation', () => {
- const itemTypeSwitcher = fixture.debugElement.query(By.css('ds-listable-object-component-loader')).nativeElement;
- expect(itemTypeSwitcher.object).toBe(mockItemMetadataRepresentation);
+ it('should call a listable-object-component-loader component and pass the item-metadata-representation', () => {
+ const objectLoader = fixture.debugElement.query(By.css('ds-listable-object-component-loader')).nativeElement;
+ expect(objectLoader.object).toBe(mockItemMetadataRepresentation);
});
});
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/claimed-search-result/claimed-search-result-list-element.component.ts b/src/app/shared/object-list/my-dspace-result-list-element/claimed-search-result/claimed-search-result-list-element.component.ts
index 6c1250773f..35371f40aa 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/claimed-search-result/claimed-search-result-list-element.component.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/claimed-search-result/claimed-search-result-list-element.component.ts
@@ -19,7 +19,7 @@ import { SearchResultListElementComponent } from '../../search-result-list-eleme
*/
@Component({
selector: 'ds-claimed-search-result-list-element',
- styleUrls: ['../my-dspace-result-list-element.component.scss'],
+ styleUrls: ['../../search-result-list-element/search-result-list-element.component.scss'],
templateUrl: './claimed-search-result-list-element.component.html',
providers: [Location, { provide: LocationStrategy, useClass: PathLocationStrategy }]
})
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/item-search-result/item-search-result-list-element-submission.component.ts b/src/app/shared/object-list/my-dspace-result-list-element/item-search-result/item-search-result-list-element-submission.component.ts
index db0216908d..6a3cc3befb 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/item-search-result/item-search-result-list-element-submission.component.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/item-search-result/item-search-result-list-element-submission.component.ts
@@ -13,7 +13,7 @@ import { SearchResultListElementComponent } from '../../search-result-list-eleme
*/
@Component({
selector: 'ds-item-search-result-list-element-submission',
- styleUrls: ['../my-dspace-result-list-element.component.scss', './item-search-result-list-element-submission.component.scss'],
+ styleUrls: ['../../search-result-list-element/search-result-list-element.component.scss', './item-search-result-list-element-submission.component.scss'],
templateUrl: './item-search-result-list-element-submission.component.html'
})
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/my-dspace-result-list-element.component.scss b/src/app/shared/object-list/my-dspace-result-list-element/my-dspace-result-list-element.component.scss
deleted file mode 100644
index 4cd8a2b697..0000000000
--- a/src/app/shared/object-list/my-dspace-result-list-element/my-dspace-result-list-element.component.scss
+++ /dev/null
@@ -1 +0,0 @@
-@import '../search-result-list-element/search-result-list-element.component.scss';
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/pool-search-result/pool-search-result-list-element.component.ts b/src/app/shared/object-list/my-dspace-result-list-element/pool-search-result/pool-search-result-list-element.component.ts
index 93941f8a81..b34e23c3e6 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/pool-search-result/pool-search-result-list-element.component.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/pool-search-result/pool-search-result-list-element.component.ts
@@ -19,7 +19,7 @@ import { TruncatableService } from '../../../truncatable/truncatable.service';
*/
@Component({
selector: 'ds-pool-search-result-list-element',
- styleUrls: ['../my-dspace-result-list-element.component.scss'],
+ styleUrls: ['../../search-result-list-element/search-result-list-element.component.scss'],
templateUrl: './pool-search-result-list-element.component.html',
})
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.spec.ts b/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.spec.ts
index 90036142c4..4ecdbea4d6 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.spec.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.spec.ts
@@ -9,7 +9,7 @@ import { WorkflowItem } from '../../../../core/submission/models/workflowitem.mo
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { createSuccessfulRemoteDataObject } from '../../../testing/utils';
import { WorkflowItemSearchResultListElementComponent } from './workflow-item-search-result-list-element.component';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
import { TruncatableService } from '../../../truncatable/truncatable.service';
let component: WorkflowItemSearchResultListElementComponent;
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.ts b/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.ts
index 8182342c3a..faf03425f0 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/workflow-item-search-result/workflow-item-search-result-list-element.component.ts
@@ -10,7 +10,7 @@ import { WorkflowItem } from '../../../../core/submission/models/workflowitem.mo
import { Item } from '../../../../core/shared/item.model';
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { listableObjectComponent } from '../../../object-collection/shared/listable-object/listable-object.decorator';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
import { SearchResultListElementComponent } from '../../search-result-list-element/search-result-list-element.component';
/**
@@ -18,7 +18,7 @@ import { SearchResultListElementComponent } from '../../search-result-list-eleme
*/
@Component({
selector: 'ds-workflow-item-my-dspace-result-list-element',
- styleUrls: ['../my-dspace-result-list-element.component.scss'],
+ styleUrls: ['../../search-result-list-element/search-result-list-element.component.scss'],
templateUrl: './workflow-item-search-result-list-element.component.html',
})
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.spec.ts b/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.spec.ts
index eac4320bd7..349f32dfd6 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.spec.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.spec.ts
@@ -9,7 +9,7 @@ import { WorkspaceItemSearchResultListElementComponent } from './workspace-item-
import { WorkspaceItem } from '../../../../core/submission/models/workspaceitem.model';
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { createSuccessfulRemoteDataObject } from '../../../testing/utils';
-import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflowitem-search-result.model';
+import { WorkflowItemSearchResult } from '../../../object-collection/shared/workflow-item-search-result.model';
import { TruncatableService } from '../../../truncatable/truncatable.service';
let component: WorkspaceItemSearchResultListElementComponent;
diff --git a/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.ts b/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.ts
index 2e9363decc..830726c677 100644
--- a/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.ts
+++ b/src/app/shared/object-list/my-dspace-result-list-element/workspace-item-search-result/workspace-item-search-result-list-element.component.ts
@@ -10,7 +10,7 @@ import { isNotUndefined } from '../../../empty.util';
import { Item } from '../../../../core/shared/item.model';
import { MyDspaceItemStatusType } from '../../../object-collection/shared/mydspace-item-status/my-dspace-item-status-type';
import { listableObjectComponent } from '../../../object-collection/shared/listable-object/listable-object.decorator';
-import { WorkspaceItemSearchResult } from '../../../object-collection/shared/workspaceitem-search-result.model';
+import { WorkspaceItemSearchResult } from '../../../object-collection/shared/workspace-item-search-result.model';
import { SearchResultListElementComponent } from '../../search-result-list-element/search-result-list-element.component';
/**
@@ -18,7 +18,7 @@ import { SearchResultListElementComponent } from '../../search-result-list-eleme
*/
@Component({
selector: 'ds-workspace-item-search-result-list-element',
- styleUrls: ['../my-dspace-result-list-element.component.scss', './workspace-item-search-result-list-element.component.scss'],
+ styleUrls: ['../../search-result-list-element/search-result-list-element.component.scss', './workspace-item-search-result-list-element.component.scss'],
templateUrl: './workspace-item-search-result-list-element.component.html',
})
diff --git a/src/app/shared/object-list/object-list.component.ts b/src/app/shared/object-list/object-list.component.ts
index e1dabce943..1158085bb0 100644
--- a/src/app/shared/object-list/object-list.component.ts
+++ b/src/app/shared/object-list/object-list.component.ts
@@ -70,7 +70,6 @@ export class ObjectListComponent {
*/
private _objects: RemoteData>;
-
/**
* Setter for the objects
* @param objects The new objects
diff --git a/src/app/shared/testing/utils.ts b/src/app/shared/testing/utils.ts
index 4a551582ee..afd048096a 100644
--- a/src/app/shared/testing/utils.ts
+++ b/src/app/shared/testing/utils.ts
@@ -121,3 +121,14 @@ export function createPendingRemoteDataObject(object?: T): RemoteData {
export function createPendingRemoteDataObject$(object?: T): Observable> {
return observableOf(createPendingRemoteDataObject(object));
}
+
+/**
+ * Creates a jasmine spy for an exported function
+ * @param target The object to spy on
+ * @param prop The property/function to spy on
+ */
+export function spyOnExported(target: T, prop: keyof T): jasmine.Spy {
+ const spy = jasmine.createSpy(`${prop}Spy`);
+ spyOnProperty(target, prop).and.returnValue(spy);
+ return spy;
+}