mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-25 15:52:35 -04:00 
			
		
		
		
	add support for iso 8601 date display
This commit is contained in:
		
							parent
							
								
									1e4ec7e29e
								
							
						
					
					
						commit
						1c81d88013
					
				| @ -34,7 +34,7 @@ | |||||||
|           <div class="col"> |           <div class="col"> | ||||||
| 
 | 
 | ||||||
|             <select class="form-control" formControlName="dateLocale"> |             <select class="form-control" formControlName="dateLocale"> | ||||||
|               <option *ngFor="let lang of dateLocaleOptions" [ngValue]="lang.code">{{lang.name}}<span *ngIf="lang.code"> - {{today | date:'shortDate':null:lang.code}}</span></option> |               <option *ngFor="let lang of dateLocaleOptions" [ngValue]="lang.code">{{lang.name}}<span *ngIf="lang.code"> - {{today | customDate:'shortDate':null:lang.code}}</span></option> | ||||||
|             </select> |             </select> | ||||||
| 
 | 
 | ||||||
|           </div> |           </div> | ||||||
|  | |||||||
| @ -35,7 +35,7 @@ export class SettingsComponent implements OnInit { | |||||||
|   savedViews: PaperlessSavedView[] |   savedViews: PaperlessSavedView[] | ||||||
| 
 | 
 | ||||||
|   get computedDateLocale(): string { |   get computedDateLocale(): string { | ||||||
|     return this.settingsForm.value.dateLocale || this.settingsForm.value.displayLanguage |     return this.settingsForm.value.dateLocale || this.settingsForm.value.displayLanguage || this.currentLocale | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   constructor( |   constructor( | ||||||
| @ -92,7 +92,10 @@ export class SettingsComponent implements OnInit { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   get dateLocaleOptions(): LanguageOption[] { |   get dateLocaleOptions(): LanguageOption[] { | ||||||
|     return [{code: "", name: $localize`Use date format of display language`}].concat(this.settings.getLanguageOptions()) |     return [ | ||||||
|  |       {code: "", name: $localize`Use date format of display language`}, | ||||||
|  |       {code: "iso-8601", name: $localize`ISO 8601`} | ||||||
|  |     ].concat(this.settings.getLanguageOptions()) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   get today() { |   get today() { | ||||||
|  | |||||||
| @ -2,18 +2,29 @@ import { DatePipe } from '@angular/common'; | |||||||
| import { Inject, LOCALE_ID, Pipe, PipeTransform } from '@angular/core'; | import { Inject, LOCALE_ID, Pipe, PipeTransform } from '@angular/core'; | ||||||
| import { SettingsService, SETTINGS_KEYS } from '../services/settings.service'; | import { SettingsService, SETTINGS_KEYS } from '../services/settings.service'; | ||||||
| 
 | 
 | ||||||
|  | const FORMAT_TO_ISO_FORMAT = { | ||||||
|  |   "longDate": "y-MM-dd", | ||||||
|  |   "mediumDate": "yy-MM-dd", | ||||||
|  |   "shortDate": "yy-MM-dd" | ||||||
|  | } | ||||||
|  | 
 | ||||||
| @Pipe({ | @Pipe({ | ||||||
|   name: 'customDate' |   name: 'customDate' | ||||||
| }) | }) | ||||||
| export class CustomDatePipe extends DatePipe implements PipeTransform { | export class CustomDatePipe extends DatePipe implements PipeTransform { | ||||||
| 
 | 
 | ||||||
|   constructor(@Inject(LOCALE_ID) locale: string, private settings: SettingsService) { |   constructor(@Inject(LOCALE_ID) locale: string, private settings: SettingsService) { | ||||||
|     super(settings.get(SETTINGS_KEYS.DATE_LOCALE) || locale) |     super(locale) | ||||||
| 
 |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   transform(value: any, format?: string, timezone?: string, locale?: string): string | null { |   transform(value: any, format?: string, timezone?: string, locale?: string): string | null { | ||||||
|  |     let l = locale || this.settings.get(SETTINGS_KEYS.DATE_LOCALE) | ||||||
|  |     let f = format || this.settings.get(SETTINGS_KEYS.DATE_FORMAT) | ||||||
|  |     if (l == "iso-8601") { | ||||||
|  |       return super.transform(value, FORMAT_TO_ISO_FORMAT[f], timezone) | ||||||
|  |     } else { | ||||||
|       return super.transform(value, format || this.settings.get(SETTINGS_KEYS.DATE_FORMAT), timezone, locale) |       return super.transform(value, format || this.settings.get(SETTINGS_KEYS.DATE_FORMAT), timezone, locale) | ||||||
|     } |     } | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user