diff --git a/src/app/curation-form/curation-form.component.ts b/src/app/curation-form/curation-form.component.ts
index 4b67580e77..e8fc67c970 100644
--- a/src/app/curation-form/curation-form.component.ts
+++ b/src/app/curation-form/curation-form.component.ts
@@ -1,4 +1,4 @@
-import { Component, Input, OnInit } from '@angular/core';
+import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';
import { ScriptDataService } from '../core/data/processes/script-data.service';
import { FormControl, FormGroup } from '@angular/forms';
import { getFirstCompletedRemoteData } from '../core/shared/operators';
@@ -40,7 +40,8 @@ export class CurationFormComponent implements OnInit {
private notificationsService: NotificationsService,
private translateService: TranslateService,
private handleService: HandleService,
- private router: Router
+ private router: Router,
+ private cdr: ChangeDetectorRef
) {
}
@@ -59,6 +60,7 @@ export class CurationFormComponent implements OnInit {
.filter((value) => isNotEmpty(value) && value.includes('='))
.map((value) => value.split('=')[1].trim());
this.form.get('task').patchValue(this.tasks[0]);
+ this.cdr.detectChanges();
});
}
diff --git a/src/app/item-page/edit-item-page/edit-item-page.module.ts b/src/app/item-page/edit-item-page/edit-item-page.module.ts
index 24d27b3340..7692df8924 100644
--- a/src/app/item-page/edit-item-page/edit-item-page.module.ts
+++ b/src/app/item-page/edit-item-page/edit-item-page.module.ts
@@ -38,7 +38,7 @@ import { IdentifierDataService } from '../../core/data/identifier-data.service';
import { IdentifierDataComponent } from '../../shared/object-list/identifier-data/identifier-data.component';
import { ItemRegisterDoiComponent } from './item-register-doi/item-register-doi.component';
import { DsoSharedModule } from '../../dso-shared/dso-shared.module';
-
+import { ItemCurateComponent } from './item-curate/item-curate.component';
/**
* Module that contains all components related to the Edit Item page administrator functionality
@@ -81,7 +81,8 @@ import { DsoSharedModule } from '../../dso-shared/dso-shared.module';
VirtualMetadataComponent,
ItemAuthorizationsComponent,
IdentifierDataComponent,
- ItemRegisterDoiComponent
+ ItemRegisterDoiComponent,
+ ItemCurateComponent
],
providers: [
BundleDataService,
diff --git a/src/app/item-page/edit-item-page/edit-item-page.routing.module.ts b/src/app/item-page/edit-item-page/edit-item-page.routing.module.ts
index 88172e2620..9923748338 100644
--- a/src/app/item-page/edit-item-page/edit-item-page.routing.module.ts
+++ b/src/app/item-page/edit-item-page/edit-item-page.routing.module.ts
@@ -41,6 +41,7 @@ import { ItemPageVersionHistoryGuard } from './item-page-version-history.guard';
import { ItemPageCollectionMapperGuard } from './item-page-collection-mapper.guard';
import { ThemedDsoEditMetadataComponent } from '../../dso-shared/dso-edit-metadata/themed-dso-edit-metadata.component';
import { ItemPageRegisterDoiGuard } from './item-page-register-doi.guard';
+import { ItemCurateComponent } from './item-curate/item-curate.component';
/**
* Routing module that handles the routing for the Edit Item page administrator functionality
@@ -82,6 +83,11 @@ import { ItemPageRegisterDoiGuard } from './item-page-register-doi.guard';
data: { title: 'item.edit.tabs.metadata.title', showBreadcrumbs: true },
canActivate: [ItemPageMetadataGuard]
},
+ {
+ path: 'curate',
+ component: ItemCurateComponent,
+ data: { title: 'item.edit.tabs.curate.title', showBreadcrumbs: true }
+ },
{
path: 'relationships',
component: ItemRelationshipsComponent,
diff --git a/src/app/item-page/edit-item-page/item-curate/item-curate.component.html b/src/app/item-page/edit-item-page/item-curate/item-curate.component.html
new file mode 100644
index 0000000000..7c7ed41bd9
--- /dev/null
+++ b/src/app/item-page/edit-item-page/item-curate/item-curate.component.html
@@ -0,0 +1,7 @@
+
+
{{'item.edit.curate.title' |translate:{item: (itemName$ |async)} }}
+
+
diff --git a/src/app/item-page/edit-item-page/item-curate/item-curate.component.spec.ts b/src/app/item-page/edit-item-page/item-curate/item-curate.component.spec.ts
new file mode 100644
index 0000000000..c104b4400b
--- /dev/null
+++ b/src/app/item-page/edit-item-page/item-curate/item-curate.component.spec.ts
@@ -0,0 +1,75 @@
+import { ComponentFixture, TestBed, waitForAsync } from '@angular/core/testing';
+import { TranslateModule } from '@ngx-translate/core';
+import { CUSTOM_ELEMENTS_SCHEMA, DebugElement } from '@angular/core';
+import { ItemCurateComponent } from './item-curate.component';
+import { of as observableOf } from 'rxjs';
+import { createSuccessfulRemoteDataObject } from '../../../shared/remote-data.utils';
+import { ActivatedRoute } from '@angular/router';
+import { DSONameService } from '../../../core/breadcrumbs/dso-name.service';
+import { Item } from '../../../core/shared/item.model';
+
+describe('ItemCurateComponent', () => {
+ let comp: ItemCurateComponent;
+ let fixture: ComponentFixture;
+ let debugEl: DebugElement;
+
+ let routeStub;
+ let dsoNameService;
+
+ const item = Object.assign(new Item(), {
+ handle: '123456789/1',
+ metadata: {'dc.title': ['Item Name']}
+ });
+
+ beforeEach(waitForAsync(() => {
+ routeStub = {
+ parent: {
+ data: observableOf({
+ dso: createSuccessfulRemoteDataObject(item)
+ })
+ }
+ };
+
+ dsoNameService = jasmine.createSpyObj('dsoNameService', {
+ getName: 'Item Name'
+ });
+
+ TestBed.configureTestingModule({
+ imports: [TranslateModule.forRoot()],
+ declarations: [ItemCurateComponent],
+ providers: [
+ {provide: ActivatedRoute, useValue: routeStub},
+ {provide: DSONameService, useValue: dsoNameService}
+ ],
+ schemas: [CUSTOM_ELEMENTS_SCHEMA]
+ }).compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(ItemCurateComponent);
+ comp = fixture.componentInstance;
+ debugEl = fixture.debugElement;
+
+ fixture.detectChanges();
+ });
+ describe('init', () => {
+ it('should initialise the comp', () => {
+ expect(comp).toBeDefined();
+ expect(debugEl.nativeElement.innerHTML).toContain('ds-curation-form');
+ });
+
+ it('should contain the item information provided in the route', (done) => {
+ comp.dsoRD$.subscribe((value) => {
+ expect(value.payload.handle).toEqual('123456789/1');
+ done();
+ });
+ });
+
+ it('should contain the item name', (done) => {
+ comp.itemName$.subscribe((value) => {
+ expect(value).toEqual('Item Name');
+ done();
+ });
+ });
+ });
+});
diff --git a/src/app/item-page/edit-item-page/item-curate/item-curate.component.ts b/src/app/item-page/edit-item-page/item-curate/item-curate.component.ts
new file mode 100644
index 0000000000..fa1e0287fa
--- /dev/null
+++ b/src/app/item-page/edit-item-page/item-curate/item-curate.component.ts
@@ -0,0 +1,39 @@
+import { Component, OnInit } from '@angular/core';
+import { filter, map, take } from 'rxjs/operators';
+import { RemoteData } from '../../../core/data/remote-data';
+import { Observable } from 'rxjs';
+import { ActivatedRoute } from '@angular/router';
+import { DSONameService } from '../../../core/breadcrumbs/dso-name.service';
+import { hasValue } from '../../../shared/empty.util';
+import { Item } from '../../../core/shared/item.model';
+
+/**
+ * Component for managing a collection's curation tasks
+ */
+@Component({
+ selector: 'ds-item-curate',
+ templateUrl: './item-curate.component.html',
+})
+export class ItemCurateComponent implements OnInit {
+ dsoRD$: Observable>;
+ itemName$: Observable;
+
+ constructor(
+ private route: ActivatedRoute,
+ private dsoNameService: DSONameService,
+ ) {}
+
+ ngOnInit(): void {
+ this.dsoRD$ = this.route.parent.data.pipe(
+ take(1),
+ map((data) => data.dso),
+ );
+
+ this.itemName$ = this.dsoRD$.pipe(
+ filter((rd: RemoteData- ) => hasValue(rd)),
+ map((rd: RemoteData
- ) => {
+ return this.dsoNameService.getName(rd.payload);
+ })
+ );
+ }
+}
diff --git a/src/assets/i18n/en.json5 b/src/assets/i18n/en.json5
index 66824e56b3..1af7c36e19 100644
--- a/src/assets/i18n/en.json5
+++ b/src/assets/i18n/en.json5
@@ -2291,6 +2291,7 @@
"item.edit.tabs.curate.head": "Curate",
"item.edit.tabs.curate.title": "Item Edit - Curate",
+ "item.edit.curate.title": "Curate Item: {{item}}",
"item.edit.tabs.metadata.head": "Metadata",