@haiilo/ngx-intl
Version:
Standalone Angular pipes using the ECMAScript Internationalization API, which provides language sensitive string comparison, number formatting, and date and time formatting.
88 lines • 14.7 kB
JavaScript
import { Inject, InjectionToken, LOCALE_ID, Optional, Pipe } from '@angular/core';
import * as i0 from "@angular/core";
export const INTL_DATE_OPTIONS = new InjectionToken('IntlDateOptions');
export const INTL_DATE_TIMEZONE = new InjectionToken('IntlDateTimezone');
export const INTL_DATE_PRESET_SHORT = { dateStyle: 'short', timeStyle: 'short' };
export const INTL_DATE_PRESET_MEDIUM = { dateStyle: 'medium', timeStyle: 'medium' };
export const INTL_DATE_PRESET_LONG = { dateStyle: 'long', timeStyle: 'long' };
export const INTL_DATE_PRESET_FULL = { year: 'numeric', month: 'long', day: 'numeric', weekday: 'long', hour: 'numeric', minute: 'numeric', second: 'numeric', timeZoneName: 'long' };
export const INTL_DATE_PRESET_SHORT_DATE = { dateStyle: 'short' };
export const INTL_DATE_PRESET_MEDIUM_DATE = { dateStyle: 'medium' };
export const INTL_DATE_PRESET_LONG_DATE = { dateStyle: 'long' };
export const INTL_DATE_PRESET_FULL_DATE = { year: 'numeric', month: 'long', day: 'numeric', weekday: 'long' };
export const INTL_DATE_PRESET_SHORT_TIME = { timeStyle: 'short' };
export const INTL_DATE_PRESET_MEDIUM_TIME = { timeStyle: 'medium' };
export const INTL_DATE_PRESET_LONG_TIME = { timeStyle: 'long' };
export const INTL_DATE_PRESET_FULL_TIME = { hour: 'numeric', minute: 'numeric', second: 'numeric', timeZoneName: 'long' };
/**
* A pipe that formats a date using the Intl.DateTimeFormat API.
*/
export class IntlDatePipe {
constructor(locale, options, timezone) {
this.locale = locale;
this.options = options;
this.timezone = timezone;
}
transform(value, options, ...locales) {
if (value === null) {
return null;
}
const _locales = this.getLocales(locales);
const _options = this.getOptions(options);
const formatValue = typeof value === 'string' ? new Date(value) : value;
return new Intl.DateTimeFormat(_locales, _options).format(formatValue);
}
getLocales(locales) {
return [...locales, this.locale];
}
getOptions(options) {
const presetStr = typeof options === 'string';
const presetKey = !presetStr
? options?.preset || this.options?.defaultPreset || IntlDatePipe.DEFAULT_OPTIONS.defaultPreset
: options;
const preset = presetKey
? (this.options?.presets?.[presetKey] || IntlDatePipe.DEFAULT_OPTIONS.presets?.[presetKey])
: undefined;
const timezone = this.timezone ? { timeZone: this.timezone } : {};
return { ...timezone, ...preset, ...(!presetStr ? options : undefined) };
}
}
IntlDatePipe.DEFAULT_OPTIONS = {
presets: {
short: INTL_DATE_PRESET_SHORT,
medium: INTL_DATE_PRESET_MEDIUM,
long: INTL_DATE_PRESET_LONG,
full: INTL_DATE_PRESET_FULL,
shortDate: INTL_DATE_PRESET_SHORT_DATE,
mediumDate: INTL_DATE_PRESET_MEDIUM_DATE,
longDate: INTL_DATE_PRESET_LONG_DATE,
fullDate: INTL_DATE_PRESET_FULL_DATE,
shortTime: INTL_DATE_PRESET_SHORT_TIME,
mediumTime: INTL_DATE_PRESET_MEDIUM_TIME,
longTime: INTL_DATE_PRESET_LONG_TIME,
fullTime: INTL_DATE_PRESET_FULL_TIME
}
};
IntlDatePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: IntlDatePipe, deps: [{ token: LOCALE_ID }, { token: INTL_DATE_OPTIONS, optional: true }, { token: INTL_DATE_TIMEZONE, optional: true }], target: i0.ɵɵFactoryTarget.Pipe });
IntlDatePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: IntlDatePipe, isStandalone: true, name: "intlDate" });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: IntlDatePipe, decorators: [{
type: Pipe,
args: [{
name: 'intlDate',
standalone: true
}]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
type: Inject,
args: [LOCALE_ID]
}] }, { type: undefined, decorators: [{
type: Inject,
args: [INTL_DATE_OPTIONS]
}, {
type: Optional
}] }, { type: undefined, decorators: [{
type: Inject,
args: [INTL_DATE_TIMEZONE]
}, {
type: Optional
}] }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intl-date.pipe.js","sourceRoot":"","sources":["../../../../projects/ngx-intl/src/lib/intl-date.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, InjectionToken, LOCALE_ID, Optional, Pipe, PipeTransform } from '@angular/core';\n\n/** A preconfigured option preset for the IntlDatePipe. */\nexport interface IntlDateOptions extends Intl.DateTimeFormatOptions {}\n\n/** Global options and presets for the IntlDatePipe. */\nexport interface IntlDateGlobalOptions {\n  presets?: { [key: string]: IntlDateOptions };\n  defaultPreset?: string;\n}\n\n/** Options for a transform call of the IntlDatePipe. */\nexport interface IntlDateLocalOptions extends IntlDateOptions {\n  preset?: string;\n}\n\nexport const INTL_DATE_OPTIONS =\n  new InjectionToken<IntlDateGlobalOptions>('IntlDateOptions');\n\nexport const INTL_DATE_TIMEZONE =\n  new InjectionToken<string>('IntlDateTimezone');\n\nexport const INTL_DATE_PRESET_SHORT: IntlDateOptions =\n  { dateStyle: 'short', timeStyle: 'short' };\nexport const INTL_DATE_PRESET_MEDIUM: IntlDateOptions =\n  { dateStyle: 'medium', timeStyle: 'medium' };\nexport const INTL_DATE_PRESET_LONG: IntlDateOptions =\n  { dateStyle: 'long', timeStyle: 'long' };\nexport const INTL_DATE_PRESET_FULL: IntlDateOptions =\n  { year: 'numeric', month: 'long', day: 'numeric', weekday: 'long', hour: 'numeric', minute: 'numeric', second: 'numeric', timeZoneName: 'long' };\nexport const INTL_DATE_PRESET_SHORT_DATE: IntlDateOptions =\n  { dateStyle: 'short' };\nexport const INTL_DATE_PRESET_MEDIUM_DATE: IntlDateOptions =\n  { dateStyle: 'medium' };\nexport const INTL_DATE_PRESET_LONG_DATE: IntlDateOptions =\n  { dateStyle: 'long' };\nexport const INTL_DATE_PRESET_FULL_DATE: IntlDateOptions =\n  { year: 'numeric', month: 'long', day: 'numeric', weekday: 'long' };\nexport const INTL_DATE_PRESET_SHORT_TIME: IntlDateOptions =\n  { timeStyle: 'short' };\nexport const INTL_DATE_PRESET_MEDIUM_TIME: IntlDateOptions =\n  { timeStyle: 'medium' };\nexport const INTL_DATE_PRESET_LONG_TIME: IntlDateOptions =\n  { timeStyle: 'long' };\nexport const INTL_DATE_PRESET_FULL_TIME: IntlDateOptions =\n  { hour: 'numeric', minute: 'numeric', second: 'numeric', timeZoneName: 'long' };\n\n/**\n * A pipe that formats a date using the Intl.DateTimeFormat API.\n */\n@Pipe({\n  name: 'intlDate',\n  standalone: true\n})\nexport class IntlDatePipe implements PipeTransform {\n  private static readonly DEFAULT_OPTIONS: IntlDateGlobalOptions = {\n    presets: {\n      short: INTL_DATE_PRESET_SHORT,\n      medium: INTL_DATE_PRESET_MEDIUM,\n      long: INTL_DATE_PRESET_LONG,\n      full: INTL_DATE_PRESET_FULL,\n      shortDate: INTL_DATE_PRESET_SHORT_DATE,\n      mediumDate: INTL_DATE_PRESET_MEDIUM_DATE,\n      longDate: INTL_DATE_PRESET_LONG_DATE,\n      fullDate: INTL_DATE_PRESET_FULL_DATE,\n      shortTime: INTL_DATE_PRESET_SHORT_TIME,\n      mediumTime: INTL_DATE_PRESET_MEDIUM_TIME,\n      longTime: INTL_DATE_PRESET_LONG_TIME,\n      fullTime: INTL_DATE_PRESET_FULL_TIME\n    }\n  };\n\n  constructor(\n    @Inject(LOCALE_ID) private readonly locale: string,\n    @Inject(INTL_DATE_OPTIONS) @Optional() private readonly options: IntlDateGlobalOptions | null,\n    @Inject(INTL_DATE_TIMEZONE) @Optional() private readonly timezone: string | null\n  ) {}\n\n  transform(value?: Date | string | number | null, options?: string | IntlDateLocalOptions, ...locales: string[]): string | null {\n    if (value === null) {\n      return null;\n    }\n\n    const _locales = this.getLocales(locales);\n    const _options = this.getOptions(options);\n    const formatValue = typeof value === 'string' ? new Date(value) : value;\n    return new Intl.DateTimeFormat(_locales, _options).format(formatValue);\n  }\n\n  private getLocales(locales: string[]): string[] {\n    return [...locales, this.locale];\n  }\n\n  private getOptions(options?: string | IntlDateLocalOptions): IntlDateOptions {\n    const presetStr = typeof options === 'string';\n    const presetKey = !presetStr\n      ? options?.preset || this.options?.defaultPreset || IntlDatePipe.DEFAULT_OPTIONS.defaultPreset\n      : options;\n    const preset = presetKey\n      ? (this.options?.presets?.[presetKey] || IntlDatePipe.DEFAULT_OPTIONS.presets?.[presetKey])\n      : undefined;\n    const timezone = this.timezone ? { timeZone: this.timezone } : {};\n    return {...timezone, ...preset, ...(!presetStr ? options : undefined)};\n  }\n}\n"]}