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; 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 => { // (this.dmp.errorModel)[item] = (errorModel)[item]; }); } }