diff --git a/src-ui/messages.xlf b/src-ui/messages.xlf index c0fe2eba2..9dc2df42d 100644 --- a/src-ui/messages.xlf +++ b/src-ui/messages.xlf @@ -2235,7 +2235,7 @@ src/app/components/document-detail/document-detail.component.ts - 856 + 860 @@ -2512,31 +2512,31 @@ src/app/components/document-detail/document-detail.component.ts - 880 + 884 src/app/components/document-detail/document-detail.component.ts - 1180 + 1191 src/app/components/document-detail/document-detail.component.ts - 1219 + 1230 src/app/components/document-detail/document-detail.component.ts - 1260 + 1271 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 759 + 773 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 792 + 806 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 811 + 825 src/app/components/manage/custom-fields/custom-fields.component.ts @@ -3118,31 +3118,31 @@ src/app/components/document-detail/document-detail.component.ts - 833 + 837 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 402 + 416 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 442 + 456 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 480 + 494 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 518 + 532 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 580 + 594 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 713 + 727 @@ -6104,7 +6104,7 @@ src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 347 + 361 this string is used to separate processing, failed and added on the file upload widget @@ -6226,7 +6226,7 @@ src/app/components/document-detail/document-detail.component.ts - 1237 + 1248 src/app/guards/dirty-saved-view.guard.ts @@ -6594,203 +6594,203 @@ Error retrieving suggestions. src/app/components/document-detail/document-detail.component.ts - 596 + 600 Document saved successfully. src/app/components/document-detail/document-detail.component.ts - 747 + 751 src/app/components/document-detail/document-detail.component.ts - 761 + 765 Error saving document src/app/components/document-detail/document-detail.component.ts - 765 + 769 src/app/components/document-detail/document-detail.component.ts - 806 + 810 Do you really want to move the document "" to the trash? src/app/components/document-detail/document-detail.component.ts - 834 + 838 Documents can be restored prior to permanent deletion. src/app/components/document-detail/document-detail.component.ts - 835 + 839 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 715 + 729 Move to trash src/app/components/document-detail/document-detail.component.ts - 837 + 841 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 717 + 731 Reprocess confirm src/app/components/document-detail/document-detail.component.ts - 876 + 880 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 755 + 769 This operation will permanently recreate the archive file for this document. src/app/components/document-detail/document-detail.component.ts - 877 + 881 The archive file will be re-generated with the current settings. src/app/components/document-detail/document-detail.component.ts - 878 + 882 Reprocess operation will begin in the background. Close and re-open or reload this document after the operation has completed to see new content. src/app/components/document-detail/document-detail.component.ts - 888 + 892 Error executing operation src/app/components/document-detail/document-detail.component.ts - 899 + 903 Page Fit src/app/components/document-detail/document-detail.component.ts - 972 + 976 Split confirm src/app/components/document-detail/document-detail.component.ts - 1178 + 1189 This operation will split the selected document(s) into new documents. src/app/components/document-detail/document-detail.component.ts - 1179 + 1190 Split operation will begin in the background. src/app/components/document-detail/document-detail.component.ts - 1195 + 1206 Error executing split operation src/app/components/document-detail/document-detail.component.ts - 1204 + 1215 Rotate confirm src/app/components/document-detail/document-detail.component.ts - 1217 + 1228 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 789 + 803 This operation will permanently rotate the original version of the current document. src/app/components/document-detail/document-detail.component.ts - 1218 + 1229 Rotation will begin in the background. Close and re-open the document after the operation has completed to see the changes. src/app/components/document-detail/document-detail.component.ts - 1234 + 1245 Error executing rotate operation src/app/components/document-detail/document-detail.component.ts - 1246 + 1257 Delete pages confirm src/app/components/document-detail/document-detail.component.ts - 1258 + 1269 This operation will permanently delete the selected pages from the original document. src/app/components/document-detail/document-detail.component.ts - 1259 + 1270 Delete pages operation will begin in the background. Close and re-open or reload this document after the operation has completed to see the changes. src/app/components/document-detail/document-detail.component.ts - 1274 + 1285 Error executing delete pages operation src/app/components/document-detail/document-detail.component.ts - 1283 + 1294 An error occurred loading tiff: src/app/components/document-detail/document-detail.component.ts - 1323 + 1334 src/app/components/document-detail/document-detail.component.ts - 1327 + 1338 @@ -6926,29 +6926,29 @@ Error executing bulk operation src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 251 + 265 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 859 + 873 "" src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 339 + 353 src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 345 + 359 "" and "" src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 341 + 355 This is for messages like 'modify "tag1" and "tag2"' @@ -6956,7 +6956,7 @@ and "" src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 349,351 + 363,365 this is for messages like 'modify "tag1", "tag2" and "tag3"' @@ -6964,14 +6964,14 @@ Confirm tags assignment src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 366 + 380 This operation will add the tag "" to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 372 + 386 @@ -6980,14 +6980,14 @@ )"/> to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 377,379 + 391,393 This operation will remove the tag "" from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 385 + 399 @@ -6996,7 +6996,7 @@ )"/> from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 390,392 + 404,406 @@ -7007,84 +7007,84 @@ )"/> on selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 394,398 + 408,412 Confirm correspondent assignment src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 435 + 449 This operation will assign the correspondent "" to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 437 + 451 This operation will remove the correspondent from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 439 + 453 Confirm document type assignment src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 473 + 487 This operation will assign the document type "" to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 475 + 489 This operation will remove the document type from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 477 + 491 Confirm storage path assignment src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 511 + 525 This operation will assign the storage path "" to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 513 + 527 This operation will remove the storage path from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 515 + 529 Confirm custom field assignment src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 544 + 558 This operation will assign the custom field "" to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 550 + 564 @@ -7093,14 +7093,14 @@ )"/> to selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 555,557 + 569,571 This operation will remove the custom field "" from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 563 + 577 @@ -7109,7 +7109,7 @@ )"/> from selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 568,570 + 582,584 @@ -7120,63 +7120,63 @@ )"/> on selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 572,576 + 586,590 Move selected document(s) to the trash? src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 714 + 728 This operation will permanently recreate the archive files for selected document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 756 + 770 The archive files will be re-generated with the current settings. src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 757 + 771 This operation will permanently rotate the original version of document(s). src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 790 + 804 Merge confirm src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 809 + 823 This operation will merge selected documents into a new document. src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 810 + 824 Merged document will be queued for consumption. src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 826 + 840 Bulk operation executed successfully src/app/components/document-list/bulk-editor/bulk-editor.component.ts - 849 + 863 diff --git a/src-ui/src/app/components/common/input/document-link/document-link.component.scss b/src-ui/src/app/components/common/input/document-link/document-link.component.scss index 1c83a7122..c83886844 100644 --- a/src-ui/src/app/components/common/input/document-link/document-link.component.scss +++ b/src-ui/src/app/components/common/input/document-link/document-link.component.scss @@ -14,7 +14,7 @@ div, .ng-arrow-wrapper, input { cursor: not-allowed; } - background-color: var(--pngx-bg-alt) !important; + background-color: var(--pngx-bg-disabled) !important; } } } diff --git a/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.spec.ts b/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.spec.ts index 4c39353ac..90957c3ea 100644 --- a/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.spec.ts +++ b/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.spec.ts @@ -66,4 +66,11 @@ describe('PermissionsFormComponent', () => { }, }) }) + + it('should disable form on disabled state change', () => { + component.setDisabledState(false) + expect(component.form.disabled).toBeFalsy() + component.setDisabledState(true) + expect(component.form.disabled).toBeTruthy() + }) }) diff --git a/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.ts b/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.ts index 313465953..7612b2acd 100644 --- a/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.ts +++ b/src-ui/src/app/components/common/input/permissions/permissions-form/permissions-form.component.ts @@ -66,4 +66,12 @@ export class PermissionsFormComponent writeValue(newValue: any): void { this.form.patchValue(newValue, { emitEvent: false }) } + + public setDisabledState(isDisabled: boolean): void { + if (isDisabled) { + this.form.disable() + } else { + this.form.enable() + } + } } diff --git a/src-ui/src/app/components/common/input/permissions/permissions-group/permissions-group.component.scss b/src-ui/src/app/components/common/input/permissions/permissions-group/permissions-group.component.scss index 822f7e490..cbf101ea6 100644 --- a/src-ui/src/app/components/common/input/permissions/permissions-group/permissions-group.component.scss +++ b/src-ui/src/app/components/common/input/permissions/permissions-group/permissions-group.component.scss @@ -5,7 +5,7 @@ pointer-events: none; .ng-select-container { - background-color: var(--pngx-bg-alt) !important; + background-color: var(--pngx-bg-disabled) !important; } } } diff --git a/src-ui/src/app/components/common/input/permissions/permissions-user/permissions-user.component.scss b/src-ui/src/app/components/common/input/permissions/permissions-user/permissions-user.component.scss index 822f7e490..cbf101ea6 100644 --- a/src-ui/src/app/components/common/input/permissions/permissions-user/permissions-user.component.scss +++ b/src-ui/src/app/components/common/input/permissions/permissions-user/permissions-user.component.scss @@ -5,7 +5,7 @@ pointer-events: none; .ng-select-container { - background-color: var(--pngx-bg-alt) !important; + background-color: var(--pngx-bg-disabled) !important; } } } diff --git a/src-ui/src/app/components/common/input/select/select.component.scss b/src-ui/src/app/components/common/input/select/select.component.scss index 4a6f6da61..e739081f1 100644 --- a/src-ui/src/app/components/common/input/select/select.component.scss +++ b/src-ui/src/app/components/common/input/select/select.component.scss @@ -9,7 +9,7 @@ pointer-events: none; .ng-select-container { - background-color: var(--pngx-bg-alt) !important; + background-color: var(--pngx-bg-disabled) !important; } } } diff --git a/src-ui/src/app/components/common/input/tags/tags.component.scss b/src-ui/src/app/components/common/input/tags/tags.component.scss index 65b8603e0..342342f25 100644 --- a/src-ui/src/app/components/common/input/tags/tags.component.scss +++ b/src-ui/src/app/components/common/input/tags/tags.component.scss @@ -16,7 +16,7 @@ pointer-events: none; .ng-select-container { - background-color: var(--pngx-bg-alt) !important; + background-color: var(--pngx-bg-disabled) !important; } } } diff --git a/src-ui/src/app/components/document-detail/document-detail.component.html b/src-ui/src/app/components/document-detail/document-detail.component.html index 86767b6e7..ba91d7f5d 100644 --- a/src-ui/src/app/components/document-detail/document-detail.component.html +++ b/src-ui/src/app/components/document-detail/document-detail.component.html @@ -45,7 +45,7 @@
 Actions
- @@ -53,15 +53,15 @@  More like this - - -
@@ -70,7 +70,7 @@ @@ -122,7 +122,7 @@ @case (CustomFieldDataType.String) { @@ -130,7 +130,7 @@ @case (CustomFieldDataType.Date) { @@ -138,7 +138,7 @@ @case (CustomFieldDataType.Integer) { @@ -166,14 +166,14 @@ @case (CustomFieldDataType.Boolean) { } @case (CustomFieldDataType.Url) { @@ -182,7 +182,7 @@ @@ -194,7 +194,7 @@ bindLabel="label" [allowNull]="true" [horizontal]="true" - [removable]="userIsOwner" + [removable]="userIsOwner && userCanEdit" (removed)="removeField(fieldInstance)" [error]="getCustomFieldError(i)"> } diff --git a/src-ui/src/app/components/document-detail/document-detail.component.ts b/src-ui/src/app/components/document-detail/document-detail.component.ts index f1afd95c0..2b39535ca 100644 --- a/src-ui/src/app/components/document-detail/document-detail.component.ts +++ b/src-ui/src/app/components/document-detail/document-detail.component.ts @@ -577,6 +577,10 @@ export class DocumentDetailComponent this.permissionsService.currentUserHasObjectPermissions( PermissionAction.Change, doc + ) && + this.permissionsService.currentUserCan( + PermissionAction.Change, + PermissionType.Document ) ) { this.documentsService @@ -1066,6 +1070,13 @@ export class DocumentDetailComponent ) } + get userCanAdd(): boolean { + return this.permissionsService.currentUserCan( + PermissionAction.Add, + PermissionType.Document + ) + } + filterDocuments(items: ObjectWithId[] | NgbDateStruct[], type?: DataType) { const filterRules: FilterRule[] = items.flatMap((i) => { if (i.hasOwnProperty('year')) { diff --git a/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.html b/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.html index 242e8abab..ac8f476c7 100644 --- a/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.html +++ b/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.html @@ -105,18 +105,18 @@
-
- - -
diff --git a/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.ts b/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.ts index 499f52f03..f671602c0 100644 --- a/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.ts +++ b/src-ui/src/app/components/document-list/bulk-editor/bulk-editor.component.ts @@ -132,6 +132,20 @@ export class BulkEditorComponent return ownsAll } + get userCanEdit(): boolean { + return this.permissionService.currentUserCan( + PermissionAction.Change, + PermissionType.Document + ) + } + + get userCanAdd(): boolean { + return this.permissionService.currentUserCan( + PermissionAction.Add, + PermissionType.Document + ) + } + ngOnInit() { if ( this.permissionService.currentUserCan( diff --git a/src-ui/src/styles.scss b/src-ui/src/styles.scss index a1fa794f3..e5987d5d2 100644 --- a/src-ui/src/styles.scss +++ b/src-ui/src/styles.scss @@ -366,7 +366,7 @@ textarea, } .form-control:disabled, .form-control[readonly] { - background-color: var(--pngx-bg-alt); + background-color: var(--pngx-bg-disabled); cursor: not-allowed; } diff --git a/src-ui/src/theme.scss b/src-ui/src/theme.scss index 1d0e8e7d6..380f78d7d 100644 --- a/src-ui/src/theme.scss +++ b/src-ui/src/theme.scss @@ -25,6 +25,7 @@ $color-mode-type: data; --pngx-bg-alt: #fff; --pngx-bg-darker: var(--bs-gray-100); --pngx-bg-alt2: var(--bs-gray-200); + --pngx-bg-disabled: #f7f7f7; --pngx-focus-alpha: 0.3; } @@ -83,6 +84,7 @@ $form-check-radio-checked-bg-image-dark: url("data:image/svg+xml,