mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-24 23:39:05 -04:00 
			
		
		
		
	Enhancement: Explain behavior of unset app config boolean to user (#5345)
This commit is contained in:
		
							parent
							
								
									8e8810cbaa
								
							
						
					
					
						commit
						3dcb973adb
					
				| @ -3706,7 +3706,7 @@ | |||||||
|         </context-group> |         </context-group> | ||||||
|         <context-group purpose="location"> |         <context-group purpose="location"> | ||||||
|           <context context-type="sourcefile">src/app/components/common/input/switch/switch.component.html</context> |           <context context-type="sourcefile">src/app/components/common/input/switch/switch.component.html</context> | ||||||
|           <context context-type="linenumber">10</context> |           <context context-type="linenumber">17</context> | ||||||
|         </context-group> |         </context-group> | ||||||
|         <context-group purpose="location"> |         <context-group purpose="location"> | ||||||
|           <context context-type="sourcefile">src/app/components/common/input/text/text.component.html</context> |           <context context-type="sourcefile">src/app/components/common/input/text/text.component.html</context> | ||||||
| @ -3827,6 +3827,13 @@ | |||||||
|           <context context-type="linenumber">92</context> |           <context context-type="linenumber">92</context> | ||||||
|         </context-group> |         </context-group> | ||||||
|       </trans-unit> |       </trans-unit> | ||||||
|  |       <trans-unit id="6541407358060244620" datatype="html"> | ||||||
|  |         <source>Note: value has not yet been set and will not apply until explicitly changed</source> | ||||||
|  |         <context-group purpose="location"> | ||||||
|  |           <context context-type="sourcefile">src/app/components/common/input/switch/switch.component.html</context> | ||||||
|  |           <context context-type="linenumber">45</context> | ||||||
|  |         </context-group> | ||||||
|  |       </trans-unit> | ||||||
|       <trans-unit id="6560126119609945418" datatype="html"> |       <trans-unit id="6560126119609945418" datatype="html"> | ||||||
|         <source>Add tag</source> |         <source>Add tag</source> | ||||||
|         <context-group purpose="location"> |         <context-group purpose="location"> | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ | |||||||
|                                                 @switch (option.type) { |                                                 @switch (option.type) { | ||||||
|                                                     @case (ConfigOptionType.Select) { <pngx-input-select [formControlName]="option.key" [error]="errors[option.key]" [items]="option.choices" [allowNull]="true"></pngx-input-select> } |                                                     @case (ConfigOptionType.Select) { <pngx-input-select [formControlName]="option.key" [error]="errors[option.key]" [items]="option.choices" [allowNull]="true"></pngx-input-select> } | ||||||
|                                                     @case (ConfigOptionType.Number) { <pngx-input-number [formControlName]="option.key" [error]="errors[option.key]" [showAdd]="false"></pngx-input-number> } |                                                     @case (ConfigOptionType.Number) { <pngx-input-number [formControlName]="option.key" [error]="errors[option.key]" [showAdd]="false"></pngx-input-number> } | ||||||
|                                                     @case (ConfigOptionType.Boolean) { <pngx-input-switch [formControlName]="option.key" [error]="errors[option.key]" [horizontal]="true" title="Enable" i18n-title></pngx-input-switch> } |                                                     @case (ConfigOptionType.Boolean) { <pngx-input-switch [formControlName]="option.key" [error]="errors[option.key]" [showUnsetNote]="true" [horizontal]="true" title="Enable" i18n-title></pngx-input-switch> } | ||||||
|                                                     @case (ConfigOptionType.String) { <pngx-input-text [formControlName]="option.key" [error]="errors[option.key]"></pngx-input-text> } |                                                     @case (ConfigOptionType.String) { <pngx-input-text [formControlName]="option.key" [error]="errors[option.key]"></pngx-input-text> } | ||||||
|                                                     @case (ConfigOptionType.JSON) { <pngx-input-text [formControlName]="option.key" [error]="errors[option.key]"></pngx-input-text> } |                                                     @case (ConfigOptionType.JSON) { <pngx-input-text [formControlName]="option.key" [error]="errors[option.key]"></pngx-input-text> } | ||||||
|                                                 } |                                                 } | ||||||
|  | |||||||
| @ -2,7 +2,14 @@ | |||||||
|   <div class="row"> |   <div class="row"> | ||||||
|     @if (!horizontal) { |     @if (!horizontal) { | ||||||
|       <div class="d-flex align-items-center position-relative hidden-button-container col-md-3"> |       <div class="d-flex align-items-center position-relative hidden-button-container col-md-3"> | ||||||
|         <label class="form-label" [for]="inputId">{{title}}</label> |         <label class="form-label" [for]="inputId" [ngbTooltip]="showUnsetNote && isUnset ? tipContent: null" placement="end"> | ||||||
|  |           {{title}} | ||||||
|  |           @if (showUnsetNote && isUnset) { | ||||||
|  |             <svg class="sidebaricon-sm ms-1" fill="currentColor"> | ||||||
|  |                 <use xlink:href="assets/bootstrap-icons.svg#exclamation-triangle"/> | ||||||
|  |               </svg> | ||||||
|  |           } | ||||||
|  |         </label> | ||||||
|         @if (removable) { |         @if (removable) { | ||||||
|           <button type="button" class="btn btn-sm btn-danger position-absolute left-0" (click)="removed.emit(this)"> |           <button type="button" class="btn btn-sm btn-danger position-absolute left-0" (click)="removed.emit(this)"> | ||||||
|             <svg class="sidebaricon" fill="currentColor"> |             <svg class="sidebaricon" fill="currentColor"> | ||||||
| @ -16,7 +23,14 @@ | |||||||
|       <div class="form-check form-switch"> |       <div class="form-check form-switch"> | ||||||
|         <input #inputField type="checkbox" class="form-check-input" [id]="inputId" [(ngModel)]="value" (change)="onChange(value)" (blur)="onTouched()" [disabled]="disabled"> |         <input #inputField type="checkbox" class="form-check-input" [id]="inputId" [(ngModel)]="value" (change)="onChange(value)" (blur)="onTouched()" [disabled]="disabled"> | ||||||
|         @if (horizontal) { |         @if (horizontal) { | ||||||
|           <label class="form-check-label" [for]="inputId">{{title}}</label> |           <label class="form-check-label" [class.text-muted]="showUnsetNote && isUnset" [for]="inputId" [ngbTooltip]="showUnsetNote && isUnset ? tipContent: null" placement="end"> | ||||||
|  |             {{title}} | ||||||
|  |             @if (showUnsetNote && isUnset) { | ||||||
|  |               <svg class="sidebaricon-sm ms-1" fill="currentColor"> | ||||||
|  |                 <use xlink:href="assets/bootstrap-icons.svg#exclamation-triangle"/> | ||||||
|  |               </svg> | ||||||
|  |             } | ||||||
|  |           </label> | ||||||
|         } |         } | ||||||
|         @if (hint) { |         @if (hint) { | ||||||
|           <div class="form-text text-muted">{{hint}}</div> |           <div class="form-text text-muted">{{hint}}</div> | ||||||
| @ -25,3 +39,8 @@ | |||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </div> | </div> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <ng-template #tipContent> | ||||||
|  |   <span class="text-light fst-italic" i18n>Note: value has not yet been set and will not apply until explicitly changed</span> | ||||||
|  | </ng-template> | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import { | |||||||
|   NG_VALUE_ACCESSOR, |   NG_VALUE_ACCESSOR, | ||||||
|   ReactiveFormsModule, |   ReactiveFormsModule, | ||||||
| } from '@angular/forms' | } from '@angular/forms' | ||||||
|  | import { NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap' | ||||||
| 
 | 
 | ||||||
| describe('SwitchComponent', () => { | describe('SwitchComponent', () => { | ||||||
|   let component: SwitchComponent |   let component: SwitchComponent | ||||||
| @ -15,7 +16,7 @@ describe('SwitchComponent', () => { | |||||||
|     TestBed.configureTestingModule({ |     TestBed.configureTestingModule({ | ||||||
|       declarations: [SwitchComponent], |       declarations: [SwitchComponent], | ||||||
|       providers: [], |       providers: [], | ||||||
|       imports: [FormsModule, ReactiveFormsModule], |       imports: [FormsModule, ReactiveFormsModule, NgbTooltipModule], | ||||||
|     }).compileComponents() |     }).compileComponents() | ||||||
| 
 | 
 | ||||||
|     fixture = TestBed.createComponent(SwitchComponent) |     fixture = TestBed.createComponent(SwitchComponent) | ||||||
| @ -36,4 +37,9 @@ describe('SwitchComponent', () => { | |||||||
|     fixture.detectChanges() |     fixture.detectChanges() | ||||||
|     expect(component.value).toBeFalsy() |     expect(component.value).toBeFalsy() | ||||||
|   }) |   }) | ||||||
|  | 
 | ||||||
|  |   it('should show note if unset', () => { | ||||||
|  |     component.value = null | ||||||
|  |     expect(component.isUnset).toBeTruthy() | ||||||
|  |   }) | ||||||
| }) | }) | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| import { Component, forwardRef } from '@angular/core' | import { Component, Input, forwardRef } from '@angular/core' | ||||||
| import { NG_VALUE_ACCESSOR } from '@angular/forms' | import { NG_VALUE_ACCESSOR } from '@angular/forms' | ||||||
| import { AbstractInputComponent } from '../abstract-input' | import { AbstractInputComponent } from '../abstract-input' | ||||||
| 
 | 
 | ||||||
| @ -15,7 +15,14 @@ import { AbstractInputComponent } from '../abstract-input' | |||||||
|   styleUrls: ['./switch.component.scss'], |   styleUrls: ['./switch.component.scss'], | ||||||
| }) | }) | ||||||
| export class SwitchComponent extends AbstractInputComponent<boolean> { | export class SwitchComponent extends AbstractInputComponent<boolean> { | ||||||
|  |   @Input() | ||||||
|  |   showUnsetNote: boolean = false | ||||||
|  | 
 | ||||||
|   constructor() { |   constructor() { | ||||||
|     super() |     super() | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|  |   get isUnset(): boolean { | ||||||
|  |     return this.value === null || this.value === undefined | ||||||
|  |   } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user