mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 08:12:34 -04:00 
			
		
		
		
	Tweakhancement: reorganize some list & bulk editing buttons (#10944)
This commit is contained in:
		
							parent
							
								
									af544177d4
								
							
						
					
					
						commit
						1717517e70
					
				| @ -174,7 +174,7 @@ test('bulk edit', async ({ page }) => { | |||||||
|   await expect(page.locator('pngx-document-list')).toHaveText( |   await expect(page.locator('pngx-document-list')).toHaveText( | ||||||
|     /Selected 61 of 61 documents/i |     /Selected 61 of 61 documents/i | ||||||
|   ) |   ) | ||||||
|   await page.getByRole('button', { name: 'Cancel' }).click() |   await page.getByRole('button', { name: 'None' }).click() | ||||||
| 
 | 
 | ||||||
|   await page.locator('pngx-document-card-small').nth(1).click() |   await page.locator('pngx-document-card-small').nth(1).click() | ||||||
|   await page.locator('pngx-document-card-small').nth(2).click() |   await page.locator('pngx-document-card-small').nth(2).click() | ||||||
|  | |||||||
| @ -1,161 +1,144 @@ | |||||||
| <div class="d-flex flex-wrap gap-4"> | <div class="d-flex flex-wrap gap-4"> | ||||||
|   <div class="d-flex align-items-center" role="group" aria-label="Select"> |   <div class="d-flex flex-wrap align-items-center gap-2" *pngxIfPermissions="{ action: PermissionAction.Change, type: PermissionType.Document }"> | ||||||
|     <button class="btn btn-sm btn-outline-secondary" (click)="list.selectNone()"> |     <label class="me-2" i18n>Edit:</label> | ||||||
|       <i-bs name="slash-circle"></i-bs> <ng-container i18n>Cancel</ng-container> |     @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Tag)) { | ||||||
|  |       <pngx-filterable-dropdown title="Tags" icon="tag-fill" i18n-title | ||||||
|  |         filterPlaceholder="Filter tags" i18n-filterPlaceholder | ||||||
|  |         [disabled]="!userCanEditAll || disabled" | ||||||
|  |         [editing]="true" | ||||||
|  |         [applyOnClose]="applyOnClose" | ||||||
|  |         [createRef]="createTag.bind(this)" | ||||||
|  |         (opened)="openTagsDropdown()" | ||||||
|  |         [(selectionModel)]="tagSelectionModel" | ||||||
|  |         [documentCounts]="tagDocumentCounts" | ||||||
|  |         (apply)="setTags($event)" | ||||||
|  |         shortcutKey="t"> | ||||||
|  |       </pngx-filterable-dropdown> | ||||||
|  |     } | ||||||
|  |     @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Correspondent)) { | ||||||
|  |       <pngx-filterable-dropdown title="Correspondent" icon="person-fill" i18n-title | ||||||
|  |         filterPlaceholder="Filter correspondents" i18n-filterPlaceholder | ||||||
|  |         [disabled]="!userCanEditAll || disabled" | ||||||
|  |         [editing]="true" | ||||||
|  |         [applyOnClose]="applyOnClose" | ||||||
|  |         [createRef]="createCorrespondent.bind(this)" | ||||||
|  |         (opened)="openCorrespondentDropdown()" | ||||||
|  |         [(selectionModel)]="correspondentSelectionModel" | ||||||
|  |         [documentCounts]="correspondentDocumentCounts" | ||||||
|  |         (apply)="setCorrespondents($event)" | ||||||
|  |         shortcutKey="y"> | ||||||
|  |       </pngx-filterable-dropdown> | ||||||
|  |     } | ||||||
|  |     @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.DocumentType)) { | ||||||
|  |       <pngx-filterable-dropdown title="Document type" icon="file-earmark-fill" i18n-title | ||||||
|  |         filterPlaceholder="Filter document types" i18n-filterPlaceholder | ||||||
|  |         [disabled]="!userCanEditAll || disabled" | ||||||
|  |         [editing]="true" | ||||||
|  |         [applyOnClose]="applyOnClose" | ||||||
|  |         [createRef]="createDocumentType.bind(this)" | ||||||
|  |         (opened)="openDocumentTypeDropdown()" | ||||||
|  |         [(selectionModel)]="documentTypeSelectionModel" | ||||||
|  |         [documentCounts]="documentTypeDocumentCounts" | ||||||
|  |         (apply)="setDocumentTypes($event)" | ||||||
|  |         shortcutKey="u"> | ||||||
|  |       </pngx-filterable-dropdown> | ||||||
|  |     } | ||||||
|  |     @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.StoragePath)) { | ||||||
|  |       <pngx-filterable-dropdown title="Storage path" icon="folder-fill" i18n-title | ||||||
|  |         filterPlaceholder="Filter storage paths" i18n-filterPlaceholder | ||||||
|  |         [disabled]="!userCanEditAll || disabled" | ||||||
|  |         [editing]="true" | ||||||
|  |         [applyOnClose]="applyOnClose" | ||||||
|  |         [createRef]="createStoragePath.bind(this)" | ||||||
|  |         (opened)="openStoragePathDropdown()" | ||||||
|  |         [(selectionModel)]="storagePathsSelectionModel" | ||||||
|  |         [documentCounts]="storagePathDocumentCounts" | ||||||
|  |         (apply)="setStoragePaths($event)" | ||||||
|  |         shortcutKey="i"> | ||||||
|  |       </pngx-filterable-dropdown> | ||||||
|  |     } | ||||||
|  |     @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.CustomField)) { | ||||||
|  |       <pngx-filterable-dropdown title="Custom fields" icon="ui-radios" i18n-title | ||||||
|  |         filterPlaceholder="Filter custom fields" i18n-filterPlaceholder | ||||||
|  |         [disabled]="!userCanEditAll" | ||||||
|  |         [editing]="true" | ||||||
|  |         [applyOnClose]="applyOnClose" | ||||||
|  |         [createRef]="createCustomField.bind(this)" | ||||||
|  |         (opened)="openCustomFieldsDropdown()" | ||||||
|  |         [(selectionModel)]="customFieldsSelectionModel" | ||||||
|  |         [documentCounts]="customFieldDocumentCounts" | ||||||
|  |         extraButtonTitle="Set values" | ||||||
|  |         i18n-extraButtonTitle | ||||||
|  |         (extraButton)="setCustomFieldValues($event)" | ||||||
|  |         (apply)="setCustomFields($event)"> | ||||||
|  |       </pngx-filterable-dropdown> | ||||||
|  |     } | ||||||
|  |     <div class="btn-group"> | ||||||
|  |       <button type="button" class="btn btn-sm btn-outline-primary me-2" (click)="setPermissions()" [disabled]="!userOwnsAll || !userCanEditAll"> | ||||||
|  |         <i-bs name="person-fill-lock"></i-bs><div class="d-none d-sm-inline"> <ng-container i18n>Permissions</ng-container></div> | ||||||
|       </button> |       </button> | ||||||
|     </div> |     </div> | ||||||
|     <div class="d-flex align-items-center gap-2" role="group" aria-label="Select"> |   </div> | ||||||
|       <label class="me-2" i18n>Select:</label> |   <div class="d-flex align-items-center gap-2 ms-auto"> | ||||||
|       <div class="btn-group"> |     <div class="btn-toolbar"> | ||||||
|         <button class="btn btn-sm btn-outline-primary" (click)="list.selectPage()"> |       <div ngbDropdown> | ||||||
|           <i-bs name="file-earmark-check"></i-bs> <ng-container i18n>Page</ng-container> |         <button class="btn btn-sm btn-outline-primary" id="dropdownSelect" [disabled]="!userCanEdit && !userCanAdd" ngbDropdownToggle> | ||||||
|  |           <i-bs name="three-dots"></i-bs> | ||||||
|  |           <div class="d-none d-sm-inline"> <ng-container i18n>Actions</ng-container></div> | ||||||
|  |         </button> | ||||||
|  |         <div ngbDropdownMenu aria-labelledby="dropdownSelect" class="shadow"> | ||||||
|  |           <button ngbDropdownItem (click)="reprocessSelected()" [disabled]="!userCanEditAll && !userCanEditAll"> | ||||||
|  |             <i-bs name="body-text"></i-bs> <ng-container i18n>Reprocess</ng-container> | ||||||
|  |           </button> | ||||||
|  |           <button ngbDropdownItem (click)="rotateSelected()" [disabled]="!userOwnsAll && !userCanEditAll"> | ||||||
|  |             <i-bs name="arrow-clockwise"></i-bs> <ng-container i18n>Rotate</ng-container> | ||||||
|  |           </button> | ||||||
|  |           <button ngbDropdownItem (click)="mergeSelected()" [disabled]="!userCanAdd || list.selected.size < 2"> | ||||||
|  |             <i-bs name="journals"></i-bs> <ng-container i18n>Merge</ng-container> | ||||||
|           </button> |           </button> | ||||||
|           <button class="btn btn-sm btn-outline-primary" (click)="list.selectAll()"> |  | ||||||
|             <i-bs name="check-all"></i-bs> <ng-container i18n>All</ng-container> |  | ||||||
|             </button> |  | ||||||
|           </div> |  | ||||||
|         </div> |         </div> | ||||||
|         <div class="d-flex align-items-center gap-2" *pngxIfPermissions="{ action: PermissionAction.Change, type: PermissionType.Document }"> |       </div> | ||||||
|           <label class="me-2" i18n>Edit:</label> |     </div> | ||||||
|           @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Tag)) { |     <div class="btn-group btn-group-sm"> | ||||||
|             <pngx-filterable-dropdown title="Tags" icon="tag-fill" i18n-title |       <button class="btn btn-sm btn-outline-primary" [disabled]="awaitingDownload" (click)="downloadSelected()"> | ||||||
|               filterPlaceholder="Filter tags" i18n-filterPlaceholder |         @if (!awaitingDownload) { | ||||||
|               [disabled]="!userCanEditAll || disabled" |           <i-bs name="arrow-down"></i-bs> | ||||||
|               [editing]="true" |         } | ||||||
|               [applyOnClose]="applyOnClose" |         @if (awaitingDownload) { | ||||||
|               [createRef]="createTag.bind(this)" |           <div class="spinner-border spinner-border-sm" role="status"> | ||||||
|               (opened)="openTagsDropdown()" |             <span class="visually-hidden">Preparing download...</span> | ||||||
|               [(selectionModel)]="tagSelectionModel" |           </div> | ||||||
|               [documentCounts]="tagDocumentCounts" |         } | ||||||
|               (apply)="setTags($event)" |         <div class="d-none d-sm-inline"> <ng-container i18n>Download</ng-container></div> | ||||||
|               shortcutKey="t"> |       </button> | ||||||
|             </pngx-filterable-dropdown> |       <div ngbDropdown class="me-2 d-flex btn-group" role="group"> | ||||||
|           } |         <button type="button" class="btn btn-sm btn-outline-primary dropdown-toggle-split rounded-end" ngbDropdownToggle></button> | ||||||
|           @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.Correspondent)) { |         <div ngbDropdownMenu aria-labelledby="dropdownSelect" class="shadow"> | ||||||
|             <pngx-filterable-dropdown title="Correspondent" icon="person-fill" i18n-title |           <form [formGroup]="downloadForm" class="px-3 py-1"> | ||||||
|               filterPlaceholder="Filter correspondents" i18n-filterPlaceholder |             <p class="mb-1" i18n>Include:</p> | ||||||
|               [disabled]="!userCanEditAll || disabled" |             <div class="form-group ps-3 mb-2"> | ||||||
|               [editing]="true" |               <div class="form-check"> | ||||||
|               [applyOnClose]="applyOnClose" |                 <input type="checkbox" class="form-check-input" id="downloadFileType_archive" formControlName="downloadFileTypeArchive" /> | ||||||
|               [createRef]="createCorrespondent.bind(this)" |                 <label class="form-check-label" for="downloadFileType_archive" i18n>Archived files</label> | ||||||
|               (opened)="openCorrespondentDropdown()" |               </div> | ||||||
|               [(selectionModel)]="correspondentSelectionModel" |               <div class="form-check"> | ||||||
|               [documentCounts]="correspondentDocumentCounts" |                 <input type="checkbox" class="form-check-input" id="downloadFileType_originals" formControlName="downloadFileTypeOriginals" /> | ||||||
|               (apply)="setCorrespondents($event)" |                 <label class="form-check-label" for="downloadFileType_originals" i18n>Original files</label> | ||||||
|               shortcutKey="y"> |               </div> | ||||||
|             </pngx-filterable-dropdown> |             </div> | ||||||
|           } |             <div class="form-check"> | ||||||
|           @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.DocumentType)) { |               <input type="checkbox" class="form-check-input" id="downloadUseFormatting" formControlName="downloadUseFormatting" /> | ||||||
|             <pngx-filterable-dropdown title="Document type" icon="file-earmark-fill" i18n-title |               <label class="form-check-label" for="downloadUseFormatting" i18n>Use formatted filename</label> | ||||||
|               filterPlaceholder="Filter document types" i18n-filterPlaceholder |             </div> | ||||||
|               [disabled]="!userCanEditAll || disabled" |           </form> | ||||||
|               [editing]="true" |  | ||||||
|               [applyOnClose]="applyOnClose" |  | ||||||
|               [createRef]="createDocumentType.bind(this)" |  | ||||||
|               (opened)="openDocumentTypeDropdown()" |  | ||||||
|               [(selectionModel)]="documentTypeSelectionModel" |  | ||||||
|               [documentCounts]="documentTypeDocumentCounts" |  | ||||||
|               (apply)="setDocumentTypes($event)" |  | ||||||
|               shortcutKey="u"> |  | ||||||
|             </pngx-filterable-dropdown> |  | ||||||
|           } |  | ||||||
|           @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.StoragePath)) { |  | ||||||
|             <pngx-filterable-dropdown title="Storage path" icon="folder-fill" i18n-title |  | ||||||
|               filterPlaceholder="Filter storage paths" i18n-filterPlaceholder |  | ||||||
|               [disabled]="!userCanEditAll || disabled" |  | ||||||
|               [editing]="true" |  | ||||||
|               [applyOnClose]="applyOnClose" |  | ||||||
|               [createRef]="createStoragePath.bind(this)" |  | ||||||
|               (opened)="openStoragePathDropdown()" |  | ||||||
|               [(selectionModel)]="storagePathsSelectionModel" |  | ||||||
|               [documentCounts]="storagePathDocumentCounts" |  | ||||||
|               (apply)="setStoragePaths($event)" |  | ||||||
|               shortcutKey="i"> |  | ||||||
|             </pngx-filterable-dropdown> |  | ||||||
|           } |  | ||||||
|           @if (permissionService.currentUserCan(PermissionAction.View, PermissionType.CustomField)) { |  | ||||||
|             <pngx-filterable-dropdown title="Custom fields" icon="ui-radios" i18n-title |  | ||||||
|               filterPlaceholder="Filter custom fields" i18n-filterPlaceholder |  | ||||||
|               [disabled]="!userCanEditAll" |  | ||||||
|               [editing]="true" |  | ||||||
|               [applyOnClose]="applyOnClose" |  | ||||||
|               [createRef]="createCustomField.bind(this)" |  | ||||||
|               (opened)="openCustomFieldsDropdown()" |  | ||||||
|               [(selectionModel)]="customFieldsSelectionModel" |  | ||||||
|               [documentCounts]="customFieldDocumentCounts" |  | ||||||
|               extraButtonTitle="Set values" |  | ||||||
|               i18n-extraButtonTitle |  | ||||||
|               (extraButton)="setCustomFieldValues($event)" |  | ||||||
|               (apply)="setCustomFields($event)"> |  | ||||||
|             </pngx-filterable-dropdown> |  | ||||||
|           } |  | ||||||
|         </div> |         </div> | ||||||
|         <div class="d-flex align-items-center gap-2 ms-auto"> |       </div> | ||||||
|           <div class="btn-toolbar"> |     </div> | ||||||
| 
 | 
 | ||||||
|             <button type="button" class="btn btn-sm btn-outline-primary me-2" (click)="setPermissions()" [disabled]="!userOwnsAll || !userCanEditAll"> |     <div class="btn-group btn-group-sm"> | ||||||
|               <i-bs name="person-fill-lock"></i-bs><div class="d-none d-sm-inline"> <ng-container i18n>Permissions</ng-container></div> |       <button type="button" class="btn btn-sm btn-outline-danger" (click)="applyDelete()" *pngxIfPermissions="{ action: PermissionAction.Delete, type: PermissionType.Document }" [disabled]="!userOwnsAll"> | ||||||
|             </button> |         <i-bs name="trash"></i-bs> <ng-container i18n>Delete</ng-container> | ||||||
| 
 |       </button> | ||||||
|             <div ngbDropdown> |     </div> | ||||||
|               <button class="btn btn-sm btn-outline-primary" id="dropdownSelect" [disabled]="!userCanEdit && !userCanAdd" ngbDropdownToggle> |   </div> | ||||||
|                 <i-bs name="three-dots"></i-bs> | </div> | ||||||
|                 <div class="d-none d-sm-inline"> <ng-container i18n>Actions</ng-container></div> |  | ||||||
|               </button> |  | ||||||
|               <div ngbDropdownMenu aria-labelledby="dropdownSelect" class="shadow"> |  | ||||||
|                 <button ngbDropdownItem (click)="reprocessSelected()" [disabled]="!userCanEditAll && !userCanEditAll"> |  | ||||||
|                   <i-bs name="body-text"></i-bs> <ng-container i18n>Reprocess</ng-container> |  | ||||||
|                 </button> |  | ||||||
|                 <button ngbDropdownItem (click)="rotateSelected()" [disabled]="!userOwnsAll && !userCanEditAll"> |  | ||||||
|                   <i-bs name="arrow-clockwise"></i-bs> <ng-container i18n>Rotate</ng-container> |  | ||||||
|                 </button> |  | ||||||
|                 <button ngbDropdownItem (click)="mergeSelected()" [disabled]="!userCanAdd || list.selected.size < 2"> |  | ||||||
|                   <i-bs name="journals"></i-bs> <ng-container i18n>Merge</ng-container> |  | ||||||
|                 </button> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
| 
 |  | ||||||
|             <div class="btn-group btn-group-sm"> |  | ||||||
|               <button class="btn btn-sm btn-outline-primary" [disabled]="awaitingDownload" (click)="downloadSelected()"> |  | ||||||
|                 @if (!awaitingDownload) { |  | ||||||
|                   <i-bs name="arrow-down"></i-bs> |  | ||||||
|                 } |  | ||||||
|                 @if (awaitingDownload) { |  | ||||||
|                   <div class="spinner-border spinner-border-sm" role="status"> |  | ||||||
|                     <span class="visually-hidden">Preparing download...</span> |  | ||||||
|                   </div> |  | ||||||
|                 } |  | ||||||
|                 <div class="d-none d-sm-inline"> <ng-container i18n>Download</ng-container></div> |  | ||||||
|               </button> |  | ||||||
|               <div ngbDropdown class="me-2 d-flex btn-group" role="group"> |  | ||||||
|                 <button type="button" class="btn btn-sm btn-outline-primary dropdown-toggle-split rounded-end" ngbDropdownToggle></button> |  | ||||||
|                 <div ngbDropdownMenu aria-labelledby="dropdownSelect" class="shadow"> |  | ||||||
|                   <form [formGroup]="downloadForm" class="px-3 py-1"> |  | ||||||
|                     <p class="mb-1" i18n>Include:</p> |  | ||||||
|                     <div class="form-group ps-3 mb-2"> |  | ||||||
|                       <div class="form-check"> |  | ||||||
|                         <input type="checkbox" class="form-check-input" id="downloadFileType_archive" formControlName="downloadFileTypeArchive" /> |  | ||||||
|                         <label class="form-check-label" for="downloadFileType_archive" i18n>Archived files</label> |  | ||||||
|                       </div> |  | ||||||
|                       <div class="form-check"> |  | ||||||
|                         <input type="checkbox" class="form-check-input" id="downloadFileType_originals" formControlName="downloadFileTypeOriginals" /> |  | ||||||
|                         <label class="form-check-label" for="downloadFileType_originals" i18n>Original files</label> |  | ||||||
|                       </div> |  | ||||||
|                     </div> |  | ||||||
|                     <div class="form-check"> |  | ||||||
|                       <input type="checkbox" class="form-check-input" id="downloadUseFormatting" formControlName="downloadUseFormatting" /> |  | ||||||
|                       <label class="form-check-label" for="downloadUseFormatting" i18n>Use formatted filename</label> |  | ||||||
|                     </div> |  | ||||||
|                   </form> |  | ||||||
|                 </div> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|             <div class="btn-group btn-group-sm"> |  | ||||||
|               <button type="button" class="btn btn-sm btn-outline-danger" (click)="applyDelete()" *pngxIfPermissions="{ action: PermissionAction.Delete, type: PermissionType.Document }" [disabled]="!userOwnsAll"> |  | ||||||
|                 <i-bs name="trash"></i-bs> <ng-container i18n>Delete</ng-container> |  | ||||||
|                 </button> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|  | |||||||
| @ -5,3 +5,7 @@ | |||||||
| .dropdown-menu{ | .dropdown-menu{ | ||||||
|     --bs-dropdown-min-width: 12rem; |     --bs-dropdown-min-width: 12rem; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .btn-group .btn { | ||||||
|  |   white-space: nowrap; | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,16 +1,36 @@ | |||||||
| <pngx-page-header [title]="getTitle()"> | <pngx-page-header [title]="getTitle()"> | ||||||
| 
 |   <div ngbDropdown class="btn-group flex-fill d-sm-none"> | ||||||
|   <div ngbDropdown class="btn-group flex-fill"> |     <button class="btn btn-sm btn-outline-primary" id="dropdownSelectMobile" ngbDropdownToggle> | ||||||
|     <button class="btn btn-sm btn-outline-primary" id="dropdownSelect" ngbDropdownToggle> |  | ||||||
|       <i-bs name="text-indent-left"></i-bs> |       <i-bs name="text-indent-left"></i-bs> | ||||||
|       <div class="d-none d-sm-inline"> <ng-container i18n>Select</ng-container></div> |       <div class="d-none d-sm-inline"> <ng-container i18n>Select</ng-container></div> | ||||||
|  |       @if (list.selected.size > 0) { | ||||||
|  |         <pngx-clearable-badge [selected]="list.selected.size > 0" [number]="list.selected.size" (cleared)="list.selectNone()"></pngx-clearable-badge><span class="visually-hidden">selected</span> | ||||||
|  |       } | ||||||
|     </button> |     </button> | ||||||
|     <div ngbDropdownMenu aria-labelledby="dropdownSelect" class="shadow"> |     <div ngbDropdownMenu aria-labelledby="dropdownSelectMobile" class="shadow"> | ||||||
|       <button ngbDropdownItem (click)="list.selectNone()" i18n>Select none</button> |       <button ngbDropdownItem (click)="list.selectNone()" i18n>Select none</button> | ||||||
|       <button ngbDropdownItem (click)="list.selectPage()" i18n>Select page</button> |       <button ngbDropdownItem (click)="list.selectPage()" i18n>Select page</button> | ||||||
|       <button ngbDropdownItem (click)="list.selectAll()" i18n>Select all</button> |       <button ngbDropdownItem (click)="list.selectAll()" i18n>Select all</button> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
|  |   <div class="d-none d-sm-flex flex-fill me-3"> | ||||||
|  |     <div class="input-group input-group-sm"> | ||||||
|  |       <span class="input-group-text border-0">Select:</span> | ||||||
|  |     </div> | ||||||
|  |     <div class="btn-group btn-group-sm flex-nowrap"> | ||||||
|  |       @if (list.selected.size > 0) { | ||||||
|  |         <button class="btn btn-sm btn-outline-secondary" (click)="list.selectNone()"> | ||||||
|  |           <i-bs name="slash-circle"></i-bs> <ng-container i18n>None</ng-container> | ||||||
|  |         </button> | ||||||
|  |       } | ||||||
|  |       <button class="btn btn-sm btn-outline-primary" (click)="list.selectPage()"> | ||||||
|  |         <i-bs name="file-earmark-check"></i-bs> <ng-container i18n>Page</ng-container> | ||||||
|  |       </button> | ||||||
|  |       <button class="btn btn-sm btn-outline-primary" (click)="list.selectAll()"> | ||||||
|  |         <i-bs name="check-all"></i-bs> <ng-container i18n>All</ng-container> | ||||||
|  |       </button> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|   <div ngbDropdown class="btn-group flex-fill"> |   <div ngbDropdown class="btn-group flex-fill"> | ||||||
|     <button class="btn btn-sm btn-outline-primary" id="dropdownDisplayFields" ngbDropdownToggle> |     <button class="btn btn-sm btn-outline-primary" id="dropdownDisplayFields" ngbDropdownToggle> | ||||||
|       <i-bs name="card-heading"></i-bs> |       <i-bs name="card-heading"></i-bs> | ||||||
| @ -126,8 +146,13 @@ | |||||||
|       @if (!list.isReloading && isFiltered) { |       @if (!list.isReloading && isFiltered) { | ||||||
|         <button class="btn btn-link py-0" (click)="resetFilters()"> |         <button class="btn btn-link py-0" (click)="resetFilters()"> | ||||||
|           <i-bs width="1em" height="1em" name="x"></i-bs><small i18n>Reset filters</small> |           <i-bs width="1em" height="1em" name="x"></i-bs><small i18n>Reset filters</small> | ||||||
|           </button> |         </button> | ||||||
|         } |       } | ||||||
|  |       @if (!list.isReloading && list.selected.size > 0) { | ||||||
|  |         <button class="btn btn-link py-0" (click)="list.selectNone()"> | ||||||
|  |           <i-bs width="1em" height="1em" name="slash-circle" class="me-1"></i-bs><small i18n>Clear selection</small> | ||||||
|  |         </button> | ||||||
|  |       } | ||||||
|       </div> |       </div> | ||||||
|       @if (list.collectionSize) { |       @if (list.collectionSize) { | ||||||
|         <ngb-pagination [pageSize]="list.pageSize" [collectionSize]="list.collectionSize" [(page)]="list.currentPage" [maxSize]="5" |         <ngb-pagination [pageSize]="list.pageSize" [collectionSize]="list.collectionSize" [(page)]="list.currentPage" [maxSize]="5" | ||||||
|  | |||||||
| @ -56,6 +56,7 @@ import { | |||||||
|   filterRulesDiffer, |   filterRulesDiffer, | ||||||
|   isFullTextFilterRule, |   isFullTextFilterRule, | ||||||
| } from 'src/app/utils/filter-rules' | } from 'src/app/utils/filter-rules' | ||||||
|  | import { ClearableBadgeComponent } from '../common/clearable-badge/clearable-badge.component' | ||||||
| import { CustomFieldDisplayComponent } from '../common/custom-field-display/custom-field-display.component' | import { CustomFieldDisplayComponent } from '../common/custom-field-display/custom-field-display.component' | ||||||
| import { PageHeaderComponent } from '../common/page-header/page-header.component' | import { PageHeaderComponent } from '../common/page-header/page-header.component' | ||||||
| import { PreviewPopupComponent } from '../common/preview-popup/preview-popup.component' | import { PreviewPopupComponent } from '../common/preview-popup/preview-popup.component' | ||||||
| @ -72,6 +73,7 @@ import { SaveViewConfigDialogComponent } from './save-view-config-dialog/save-vi | |||||||
|   templateUrl: './document-list.component.html', |   templateUrl: './document-list.component.html', | ||||||
|   styleUrls: ['./document-list.component.scss'], |   styleUrls: ['./document-list.component.scss'], | ||||||
|   imports: [ |   imports: [ | ||||||
|  |     ClearableBadgeComponent, | ||||||
|     CustomFieldDisplayComponent, |     CustomFieldDisplayComponent, | ||||||
|     PageHeaderComponent, |     PageHeaderComponent, | ||||||
|     BulkEditorComponent, |     BulkEditorComponent, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user