Prevent close button 'stealing' focus from modal input fields

This commit is contained in:
Michael Shamoon 2021-01-16 14:09:23 -08:00
parent 961354aa8a
commit 98f3e99e2e
6 changed files with 18 additions and 6 deletions

View File

@ -27,6 +27,8 @@ export abstract class EditDialogComponent<T extends ObjectWithId> implements OnI
networkActive = false networkActive = false
closeEnabled = false
error = null error = null
abstract getForm(): FormGroup abstract getForm(): FormGroup
@ -37,6 +39,11 @@ export abstract class EditDialogComponent<T extends ObjectWithId> implements OnI
if (this.object != null) { if (this.object != null) {
this.objectForm.patchValue(this.object) this.objectForm.patchValue(this.object)
} }
// we wait to enable the close button so it doesnt pull browser focus since its the first clickable element in the DOM
setTimeout(() => {
this.closeEnabled = true
});
} }
getCreateTitle() { getCreateTitle() {

View File

@ -1,7 +1,7 @@
<form [formGroup]="saveViewConfigForm" (ngSubmit)="save()"> <form [formGroup]="saveViewConfigForm" (ngSubmit)="save()">
<div class="modal-header"> <div class="modal-header">
<h4 class="modal-title" id="modal-basic-title" i18n>Save current view</h4> <h4 class="modal-title" id="modal-basic-title" i18n>Save current view</h4>
<button type="button" class="close" aria-label="Close" (click)="cancel()"> <button type="button" [disabled]="!closeEnabled" class="close" aria-label="Close" (click)="cancel()">
<span aria-hidden="true">&times;</span> <span aria-hidden="true">&times;</span>
</button> </button>
</div> </div>

View File

@ -20,6 +20,8 @@ export class SaveViewConfigDialogComponent implements OnInit {
@Input() @Input()
buttonsEnabled = true buttonsEnabled = true
closeEnabled = false
_defaultName = "" _defaultName = ""
get defaultName() { get defaultName() {
@ -31,7 +33,7 @@ export class SaveViewConfigDialogComponent implements OnInit {
this._defaultName = value this._defaultName = value
this.saveViewConfigForm.patchValue({name: value}) this.saveViewConfigForm.patchValue({name: value})
} }
saveViewConfigForm = new FormGroup({ saveViewConfigForm = new FormGroup({
name: new FormControl(''), name: new FormControl(''),
showInSideBar: new FormControl(false), showInSideBar: new FormControl(false),
@ -39,6 +41,10 @@ export class SaveViewConfigDialogComponent implements OnInit {
}) })
ngOnInit(): void { ngOnInit(): void {
// wait to enable close button so it doesnt steal focus form input
setTimeout(() => {
this.closeEnabled = true
});
} }
save() { save() {

View File

@ -1,12 +1,11 @@
<form [formGroup]="objectForm" (ngSubmit)="save()"> <form [formGroup]="objectForm" (ngSubmit)="save()">
<div class="modal-header"> <div class="modal-header">
<h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4> <h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4>
<button type="button" class="close" aria-label="Close" (click)="cancel()"> <button type="button" [disabled]="!closeEnabled" class="close" aria-label="Close" (click)="cancel()">
<span aria-hidden="true">&times;</span> <span aria-hidden="true">&times;</span>
</button> </button>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<app-input-text i18n-title title="Name" formControlName="name" [error]="error?.name"></app-input-text> <app-input-text i18n-title title="Name" formControlName="name" [error]="error?.name"></app-input-text>
<app-input-select i18n-title title="Matching algorithm" [items]="getMatchingAlgorithms()" formControlName="matching_algorithm"></app-input-select> <app-input-select i18n-title title="Matching algorithm" [items]="getMatchingAlgorithms()" formControlName="matching_algorithm"></app-input-select>
<app-input-text *ngIf="patternRequired" i18n-title title="Matching pattern" formControlName="match"></app-input-text> <app-input-text *ngIf="patternRequired" i18n-title title="Matching pattern" formControlName="match"></app-input-text>

View File

@ -1,7 +1,7 @@
<form [formGroup]="objectForm" (ngSubmit)="save()"> <form [formGroup]="objectForm" (ngSubmit)="save()">
<div class="modal-header"> <div class="modal-header">
<h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4> <h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4>
<button type="button" class="close" aria-label="Close" (click)="cancel()"> <button type="button" [disabled]="!closeEnabled" class="close" aria-label="Close" (click)="cancel()">
<span aria-hidden="true">&times;</span> <span aria-hidden="true">&times;</span>
</button> </button>
</div> </div>

View File

@ -1,7 +1,7 @@
<form [formGroup]="objectForm" (ngSubmit)="save()"> <form [formGroup]="objectForm" (ngSubmit)="save()">
<div class="modal-header"> <div class="modal-header">
<h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4> <h4 class="modal-title" id="modal-basic-title">{{getTitle()}}</h4>
<button type="button" class="close" aria-label="Close" (click)="cancel()"> <button type="button" [disabled]="!closeEnabled" class="close" aria-label="Close" (click)="cancel()">
<span aria-hidden="true">&times;</span> <span aria-hidden="true">&times;</span>
</button> </button>
</div> </div>