94 lines
3.0 KiB
TypeScript
94 lines
3.0 KiB
TypeScript
|
import { Component, OnInit } from '@angular/core';
|
||
|
import { FormGroup } from '@angular/forms';
|
||
|
import { MatSnackBar } from '@angular/material';
|
||
|
import { ActivatedRoute, Params, Router } from '@angular/router';
|
||
|
import { TranslateService } from '@ngx-translate/core';
|
||
|
import { Observable } from 'rxjs';
|
||
|
import { takeUntil } from 'rxjs/operators';
|
||
|
import { BaseComponent } from '../../../core/common/base/base.component';
|
||
|
import { DmpModel } from '../../../core/model/dmp/dmp';
|
||
|
import { DmpService } from '../../../core/services/dmp/dmp.service';
|
||
|
import { SnackBarNotificationComponent } from '../../../library/notification/snack-bar/snack-bar-notification.component';
|
||
|
import { BreadcrumbItem } from '../../misc/breadcrumb/definition/breadcrumb-item';
|
||
|
import { IBreadCrumbComponent } from '../../misc/breadcrumb/definition/IBreadCrumbComponent';
|
||
|
import { DmpWizardEditorModel } from './dmp-wizard-editor.model';
|
||
|
|
||
|
@Component({
|
||
|
selector: 'app-dmp-wizard-component',
|
||
|
templateUrl: 'dmp-wizard.component.html',
|
||
|
styleUrls: ['./dmp-wizard.component.scss'],
|
||
|
})
|
||
|
export class DmpWizardComponent extends BaseComponent implements OnInit, IBreadCrumbComponent {
|
||
|
|
||
|
breadCrumbs: Observable<BreadcrumbItem[]>;
|
||
|
itemId: string;
|
||
|
dmp: DmpWizardEditorModel;
|
||
|
formGroup: FormGroup;
|
||
|
isClone: boolean;
|
||
|
|
||
|
constructor(
|
||
|
private dmpService: DmpService,
|
||
|
private language: TranslateService,
|
||
|
private snackBar: MatSnackBar,
|
||
|
private route: ActivatedRoute,
|
||
|
private router: Router
|
||
|
) { super(); }
|
||
|
|
||
|
ngOnInit(): void {
|
||
|
|
||
|
this.route.params
|
||
|
.pipe(takeUntil(this._destroyed))
|
||
|
.subscribe((params: Params) => {
|
||
|
this.itemId = params['id'];
|
||
|
this.dmpService.getSingle(this.itemId).map(data => data as DmpModel)
|
||
|
.pipe(takeUntil(this._destroyed))
|
||
|
.subscribe(data => {
|
||
|
this.dmp = new DmpWizardEditorModel().fromModel(data);
|
||
|
this.isClone = this.route.snapshot.data.clone;
|
||
|
if (this.isClone === false) { this.dmp.version = this.dmp.version + 1; }
|
||
|
this.formGroup = this.dmp.buildForm();
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
|
||
|
|
||
|
submit() {
|
||
|
if (this.isClone) {
|
||
|
this.dmpService.clone(this.formGroup.getRawValue(), this.itemId)
|
||
|
.pipe(takeUntil(this._destroyed))
|
||
|
.subscribe(
|
||
|
complete => this.onCallbackSuccess(),
|
||
|
error => this.onCallbackError(error)
|
||
|
);
|
||
|
} else {
|
||
|
this.dmpService.newVersion(this.formGroup.getRawValue(), this.itemId)
|
||
|
.pipe(takeUntil(this._destroyed))
|
||
|
.subscribe(
|
||
|
complete => this.onCallbackSuccess(),
|
||
|
error => this.onCallbackError(error)
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
onCallbackSuccess(): void {
|
||
|
this.snackBar.openFromComponent(SnackBarNotificationComponent, {
|
||
|
data: { message: 'GENERAL.SNACK-BAR.SUCCESSFUL-UPDATE', language: this.language },
|
||
|
duration: 3000,
|
||
|
});
|
||
|
this.router.navigate(['/plans']);
|
||
|
}
|
||
|
|
||
|
onCallbackError(error: any) {
|
||
|
this.setErrorModel(error.error);
|
||
|
//this.validateAllFormFields(this.formGroup);
|
||
|
}
|
||
|
|
||
|
public setErrorModel(errorModel: any) {
|
||
|
Object.keys(errorModel).forEach(item => {
|
||
|
// (<any>this.dmp.errorModel)[item] = (<any>errorModel)[item];
|
||
|
});
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|