mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Support keyboard esc and X button for filter editor text field
This commit is contained in:
parent
89e0f8e3ef
commit
a9abffaddc
@ -11,7 +11,12 @@
|
|||||||
<select *ngIf="textFilterTarget == 'asn'" class="form-select flex-grow-0 w-auto" [(ngModel)]="textFilterModifier" (change)="textFilterModifierChange()">
|
<select *ngIf="textFilterTarget == 'asn'" class="form-select flex-grow-0 w-auto" [(ngModel)]="textFilterModifier" (change)="textFilterModifierChange()">
|
||||||
<option *ngFor="let m of textFilterModifiers" ngbDropdownItem [value]="m.id">{{m.label}}</option>
|
<option *ngFor="let m of textFilterModifiers" ngbDropdownItem [value]="m.id">{{m.label}}</option>
|
||||||
</select>
|
</select>
|
||||||
<input #textFilterInput class="form-control form-control-sm" type="text" [disabled]="textFilterModifierIsNull" [(ngModel)]="textFilter" (keyup.enter)="textFilterEnter()" [readonly]="textFilterTarget == 'fulltext-morelike'">
|
<button *ngIf="_textFilter" class="btn btn-link btn-sm px-0 position-absolute top-0 end-0 z-10" (click)="resetTextField()">
|
||||||
|
<svg width="1em" height="1em" viewBox="0 0 16 16" class="bi bi-x me-1" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path fill-rule="evenodd" d="M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z"/>
|
||||||
|
</svg>
|
||||||
|
</button>
|
||||||
|
<input #textFilterInput class="form-control form-control-sm" type="text" [disabled]="textFilterModifierIsNull" [(ngModel)]="textFilter" (keyup)="textFilterKeyup($event)" [readonly]="textFilterTarget == 'fulltext-morelike'">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -21,3 +21,7 @@
|
|||||||
input[type="text"] {
|
input[type="text"] {
|
||||||
min-width: 120px;
|
min-width: 120px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.z-10 {
|
||||||
|
z-index: 10;
|
||||||
|
}
|
||||||
|
@ -709,15 +709,23 @@ export class FilterEditorComponent implements OnInit, OnDestroy {
|
|||||||
this.updateRules()
|
this.updateRules()
|
||||||
}
|
}
|
||||||
|
|
||||||
textFilterEnter() {
|
textFilterKeyup(event: KeyboardEvent) {
|
||||||
const filterString = (
|
if (event.key == 'Enter') {
|
||||||
this.textFilterInput.nativeElement as HTMLInputElement
|
const filterString = (
|
||||||
).value
|
this.textFilterInput.nativeElement as HTMLInputElement
|
||||||
if (filterString.length) {
|
).value
|
||||||
this.updateTextFilter(filterString)
|
if (filterString.length) {
|
||||||
|
this.updateTextFilter(filterString)
|
||||||
|
}
|
||||||
|
} else if (event.key == 'Escape') {
|
||||||
|
this.resetTextField()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resetTextField() {
|
||||||
|
this.updateTextFilter('')
|
||||||
|
}
|
||||||
|
|
||||||
changeTextFilterTarget(target) {
|
changeTextFilterTarget(target) {
|
||||||
if (
|
if (
|
||||||
this.textFilterTarget == TEXT_FILTER_TARGET_FULLTEXT_MORELIKE &&
|
this.textFilterTarget == TEXT_FILTER_TARGET_FULLTEXT_MORELIKE &&
|
||||||
|
Loading…
x
Reference in New Issue
Block a user