mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-10-23 23:09:08 -04:00
Use ng-select for document detail screen tags
This commit is contained in:
parent
9b244d0265
commit
e10a2391c4
@ -1,29 +1,33 @@
|
|||||||
<div class="form-group">
|
<div class="form-group paperless-input-select paperless-input-tags">
|
||||||
<label for="exampleFormControlTextarea1">Tags</label>
|
<label for="tags">Tags</label>
|
||||||
|
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<div class="form-control tags-form-control" id="tags">
|
<ng-select name="tags" [items]="tags" bindLabel="name" bindValue="id" [(ngModel)]="displayValue"
|
||||||
<app-tag class="mr-2" *ngFor="let id of displayValue" [tag]="getTag(id)" (click)="removeTag(id)"></app-tag>
|
[multiple]="true"
|
||||||
</div>
|
[closeOnSelect]="false"
|
||||||
|
[disabled]="disabled"
|
||||||
|
(change)="ngSelectChange()">
|
||||||
|
|
||||||
<div class="input-group-append" ngbDropdown placement="top-right">
|
<ng-template ng-label-tmp let-item="item">
|
||||||
<button class="btn btn-outline-secondary" type="button" ngbDropdownToggle></button>
|
<app-tag style="background-color: none;" [tag]="getTag(item.id)" (click)="removeTag(item.id)"></app-tag>
|
||||||
<div ngbDropdownMenu class="scrollable-menu shadow">
|
</ng-template>
|
||||||
<button type="button" *ngFor="let tag of tags" ngbDropdownItem (click)="addTag(tag.id)">
|
<ng-template ng-option-tmp let-item="item" let-index="index" let-search="searchTerm">
|
||||||
<app-tag [tag]="tag"></app-tag>
|
<div class="selected-icon d-inline-block mr-1">
|
||||||
</button>
|
<svg *ngIf="displayValue.includes(item.id)" width="1em" height="1em" viewBox="0 0 16 16" class="bi bi-check" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
|
||||||
</div>
|
<path fill-rule="evenodd" d="M10.97 4.97a.75.75 0 0 1 1.071 1.05l-3.992 4.99a.75.75 0 0 1-1.08.02L4.324 8.384a.75.75 0 1 1 1.06-1.06l2.094 2.093 3.473-4.425a.236.236 0 0 1 .02-.022z"/>
|
||||||
|
</svg>
|
||||||
</div>
|
</div>
|
||||||
|
<app-tag class="mr-2" [tag]="getTag(item.id)"></app-tag>
|
||||||
|
</ng-template>
|
||||||
|
</ng-select>
|
||||||
|
|
||||||
<div class="input-group-append">
|
<div class="input-group-append">
|
||||||
|
|
||||||
<button class="btn btn-outline-secondary" type="button" (click)="createTag()">
|
<button class="btn btn-outline-secondary" type="button" (click)="createTag()">
|
||||||
<svg class="buttonicon" fill="currentColor">
|
<svg class="buttonicon" fill="currentColor">
|
||||||
<use xlink:href="assets/bootstrap-icons.svg#plus" />
|
<use xlink:href="assets/bootstrap-icons.svg#plus" />
|
||||||
</svg>
|
</svg>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<small class="form-text text-muted" *ngIf="hint">{{hint}}</small>
|
<small class="form-text text-muted" *ngIf="hint">{{hint}}</small>
|
||||||
|
|
||||||
|
@ -1,10 +1,4 @@
|
|||||||
.tags-form-control {
|
.selected-icon {
|
||||||
height: auto;
|
min-width: 1em;
|
||||||
}
|
min-height: 1em;
|
||||||
|
|
||||||
|
|
||||||
.scrollable-menu {
|
|
||||||
height: auto;
|
|
||||||
max-height: 300px;
|
|
||||||
overflow-x: hidden;
|
|
||||||
}
|
}
|
@ -66,29 +66,28 @@ export class TagsComponent implements OnInit, ControlValueAccessor {
|
|||||||
removeTag(id) {
|
removeTag(id) {
|
||||||
let index = this.displayValue.indexOf(id)
|
let index = this.displayValue.indexOf(id)
|
||||||
if (index > -1) {
|
if (index > -1) {
|
||||||
this.displayValue.splice(index, 1)
|
let oldValue = this.displayValue
|
||||||
|
oldValue.splice(index, 1)
|
||||||
|
this.displayValue = [...oldValue]
|
||||||
this.onChange(this.displayValue)
|
this.onChange(this.displayValue)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
addTag(id) {
|
|
||||||
let index = this.displayValue.indexOf(id)
|
|
||||||
if (index == -1) {
|
|
||||||
this.displayValue.push(id)
|
|
||||||
this.onChange(this.displayValue)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
createTag() {
|
createTag() {
|
||||||
var modal = this.modalService.open(TagEditDialogComponent, {backdrop: 'static'})
|
var modal = this.modalService.open(TagEditDialogComponent, {backdrop: 'static'})
|
||||||
modal.componentInstance.dialogMode = 'create'
|
modal.componentInstance.dialogMode = 'create'
|
||||||
modal.componentInstance.success.subscribe(newTag => {
|
modal.componentInstance.success.subscribe(newTag => {
|
||||||
this.tagService.listAll().subscribe(tags => {
|
this.tagService.listAll().subscribe(tags => {
|
||||||
this.tags = tags.results
|
this.tags = tags.results
|
||||||
this.addTag(newTag.id)
|
this.displayValue = [...this.displayValue, newTag.id]
|
||||||
|
this.onChange(this.displayValue)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ngSelectChange() {
|
||||||
|
this.value = this.displayValue
|
||||||
|
this.onChange(this.displayValue)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -52,9 +52,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<app-input-date-time titleDate="Date created" formControlName="created"></app-input-date-time>
|
<app-input-date-time titleDate="Date created" formControlName="created"></app-input-date-time>
|
||||||
<app-input-select [items]="correspondents" title="Correspondent" formControlName="correspondent"
|
<app-input-select [items]="correspondents" title="Correspondent" formControlName="correspondent"
|
||||||
allowNull="true" (createNew)="createCorrespondent()"></app-input-select>
|
(createNew)="createCorrespondent()"></app-input-select>
|
||||||
<app-input-select [items]="documentTypes" title="Document type" formControlName="document_type"
|
<app-input-select [items]="documentTypes" title="Document type" formControlName="document_type"
|
||||||
allowNull="true" (createNew)="createDocumentType()"></app-input-select>
|
(createNew)="createDocumentType()"></app-input-select>
|
||||||
<app-input-tags formControlName="tags" title="Tags"></app-input-tags>
|
<app-input-tags formControlName="tags" title="Tags"></app-input-tags>
|
||||||
|
|
||||||
</ng-template>
|
</ng-template>
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
@import "theme";
|
@import "theme";
|
||||||
|
|
||||||
@import "node_modules/bootstrap/scss/bootstrap";
|
@import "node_modules/bootstrap/scss/bootstrap";
|
||||||
|
|
||||||
@import "~@ng-select/ng-select/themes/default.theme.css";
|
@import "~@ng-select/ng-select/themes/default.theme.css";
|
||||||
|
|
||||||
.toolbaricon {
|
.toolbaricon {
|
||||||
@ -21,7 +19,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
font-size: .875rem;
|
font-size: 0.875rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.form-control-dark {
|
.form-control-dark {
|
||||||
@ -85,5 +83,16 @@ body {
|
|||||||
top: 8px;
|
top: 8px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
|
||||||
|
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked {
|
||||||
|
background: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.paperless-input-tags {
|
||||||
|
.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value {
|
||||||
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user