Admin template editor: reseachers multi auto-complete fix. Discard changes on dataset editor navigates back to dmp editor.

This commit is contained in:
Kristian Ntavidi 2021-04-07 12:58:45 +03:00
parent 959479757a
commit 037e246262
13 changed files with 192 additions and 29 deletions

View File

@ -74,7 +74,7 @@ export class FieldEditorModel extends BaseFormModel {
if (this.viewStyle.renderStyle === 'registries') { this.data = new RegistriesDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'registries') { this.data = new RegistriesDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'services') { this.data = new ServicesDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'services') { this.data = new ServicesDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'tags') { this.data = new TagsDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'tags') { this.data = new TagsDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'researchers') { this.data = new ResearchersDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'researchers') { this.data = new ResearchersAutoCompleteFieldDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'organizations') { this.data = new OrganizationsDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'organizations') { this.data = new OrganizationsDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'datasetIdentifier') { this.data = new DatasetIdentifierDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'datasetIdentifier') { this.data = new DatasetIdentifierDataEditorModel().fromModel(item.data); }
if (this.viewStyle.renderStyle === 'currency') { this.data = new CurrencyDataEditorModel().fromModel(item.data); } if (this.viewStyle.renderStyle === 'currency') { this.data = new CurrencyDataEditorModel().fromModel(item.data); }

View File

@ -735,15 +735,22 @@ export class DatasetProfileEditorCompositeFieldComponent implements OnInit, OnCh
// fieldForm.addControl('data', new ResearchersAutoCompleteFieldDataEditorModel().buildForm()); // fieldForm.addControl('data', new ResearchersAutoCompleteFieldDataEditorModel().buildForm());
// field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.Researchers; // field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.Researchers;
const data : ResearchersAutoCompleteFieldData = { const data : ResearchersAutoCompleteFieldData = {
label:'', label:'',
multiAutoComplete: false, multiAutoComplete: false,
type: DatasetProfileInternalDmpEntitiesType.Researchers type: DatasetProfileInternalDmpEntitiesType.Researchers
} }
field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.InternalDmpEntities; // field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.InternalDmpEntities;
// field.data = {label:''}
field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.Researchers;
field.data = data; field.data = data;
break; break;
} }
case this.viewTypeEnum.Organizations:{ case this.viewTypeEnum.Organizations:{

View File

@ -698,7 +698,7 @@ export class DatasetProfileEditorFieldComponent extends BaseComponent implements
} }
field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.InternalDmpEntities; field.viewStyle.renderStyle = DatasetProfileFieldViewStyle.Researchers;
field.data = data; field.data = data;

View File

@ -31,8 +31,8 @@ import { ValidationErrorModel } from '@common/forms/validation/error-model/valid
import { ConfirmationDialogComponent } from '@common/modules/confirmation-dialog/confirmation-dialog.component'; import { ConfirmationDialogComponent } from '@common/modules/confirmation-dialog/confirmation-dialog.component';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import * as FileSaver from 'file-saver'; import * as FileSaver from 'file-saver';
import { Observable, of as observableOf, interval } from 'rxjs'; import { Observable, of as observableOf, interval, Subscription } from 'rxjs';
import { catchError, map, takeUntil } from 'rxjs/operators'; import { catchError, debounceTime, map, takeUntil } from 'rxjs/operators';
import { LockService } from '@app/core/services/lock/lock.service'; import { LockService } from '@app/core/services/lock/lock.service';
import { Location } from '@angular/common'; import { Location } from '@angular/common';
import { LockModel } from '@app/core/model/lock/lock.model'; import { LockModel } from '@app/core/model/lock/lock.model';
@ -95,6 +95,7 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
showtocentriesErrors = false; showtocentriesErrors = false;
@ViewChild('table0fContents', {static: false}) table0fContents: TableOfContents; @ViewChild('table0fContents', {static: false}) table0fContents: TableOfContents;
hintErrors: boolean = false; hintErrors: boolean = false;
datasetIsOnceSaved = false;
fieldsetIdWithFocus:string; fieldsetIdWithFocus:string;
@ -393,12 +394,15 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
// }); // });
} }
// private _listenersSubscription:Subscription = new Subscription();
registerFormListeners() { registerFormListeners() {
// const dmpSubscription =
this.formGroup.get('dmp').valueChanges this.formGroup.get('dmp').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.dmpValueChanged(x); this.dmpValueChanged(x);
}); });
// const profileSubscription =
this.formGroup.get('profile').valueChanges this.formGroup.get('profile').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
@ -407,34 +411,51 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
this.formChanged(); this.formChanged();
} }
}); });
// const labelSubscription =
this.formGroup.get('label').valueChanges this.formGroup.get('label').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.formChanged(); this.formChanged();
}); });
// const descriptionSubscription =
this.formGroup.get('description').valueChanges this.formGroup.get('description').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.formChanged(); this.formChanged();
}); });
// const uriSubscription =
this.formGroup.get('uri').valueChanges this.formGroup.get('uri').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.formChanged(); this.formChanged();
}); });
// const tagsSubscription =
this.formGroup.get('tags').valueChanges this.formGroup.get('tags').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.formChanged(); this.formChanged();
}); });
if (this.formGroup.get('datasetProfileDefinition')) { if (this.formGroup.get('datasetProfileDefinition')) {
// const datasetProfileDefinitionSubscription =
this.formGroup.get('datasetProfileDefinition').valueChanges this.formGroup.get('datasetProfileDefinition').valueChanges
.pipe(takeUntil(this._destroyed)) .pipe(takeUntil(this._destroyed))
.subscribe(x => { .subscribe(x => {
this.formChanged(); this.formChanged();
}); });
// this._listenersSubscription.add(datasetProfileDefinitionSubscription);
} }
// this._listenersSubscription.add(dmpSubscription);
// this._listenersSubscription.add(profileSubscription);
// this._listenersSubscription.add(labelSubscription);
// this._listenersSubscription.add(descriptionSubscription);
// this._listenersSubscription.add(uriSubscription);
// this._listenersSubscription.add(tagsSubscription);
} }
// private _unregisterFormListeners(){
// this._listenersSubscription.unsubscribe();
// this._listenersSubscription = new Subscription();
// }
dmpValueChanged(dmp: DmpListingModel) { dmpValueChanged(dmp: DmpListingModel) {
if (dmp) { if (dmp) {
@ -519,6 +540,27 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
this.datasetWizardModel.datasetProfileDefinition = new DatasetDescriptionFormEditorModel().fromModel(item); this.datasetWizardModel.datasetProfileDefinition = new DatasetDescriptionFormEditorModel().fromModel(item);
this.datasetProfileDefinitionModel = this.datasetWizardModel.datasetProfileDefinition; this.datasetProfileDefinitionModel = this.datasetWizardModel.datasetProfileDefinition;
this.formGroup.addControl('datasetProfileDefinition', this.datasetProfileDefinitionModel.buildForm()); this.formGroup.addControl('datasetProfileDefinition', this.datasetProfileDefinitionModel.buildForm());
// const datasetProfileDefinitionForm = this.datasetProfileDefinitionModel.buildForm();
// let profId = null;
// try{
// profId = this.formGroup.get('profile').value.id;
// }catch{
// }
// if(this.formGroupRawValue && this.formGroupRawValue.datasetProfileDefinition && (this.formGroupRawValue.profile.id === profId)){
// // this.formGroup.get('datasetProfileDefinition').patchValue( this.formGroupRawValue.datasetProfileDefinition);
// datasetProfileDefinitionForm.patchValue(this.formGroupRawValue.datasetProfileDefinition);
// }
// this.formGroup.addControl('datasetProfileDefinition', datasetProfileDefinitionForm);
this.formGroup.get('datasetProfileDefinition').valueChanges
.pipe(debounceTime(600))
.pipe(takeUntil(this._destroyed))
.subscribe(x => {
this.formChanged();
});
}); });
} }
@ -569,6 +611,7 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
.subscribe( .subscribe(
data => { data => {
this.onCallbackSuccess(data, saveType); this.onCallbackSuccess(data, saveType);
this.datasetIsOnceSaved = true;
}, },
error => this.onCallbackError(error)); error => this.onCallbackError(error));
} }
@ -1039,24 +1082,74 @@ export class DatasetWizardComponent extends BaseComponent implements OnInit, IBr
} }
discardChanges() { discardChanges() {
this.isDiscarded = true; // this.isDiscarded = true;
this.hasChanges = false; // this.hasChanges = false;
this.hintErrors = false; // this.hintErrors = false;
if (this.isNew) { let messageText = "";
Object.keys(this.formGroup['controls']).forEach((key: string) => { let confirmButtonText ="";
if (key !== 'dmp' && (key!== 'profile')) { let cancelButtonText = "";
if(key === 'datasetProfileDefinition'){ let isDeleteConfirmation = false;
this.formGroup.get(key).patchValue(this.datasetProfileDefinitionModel.buildForm().getRawValue);
if (this.isNew && !this.datasetIsOnceSaved) {
messageText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-NEW-MESSAGE');
confirmButtonText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-NEW-CONFIRM');
cancelButtonText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-NEW-DENY');
isDeleteConfirmation = true;
// Object.keys(this.formGroup['controls']).forEach((key: string) => {
// if (key !== 'dmp' && (key!== 'profile')) {
// if(key === 'datasetProfileDefinition'){
// this.formGroup.get(key).patchValue(this.datasetProfileDefinitionModel.buildForm().getRawValue);
// }else{
// this.formGroup.get(key).reset();
// }
// }
// });
} else { } else {
this.formGroup.get(key).reset();
} messageText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-EDITED-MESSAGE');
confirmButtonText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-EDITED-CONFIRM');
cancelButtonText = this.language.instant('DATASET-EDITOR.ACTIONS.DISCARD.DISCARD-EDITED-DENY');
isDeleteConfirmation = false;
// this.isDiscarded = true;
// this.hasChanges = false;
// this.hintErrors = false;
// // this._unregisterFormListeners();
// this.formGroup.patchValue(JSON.parse(JSON.stringify(this.formGroupRawValue)));
// // this.registerFormListeners();
// this.isDiscarded = false;
} }
});
} else {
this.formGroup.patchValue(JSON.parse(JSON.stringify(this.formGroupRawValue)));
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
restoreFocus: false,
data: {
message: messageText,
confirmButton: confirmButtonText,
cancelButton: cancelButtonText,
isDeleteConfirmation: true
} }
this.isDiscarded = false; });
dialogRef.afterClosed().pipe(takeUntil(this._destroyed)).subscribe(result => {
if (result) {
this.backToDmp(this.formGroup.get('dmp').value.id)
}
});
// this.isDiscarded = false;
} }
addDataset(dmpId: string) { addDataset(dmpId: string) {

View File

@ -73,7 +73,6 @@ export class TableOfContents extends BaseComponent implements OnInit, OnChanges
ngOnInit(): void { ngOnInit(): void {
if(this.formGroup){ if(this.formGroup){
this.tocentries = this.getTocEntries(this.formGroup.get('datasetProfileDefinition')); this.tocentries = this.getTocEntries(this.formGroup.get('datasetProfileDefinition'));
const fg = this.formGroup.get('datasetProfileDefinition'); const fg = this.formGroup.get('datasetProfileDefinition');

View File

@ -1140,7 +1140,15 @@
"SAVE": "Speichern", "SAVE": "Speichern",
"CANCEL": "Abbrechen", "CANCEL": "Abbrechen",
"DELETE": "Löschen", "DELETE": "Löschen",
"UPDATE": "Update" "UPDATE": "Update",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Fill with description", "DESCRIPTION": "Fill with description",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Save", "SAVE": "Save",
"CANCEL": "Cancel", "CANCEL": "Cancel",
"DELETE": "Delete", "DELETE": "Delete",
"UPDATE": "Update" "UPDATE": "Update",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Fill with description", "DESCRIPTION": "Fill with description",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Grabar", "SAVE": "Grabar",
"CANCEL": "Cancelar", "CANCEL": "Cancelar",
"DELETE": "Borrar", "DELETE": "Borrar",
"UPDATE": "Actualizar" "UPDATE": "Actualizar",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Rellenar con la descripción", "DESCRIPTION": "Rellenar con la descripción",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Αποθήκευση", "SAVE": "Αποθήκευση",
"CANCEL": "Ακύρωση", "CANCEL": "Ακύρωση",
"DELETE": "Διαγραφή", "DELETE": "Διαγραφή",
"UPDATE": "Ενημέρωση" "UPDATE": "Ενημέρωση",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Συμπληρώστε με περιγραφή", "DESCRIPTION": "Συμπληρώστε με περιγραφή",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Guardar", "SAVE": "Guardar",
"CANCEL": "Cancelar", "CANCEL": "Cancelar",
"DELETE": "Eliminar", "DELETE": "Eliminar",
"UPDATE": "Atualizar" "UPDATE": "Atualizar",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Preencher com descrição", "DESCRIPTION": "Preencher com descrição",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Uložiť", "SAVE": "Uložiť",
"CANCEL": "Zrušiť", "CANCEL": "Zrušiť",
"DELETE": "Vymazať", "DELETE": "Vymazať",
"UPDATE": "Aktualizovať" "UPDATE": "Aktualizovať",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Doplniť opis", "DESCRIPTION": "Doplniť opis",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Sačuvajte", "SAVE": "Sačuvajte",
"CANCEL": "Otkažite", "CANCEL": "Otkažite",
"DELETE": "Obrišite", "DELETE": "Obrišite",
"UPDATE": "Ažurirajte" "UPDATE": "Ažurirajte",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Dopunite opisom", "DESCRIPTION": "Dopunite opisom",

View File

@ -1140,7 +1140,15 @@
"SAVE": "Kaydet", "SAVE": "Kaydet",
"CANCEL": "İptal", "CANCEL": "İptal",
"DELETE": "Sil", "DELETE": "Sil",
"UPDATE": "Güncelle" "UPDATE": "Güncelle",
"DISCARD":{
"DISCARD-NEW-MESSAGE":"All changes made will be discarded and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-NEW-CONFIRM":"Yes, discard and remove dataset.",
"DISCARD-NEW-DENY":"No.",
"DISCARD-EDITED-MESSAGE":"All unsaved changes will be reverted to their initial state and you will be redirected back to DMP Editor. Would you like to proceed?",
"DISCARD-EDITED-CONFIRM":"Yes, revert changes and go back.",
"DISCARD-EDITED-DENY":"No."
}
}, },
"PLACEHOLDER": { "PLACEHOLDER": {
"DESCRIPTION": "Açıklamayla Doldur", "DESCRIPTION": "Açıklamayla Doldur",