mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05: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 {
|
||||||
return super.transform(value, format || this.settings.get(SETTINGS_KEYS.DATE_FORMAT), timezone, locale)
|
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)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user