mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 10:04:11 +00:00
127047: Merge branch 'themed-SubmissionComponents_contribute-7.6' into 'themed-SubmissionComponents_contribute-main'
This commit is contained in:
@@ -1,10 +1,10 @@
|
|||||||
<div class="submission-submit-container" >
|
<div class="submission-submit-container" >
|
||||||
<ds-submission-form [collectionId]="collectionId"
|
<ds-themed-submission-form [collectionId]="collectionId"
|
||||||
[sections]="sections"
|
[sections]="sections"
|
||||||
[selfUrl]="selfUrl"
|
[selfUrl]="selfUrl"
|
||||||
[submissionDefinition]="submissionDefinition"
|
[submissionDefinition]="submissionDefinition"
|
||||||
[submissionErrors]="submissionErrors"
|
[submissionErrors]="submissionErrors"
|
||||||
[item]="item"
|
[item]="item"
|
||||||
[collectionModifiable]="collectionModifiable"
|
[collectionModifiable]="collectionModifiable"
|
||||||
[submissionId]="submissionId"></ds-submission-form>
|
[submissionId]="submissionId"></ds-themed-submission-form>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -0,0 +1,27 @@
|
|||||||
|
import { ThemedComponent } from '../../../shared/theme-support/themed.component';
|
||||||
|
import { SubmissionFormFooterComponent } from './submission-form-footer.component';
|
||||||
|
import { Component, Input } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-themed-submission-form-footer',
|
||||||
|
styleUrls: [],
|
||||||
|
templateUrl: '../../../shared/theme-support/themed.component.html',
|
||||||
|
})
|
||||||
|
export class ThemedSubmissionFormFooterComponent extends ThemedComponent<SubmissionFormFooterComponent> {
|
||||||
|
@Input() submissionId: string;
|
||||||
|
|
||||||
|
protected inAndOutputNames: (keyof SubmissionFormFooterComponent & keyof this)[] = ['submissionId'];
|
||||||
|
|
||||||
|
protected getComponentName(): string {
|
||||||
|
return 'SubmissionFormFooterComponent';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importThemedComponent(themeName: string): Promise<any> {
|
||||||
|
return import(`../../../../themes/${themeName}/app/submission/form/footer/submission-form-footer.component`);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importUnthemedComponent(): Promise<any> {
|
||||||
|
return import(`./submission-form-footer.component`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -31,18 +31,18 @@
|
|||||||
|
|
||||||
<div class="submission-form-content">
|
<div class="submission-form-content">
|
||||||
@if ((isLoading() | async)) {
|
@if ((isLoading() | async)) {
|
||||||
<ds-loading message="Loading..."></ds-loading>
|
<ds-themed-loading message="Loading..."></ds-themed-loading>
|
||||||
}
|
}
|
||||||
@for (object of $any(submissionSections | async); track object) {
|
@for (object of $any(submissionSections | async); track object) {
|
||||||
<ds-submission-section-container [collectionId]="collectionId"
|
<ds-themed-submission-section-container [collectionId]="collectionId"
|
||||||
[submissionId]="submissionId"
|
[submissionId]="submissionId"
|
||||||
[sectionData]="$any(object)">
|
[sectionData]="$any(object)">
|
||||||
</ds-submission-section-container>
|
</ds-themed-submission-section-container>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
@if ((isLoading() | async) !== true) {
|
@if ((isLoading() | async) !== true) {
|
||||||
<div class="submission-form-footer mt-3 mb-3 position-sticky">
|
<div class="submission-form-footer mt-3 mb-3 position-sticky">
|
||||||
<ds-submission-form-footer [submissionId]="submissionId"></ds-submission-form-footer>
|
<ds-themed-submission-form-footer [submissionId]="submissionId"></ds-themed-submission-form-footer>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
|
44
src/app/submission/form/themed-submission-form.component.ts
Normal file
44
src/app/submission/form/themed-submission-form.component.ts
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
import { ThemedComponent } from '../../shared/theme-support/themed.component';
|
||||||
|
import { SubmissionFormComponent } from './submission-form.component';
|
||||||
|
import { Component, Input } from '@angular/core';
|
||||||
|
import { Item } from '../../core/shared/item.model';
|
||||||
|
import { WorkspaceitemSectionsObject } from '../../core/submission/models/workspaceitem-sections.model';
|
||||||
|
import { SubmissionError } from '../objects/submission-error.model';
|
||||||
|
import { SubmissionDefinitionsModel } from '../../core/config/models/config-submission-definitions.model';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-themed-submission-form',
|
||||||
|
styleUrls: [],
|
||||||
|
templateUrl: '../../shared/theme-support/themed.component.html',
|
||||||
|
})
|
||||||
|
export class ThemedSubmissionFormComponent extends ThemedComponent<SubmissionFormComponent> {
|
||||||
|
@Input() collectionId: string;
|
||||||
|
|
||||||
|
@Input() item: Item;
|
||||||
|
|
||||||
|
@Input() collectionModifiable: boolean | null = null;
|
||||||
|
|
||||||
|
@Input() sections: WorkspaceitemSectionsObject;
|
||||||
|
|
||||||
|
@Input() submissionErrors: SubmissionError;
|
||||||
|
|
||||||
|
@Input() selfUrl: string;
|
||||||
|
|
||||||
|
@Input() submissionDefinition: SubmissionDefinitionsModel;
|
||||||
|
|
||||||
|
@Input() submissionId: string;
|
||||||
|
|
||||||
|
protected inAndOutputNames: (keyof SubmissionFormComponent & keyof this)[] = ['collectionId', 'item', 'collectionModifiable', 'sections', 'submissionErrors', 'selfUrl', 'submissionDefinition', 'submissionId'];
|
||||||
|
|
||||||
|
protected getComponentName(): string {
|
||||||
|
return 'SubmissionFormComponent';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importThemedComponent(themeName: string): Promise<any> {
|
||||||
|
return import(`../../../themes/${themeName}/app/submission/form/submission-form.component`);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importUnthemedComponent(): Promise<any> {
|
||||||
|
return import(`./submission-form.component`);
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,29 @@
|
|||||||
|
import { ThemedComponent } from '../../../shared/theme-support/themed.component';
|
||||||
|
import { SubmissionSectionContainerComponent } from './section-container.component';
|
||||||
|
import { Component, Input } from '@angular/core';
|
||||||
|
import { SectionDataObject } from '../models/section-data.model';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-themed-submission-section-container',
|
||||||
|
styleUrls: [],
|
||||||
|
templateUrl: '../../../shared/theme-support/themed.component.html',
|
||||||
|
})
|
||||||
|
export class ThemedSubmissionSectionContainerComponent extends ThemedComponent<SubmissionSectionContainerComponent> {
|
||||||
|
@Input() collectionId: string;
|
||||||
|
@Input() sectionData: SectionDataObject;
|
||||||
|
@Input() submissionId: string;
|
||||||
|
|
||||||
|
protected inAndOutputNames: (keyof SubmissionSectionContainerComponent & keyof this)[] = ['collectionId', 'sectionData', 'submissionId'];
|
||||||
|
|
||||||
|
protected getComponentName(): string {
|
||||||
|
return 'SubmissionSectionContainerComponent';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importThemedComponent(themeName: string): Promise<any> {
|
||||||
|
return import(`../../../../themes/${themeName}/app/submission/sections/container/section-container.component`);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected importUnthemedComponent(): Promise<any> {
|
||||||
|
return import(`./section-container.component`);
|
||||||
|
}
|
||||||
|
}
|
161
src/app/submission/submission.module.ts
Normal file
161
src/app/submission/submission.module.ts
Normal file
@@ -0,0 +1,161 @@
|
|||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import { CoreModule } from '../core/core.module';
|
||||||
|
import { SharedModule } from '../shared/shared.module';
|
||||||
|
|
||||||
|
import { SubmissionSectionFormComponent } from './sections/form/section-form.component';
|
||||||
|
import { SectionsDirective } from './sections/sections.directive';
|
||||||
|
import { SectionsService } from './sections/sections.service';
|
||||||
|
import { SubmissionFormCollectionComponent } from './form/collection/submission-form-collection.component';
|
||||||
|
import { SubmissionFormFooterComponent } from './form/footer/submission-form-footer.component';
|
||||||
|
import { SubmissionFormComponent } from './form/submission-form.component';
|
||||||
|
import { SubmissionFormSectionAddComponent } from './form/section-add/submission-form-section-add.component';
|
||||||
|
import { SubmissionSectionContainerComponent } from './sections/container/section-container.component';
|
||||||
|
import { CommonModule } from '@angular/common';
|
||||||
|
import { Action, StoreConfig, StoreModule } from '@ngrx/store';
|
||||||
|
import { EffectsModule } from '@ngrx/effects';
|
||||||
|
import { submissionReducers, SubmissionState } from './submission.reducers';
|
||||||
|
import { submissionEffects } from './submission.effects';
|
||||||
|
import { SubmissionSectionUploadComponent } from './sections/upload/section-upload.component';
|
||||||
|
import { SectionUploadService } from './sections/upload/section-upload.service';
|
||||||
|
import { SubmissionUploadFilesComponent } from './form/submission-upload-files/submission-upload-files.component';
|
||||||
|
import { SubmissionSectionLicenseComponent } from './sections/license/section-license.component';
|
||||||
|
import { SubmissionUploadsConfigDataService } from '../core/config/submission-uploads-config-data.service';
|
||||||
|
import { SubmissionEditComponent } from './edit/submission-edit.component';
|
||||||
|
import { SubmissionSectionUploadFileComponent } from './sections/upload/file/section-upload-file.component';
|
||||||
|
import {
|
||||||
|
SubmissionSectionUploadFileEditComponent
|
||||||
|
} from './sections/upload/file/edit/section-upload-file-edit.component';
|
||||||
|
import {
|
||||||
|
SubmissionSectionUploadFileViewComponent
|
||||||
|
} from './sections/upload/file/view/section-upload-file-view.component';
|
||||||
|
import {
|
||||||
|
SubmissionSectionUploadAccessConditionsComponent
|
||||||
|
} from './sections/upload/accessConditions/submission-section-upload-access-conditions.component';
|
||||||
|
import { SubmissionSubmitComponent } from './submit/submission-submit.component';
|
||||||
|
import { storeModuleConfig } from '../app.reducer';
|
||||||
|
import { SubmissionImportExternalComponent } from './import-external/submission-import-external.component';
|
||||||
|
import {
|
||||||
|
SubmissionImportExternalSearchbarComponent
|
||||||
|
} from './import-external/import-external-searchbar/submission-import-external-searchbar.component';
|
||||||
|
import {
|
||||||
|
SubmissionImportExternalPreviewComponent
|
||||||
|
} from './import-external/import-external-preview/submission-import-external-preview.component';
|
||||||
|
import {
|
||||||
|
SubmissionImportExternalCollectionComponent
|
||||||
|
} from './import-external/import-external-collection/submission-import-external-collection.component';
|
||||||
|
import { SubmissionSectionCcLicensesComponent } from './sections/cc-license/submission-section-cc-licenses.component';
|
||||||
|
import { JournalEntitiesModule } from '../entity-groups/journal-entities/journal-entities.module';
|
||||||
|
import { ResearchEntitiesModule } from '../entity-groups/research-entities/research-entities.module';
|
||||||
|
import { ThemedSubmissionEditComponent } from './edit/themed-submission-edit.component';
|
||||||
|
import { ThemedSubmissionSubmitComponent } from './submit/themed-submission-submit.component';
|
||||||
|
import { ThemedSubmissionImportExternalComponent } from './import-external/themed-submission-import-external.component';
|
||||||
|
import { ThemedSubmissionSectionUploadFileComponent } from './sections/upload/file/themed-section-upload-file.component';
|
||||||
|
import { FormModule } from '../shared/form/form.module';
|
||||||
|
import { NgbAccordionModule, NgbCollapseModule, NgbModalModule } from '@ng-bootstrap/ng-bootstrap';
|
||||||
|
import { SubmissionSectionAccessesComponent } from './sections/accesses/section-accesses.component';
|
||||||
|
import { SubmissionAccessesConfigDataService } from '../core/config/submission-accesses-config-data.service';
|
||||||
|
import { SectionAccessesService } from './sections/accesses/section-accesses.service';
|
||||||
|
import { SubmissionSectionSherpaPoliciesComponent } from './sections/sherpa-policies/section-sherpa-policies.component';
|
||||||
|
import { ContentAccordionComponent } from './sections/sherpa-policies/content-accordion/content-accordion.component';
|
||||||
|
import { PublisherPolicyComponent } from './sections/sherpa-policies/publisher-policy/publisher-policy.component';
|
||||||
|
import {
|
||||||
|
PublicationInformationComponent
|
||||||
|
} from './sections/sherpa-policies/publication-information/publication-information.component';
|
||||||
|
import { UploadModule } from '../shared/upload/upload.module';
|
||||||
|
import {
|
||||||
|
MetadataInformationComponent
|
||||||
|
} from './sections/sherpa-policies/metadata-information/metadata-information.component';
|
||||||
|
import { SectionFormOperationsService } from './sections/form/section-form-operations.service';
|
||||||
|
import {SubmissionSectionIdentifiersComponent} from './sections/identifiers/section-identifiers.component';
|
||||||
|
import { ThemedSubmissionSectionContainerComponent } from './sections/container/themed-section-container.component';
|
||||||
|
import { ThemedSubmissionFormFooterComponent } from './form/footer/themed-submission-form-footer.component';
|
||||||
|
import { ThemedSubmissionFormComponent } from './form/themed-submission-form.component';
|
||||||
|
|
||||||
|
const ENTRY_COMPONENTS = [
|
||||||
|
// put only entry components that use custom decorator
|
||||||
|
SubmissionSectionUploadComponent,
|
||||||
|
SubmissionSectionFormComponent,
|
||||||
|
SubmissionSectionLicenseComponent,
|
||||||
|
SubmissionSectionCcLicensesComponent,
|
||||||
|
SubmissionSectionAccessesComponent,
|
||||||
|
SubmissionSectionSherpaPoliciesComponent,
|
||||||
|
];
|
||||||
|
|
||||||
|
const DECLARATIONS = [
|
||||||
|
...ENTRY_COMPONENTS,
|
||||||
|
SectionsDirective,
|
||||||
|
SubmissionEditComponent,
|
||||||
|
ThemedSubmissionEditComponent,
|
||||||
|
SubmissionFormSectionAddComponent,
|
||||||
|
SubmissionFormCollectionComponent,
|
||||||
|
SubmissionFormComponent,
|
||||||
|
SubmissionFormFooterComponent,
|
||||||
|
SubmissionSubmitComponent,
|
||||||
|
ThemedSubmissionSubmitComponent,
|
||||||
|
SubmissionUploadFilesComponent,
|
||||||
|
SubmissionSectionContainerComponent,
|
||||||
|
SubmissionSectionUploadAccessConditionsComponent,
|
||||||
|
SubmissionSectionUploadFileComponent,
|
||||||
|
SubmissionSectionUploadFileEditComponent,
|
||||||
|
SubmissionSectionUploadFileViewComponent,
|
||||||
|
SubmissionSectionIdentifiersComponent,
|
||||||
|
SubmissionImportExternalComponent,
|
||||||
|
ThemedSubmissionImportExternalComponent,
|
||||||
|
SubmissionImportExternalSearchbarComponent,
|
||||||
|
SubmissionImportExternalPreviewComponent,
|
||||||
|
SubmissionImportExternalCollectionComponent,
|
||||||
|
ContentAccordionComponent,
|
||||||
|
PublisherPolicyComponent,
|
||||||
|
PublicationInformationComponent,
|
||||||
|
MetadataInformationComponent,
|
||||||
|
ThemedSubmissionSectionUploadFileComponent,
|
||||||
|
ThemedSubmissionSectionContainerComponent,
|
||||||
|
ThemedSubmissionFormFooterComponent,
|
||||||
|
ThemedSubmissionFormComponent,
|
||||||
|
];
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
CommonModule,
|
||||||
|
CoreModule.forRoot(),
|
||||||
|
SharedModule,
|
||||||
|
StoreModule.forFeature('submission', submissionReducers, storeModuleConfig as StoreConfig<SubmissionState, Action>),
|
||||||
|
EffectsModule.forFeature(submissionEffects),
|
||||||
|
JournalEntitiesModule.withEntryComponents(),
|
||||||
|
ResearchEntitiesModule.withEntryComponents(),
|
||||||
|
FormModule,
|
||||||
|
NgbModalModule,
|
||||||
|
NgbCollapseModule,
|
||||||
|
NgbAccordionModule,
|
||||||
|
UploadModule,
|
||||||
|
],
|
||||||
|
declarations: DECLARATIONS,
|
||||||
|
exports: [
|
||||||
|
...DECLARATIONS,
|
||||||
|
FormModule,
|
||||||
|
],
|
||||||
|
providers: [
|
||||||
|
SectionUploadService,
|
||||||
|
SectionsService,
|
||||||
|
SubmissionUploadsConfigDataService,
|
||||||
|
SubmissionAccessesConfigDataService,
|
||||||
|
SectionAccessesService,
|
||||||
|
SectionFormOperationsService,
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This module handles all components that are necessary for the submission process
|
||||||
|
*/
|
||||||
|
export class SubmissionModule {
|
||||||
|
/**
|
||||||
|
* NOTE: this method allows to resolve issue with components that using a custom decorator
|
||||||
|
* which are not loaded during SSR otherwise
|
||||||
|
*/
|
||||||
|
static withEntryComponents() {
|
||||||
|
return {
|
||||||
|
ngModule: SubmissionModule,
|
||||||
|
providers: ENTRY_COMPONENTS.map((component) => ({ provide: component }))
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,15 @@
|
|||||||
|
import {
|
||||||
|
SubmissionFormFooterComponent as BaseComponent
|
||||||
|
} from '../../../../../../app/submission/form/footer/submission-form-footer.component';
|
||||||
|
import { Component } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-submission-form-footer',
|
||||||
|
// styleUrls: ['./submission-form-footer.component.scss'],
|
||||||
|
styleUrls: ['../../../../../../app/submission/form/footer/submission-form-footer.component.scss'],
|
||||||
|
// templateUrl: './submission-form-footer.component.html'
|
||||||
|
templateUrl: '../../../../../../app/submission/form/footer/submission-form-footer.component.html'
|
||||||
|
})
|
||||||
|
export class SubmissionFormFooterComponent extends BaseComponent {
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,15 @@
|
|||||||
|
import {
|
||||||
|
SubmissionFormComponent as BaseComponent
|
||||||
|
} from '../../../../../app/submission/form/submission-form.component';
|
||||||
|
import { Component } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-submission-form',
|
||||||
|
// styleUrls: ['./submission-form.component.scss'],
|
||||||
|
styleUrls: ['../../../../../app/submission/form/submission-form.component.scss'],
|
||||||
|
// templateUrl: './submission-form.component.html'
|
||||||
|
templateUrl: '../../../../../app/submission/form/submission-form.component.html'
|
||||||
|
})
|
||||||
|
export class SubmissionFormComponent extends BaseComponent {
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,15 @@
|
|||||||
|
import {
|
||||||
|
SubmissionSectionContainerComponent as BaseComponent
|
||||||
|
} from '../../../../../../app/submission/sections/container/section-container.component';
|
||||||
|
import { Component } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'ds-submission-upload-section-file',
|
||||||
|
// styleUrls: ['./section-container.component.scss'],
|
||||||
|
styleUrls: ['../../../../../../app/submission/sections/container/section-container.component.scss'],
|
||||||
|
// templateUrl: './section-container.component.html'
|
||||||
|
templateUrl: '../../../../../../app/submission/sections/container/section-container.component.html'
|
||||||
|
})
|
||||||
|
export class SubmissionSectionContainerComponent extends BaseComponent {
|
||||||
|
|
||||||
|
}
|
@@ -108,7 +108,9 @@ import { ThumbnailComponent } from './app/thumbnail/thumbnail.component';
|
|||||||
import { WorkflowItemDeleteComponent } from './app/workflowitems-edit-page/workflow-item-delete/workflow-item-delete.component';
|
import { WorkflowItemDeleteComponent } from './app/workflowitems-edit-page/workflow-item-delete/workflow-item-delete.component';
|
||||||
import { WorkflowItemSendBackComponent } from './app/workflowitems-edit-page/workflow-item-send-back/workflow-item-send-back.component';
|
import { WorkflowItemSendBackComponent } from './app/workflowitems-edit-page/workflow-item-send-back/workflow-item-send-back.component';
|
||||||
import { WorkspaceItemsDeletePageComponent } from './app/workspaceitems-edit-page/workspaceitems-delete-page/workspaceitems-delete-page.component';
|
import { WorkspaceItemsDeletePageComponent } from './app/workspaceitems-edit-page/workspaceitems-delete-page/workspaceitems-delete-page.component';
|
||||||
|
import { SubmissionSectionContainerComponent } from './app/submission/sections/container/section-container.component';
|
||||||
|
import { SubmissionFormFooterComponent } from './app/submission/form/footer/submission-form-footer.component';
|
||||||
|
import { SubmissionFormComponent } from './app/submission/form/submission-form.component';
|
||||||
|
|
||||||
const DECLARATIONS = [
|
const DECLARATIONS = [
|
||||||
FileSectionComponent,
|
FileSectionComponent,
|
||||||
@@ -204,6 +206,9 @@ const DECLARATIONS = [
|
|||||||
AdminSearchPageComponent,
|
AdminSearchPageComponent,
|
||||||
AdminWorkflowPageComponent,
|
AdminWorkflowPageComponent,
|
||||||
SearchResultsSkeletonComponent,
|
SearchResultsSkeletonComponent,
|
||||||
|
SubmissionSectionContainerComponent,
|
||||||
|
SubmissionFormFooterComponent,
|
||||||
|
SubmissionFormComponent,
|
||||||
];
|
];
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
|
Reference in New Issue
Block a user