mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 00:02:35 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			153 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <app-page-header [title]="getTitle()">
 | |
| 
 | |
|   <div ngbDropdown class="d-inline-block mr-2">
 | |
|     <button class="btn btn-sm btn-outline-primary" id="dropdownBasic1" ngbDropdownToggle>
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#text-indent-left" />
 | |
|       </svg>
 | |
|       Bulk edit
 | |
|     </button>
 | |
|     <div ngbDropdownMenu aria-labelledby="dropdownBasic1" class="shadow">
 | |
|       <button ngbDropdownItem (click)="list.selectPage()">Select page</button>
 | |
|       <button ngbDropdownItem (click)="list.selectAll()">Select all</button>
 | |
|       <button ngbDropdownItem (click)="list.selectNone()">Select none</button>
 | |
|       <div class="dropdown-divider"></div>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkSetCorrespondent()">Set correspondent</button>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkRemoveCorrespondent()">Remove correspondent</button>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkSetDocumentType()">Set document type</button>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkRemoveDocumentType()">Remove document type</button>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkAddTag()">Add tag</button>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkRemoveTag()">Remove tag</button>
 | |
|       <div class="dropdown-divider"></div>
 | |
|       <button ngbDropdownItem [disabled]="list.selected.size == 0" (click)="bulkDelete()">Delete</button>
 | |
|     </div>
 | |
|   </div>
 | |
| 
 | |
|   <div class="btn-group btn-group-toggle" ngbRadioGroup [(ngModel)]="displayMode"
 | |
|     (ngModelChange)="saveDisplayMode()">
 | |
|     <label ngbButtonLabel class="btn-outline-primary btn-sm">
 | |
|       <input ngbButton type="radio" class="btn btn-sm" value="details">
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#list-ul" />
 | |
|       </svg>
 | |
|     </label>
 | |
|     <label ngbButtonLabel class="btn-outline-primary btn-sm">
 | |
|       <input ngbButton type="radio" class="btn btn-sm" value="smallCards">
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#grid" />
 | |
|       </svg>
 | |
|     </label>
 | |
|     <label ngbButtonLabel class="btn-outline-primary btn-sm">
 | |
|       <input ngbButton type="radio" class="btn btn-sm" value="largeCards">
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#hdd-stack" />
 | |
|       </svg>
 | |
|     </label>
 | |
|   </div>
 | |
| 
 | |
|   <div class="btn-group btn-group-toggle ml-2" ngbRadioGroup [(ngModel)]="list.sortReverse">
 | |
|     <div ngbDropdown class="btn-group">
 | |
|       <button class="btn btn-outline-primary btn-sm" id="dropdownBasic1" ngbDropdownToggle i18n>Sort by</button>
 | |
|       <div ngbDropdownMenu aria-labelledby="dropdownBasic1" class="shadow">
 | |
|         <button *ngFor="let f of getSortFields()" ngbDropdownItem (click)="list.sortField = f.field"
 | |
|           [class.active]="list.sortField == f.field">{{f.name}}</button>
 | |
|       </div>
 | |
|     </div>
 | |
|     <label ngbButtonLabel class="btn-outline-primary btn-sm">
 | |
|       <input ngbButton type="radio" class="btn btn-sm" [value]="false">
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#sort-alpha-down" />
 | |
|       </svg>
 | |
|     </label>
 | |
|     <label ngbButtonLabel class="btn-outline-primary btn-sm">
 | |
|       <input ngbButton type="radio" class="btn btn-sm" [value]="true">
 | |
|       <svg class="toolbaricon" fill="currentColor">
 | |
|         <use xlink:href="assets/bootstrap-icons.svg#sort-alpha-up-alt" />
 | |
|       </svg>
 | |
|     </label>
 | |
|   </div>
 | |
| 
 | |
|   <div class="btn-group ml-2">
 | |
| 
 | |
|     <div class="btn-group" ngbDropdown role="group">
 | |
|       <button class="btn btn-sm btn-outline-primary dropdown-toggle" ngbDropdownToggle i18n>Views</button>
 | |
|       <div class="dropdown-menu shadow" ngbDropdownMenu>
 | |
|         <ng-container *ngIf="!list.savedViewId">
 | |
|           <button ngbDropdownItem *ngFor="let view of savedViewService.allViews" (click)="loadViewConfig(view)">{{view.name}}</button>
 | |
|           <div class="dropdown-divider" *ngIf="savedViewService.allViews.length > 0"></div>
 | |
|         </ng-container>
 | |
| 
 | |
|         <button ngbDropdownItem (click)="saveViewConfig()" *ngIf="list.savedViewId" i18n>Save "{{list.savedViewTitle}}"</button>
 | |
|         <button ngbDropdownItem (click)="saveViewConfigAs()" i18n>Save as...</button>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|   </div>
 | |
| 
 | |
| </app-page-header>
 | |
| 
 | |
| <div class="w-100 mb-2 mb-sm-4">
 | |
|   <app-filter-editor [(filterRules)]="list.filterRules" #filterEditor></app-filter-editor>
 | |
| </div>
 | |
| 
 | |
| <div class="d-flex justify-content-between align-items-center">
 | |
|   <p><span *ngIf="list.selected.size > 0">Selected {{list.selected.size}} of </span>{{list.collectionSize || 0}} document(s) <span *ngIf="isFiltered">(filtered)</span></p>
 | |
|   <ngb-pagination [pageSize]="list.currentPageSize" [collectionSize]="list.collectionSize" [(page)]="list.currentPage" [maxSize]="5"
 | |
|   [rotate]="true" (pageChange)="list.reload()" aria-label="Default pagination"></ngb-pagination>
 | |
| </div>
 | |
| 
 | |
| <div *ngIf="displayMode == 'largeCards'">
 | |
|   <app-document-card-large [selected]="list.isSelected(d)" (selectedChange)="list.setSelected(d, $event)"   *ngFor="let d of list.documents; trackBy: trackByDocumentId" [document]="d" [details]="d.content" (clickTag)="clickTag($event)" (clickCorrespondent)="clickCorrespondent($event)">
 | |
|   </app-document-card-large>
 | |
| </div>
 | |
| 
 | |
| <table class="table table-sm border shadow-sm" *ngIf="displayMode == 'details'">
 | |
|   <thead>
 | |
|     <th></th>
 | |
|     <th class="d-none d-lg-table-cell" i18n>ASN</th>
 | |
|     <th class="d-none d-md-table-cell" i18n>Correspondent</th>
 | |
|     <th i18n>Title</th>
 | |
|     <th class="d-none d-xl-table-cell" i18n>Document type</th>
 | |
|     <th i18n>Created</th>
 | |
|     <th class="d-none d-xl-table-cell" i18n>Added</th>
 | |
|   </thead>
 | |
|   <tbody>
 | |
|     <tr *ngFor="let d of list.documents; trackBy: trackByDocumentId" [ngClass]="list.isSelected(d) ? 'table-row-selected' : ''">
 | |
|       <td>
 | |
|         <div class="custom-control custom-checkbox">
 | |
|           <input type="checkbox" class="custom-control-input" id="docCheck{{d.id}}" [checked]="list.isSelected(d)" (change)="list.setSelected(d, $event.target.checked)">
 | |
|           <label class="custom-control-label" for="docCheck{{d.id}}"></label>
 | |
|         </div>
 | |
|       </td>
 | |
|       <td class="d-none d-lg-table-cell">
 | |
|         {{d.archive_serial_number}}
 | |
|       </td>
 | |
|       <td class="d-none d-md-table-cell">
 | |
|         <ng-container *ngIf="d.correspondent">
 | |
|           <a [routerLink]="" (click)="clickCorrespondent(d.correspondent)" title="Filter by correspondent">{{(d.correspondent$ | async)?.name}}</a>
 | |
|         </ng-container>
 | |
|       </td>
 | |
|       <td>
 | |
|         <a routerLink="/documents/{{d.id}}" title="Edit document" style="overflow-wrap: anywhere;">{{d.title | documentTitle}}</a>
 | |
|         <app-tag [tag]="t" *ngFor="let t of d.tags$ | async" class="ml-1" clickable="true" linkTitle="Filter by tag" (click)="clickTag(t.id)"></app-tag>
 | |
|       </td>
 | |
|       <td class="d-none d-xl-table-cell">
 | |
|         <ng-container *ngIf="d.document_type">
 | |
|           <a [routerLink]="" (click)="clickDocumentType(d.document_type)" title="Filter by document type">{{(d.document_type$ | async)?.name}}</a>
 | |
|         </ng-container>
 | |
|       </td>
 | |
|       <td>
 | |
|         {{d.created | date}}
 | |
|       </td>
 | |
|       <td class="d-none d-xl-table-cell">
 | |
|         {{d.added | date}}
 | |
|       </td>
 | |
|     </tr>
 | |
|   </tbody>
 | |
| </table>
 | |
| 
 | |
| 
 | |
| <div class="m-n2 row row-cols-paperless-cards" *ngIf="displayMode == 'smallCards'">
 | |
|   <app-document-card-small [selected]="list.isSelected(d)" (selectedChange)="list.setSelected(d, $event)"  [document]="d" *ngFor="let d of list.documents; trackBy: trackByDocumentId" (clickTag)="clickTag($event)" (clickCorrespondent)="clickCorrespondent($event)"></app-document-card-small>
 | |
| </div>
 |