UNPKG

ng-zorro-antd-yj

Version:

An enterprise-class UI components based on Ant Design and Angular

283 lines 20.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { DatePipe } from '@angular/common'; import { Inject, Injectable, Injector, Optional } from '@angular/core'; import fnsFormat from 'date-fns/format'; import fnsGetISOWeek from 'date-fns/get_iso_week'; import fnsParse from 'date-fns/parse'; import { mergeDateConfig, NZ_DATE_CONFIG } from './date-config'; import { NzI18nService } from './nz-i18n.service'; import * as i0 from "@angular/core"; import * as i1 from "./public-api"; import * as i2 from "@angular/common"; /** * @param {?} injector * @param {?} config * @param {?} datePipe * @return {?} */ export function DATE_HELPER_SERVICE_FACTORY(injector, config, datePipe) { /** @type {?} */ var i18n = injector.get(NzI18nService); return i18n.getDateLocale() ? new DateHelperByDateFns(i18n, config) : new DateHelperByDatePipe(i18n, config, datePipe); } /** * Abstract DateHelperService(Token via Class) * Compatibility: compact for original usage by default which using DatePipe * @abstract */ var DateHelperService = /** @class */ (function () { function DateHelperService(i18n, config) { this.i18n = i18n; this.config = config; this.relyOnDatePipe = this instanceof DateHelperByDatePipe; // Indicate whether this service is rely on DatePipe this.config = mergeDateConfig(this.config); } /** * @param {?} text * @return {?} */ DateHelperService.prototype.parseDate = /** * @param {?} text * @return {?} */ function (text) { if (!text) { return; } return fnsParse(text); }; /** * @param {?} text * @return {?} */ DateHelperService.prototype.parseTime = /** * @param {?} text * @return {?} */ function (text) { if (!text) { return; } return fnsParse("1970-01-01 " + text); }; DateHelperService.decorators = [ { type: Injectable, args: [{ providedIn: 'root', useFactory: DATE_HELPER_SERVICE_FACTORY, deps: [Injector, [new Optional(), NZ_DATE_CONFIG], DatePipe] },] } ]; /** @nocollapse */ DateHelperService.ctorParameters = function () { return [ { type: NzI18nService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_DATE_CONFIG,] }] } ]; }; /** @nocollapse */ DateHelperService.ngInjectableDef = i0.defineInjectable({ factory: function DateHelperService_Factory() { return DATE_HELPER_SERVICE_FACTORY(i0.inject(i0.INJECTOR), i0.inject(i1.NZ_DATE_CONFIG, 8), i0.inject(i2.DatePipe)); }, token: i1.DateHelperService, providedIn: "root" }); return DateHelperService; }()); export { DateHelperService }; if (false) { /** @type {?} */ DateHelperService.prototype.relyOnDatePipe; /** * @type {?} * @protected */ DateHelperService.prototype.i18n; /** * @type {?} * @protected */ DateHelperService.prototype.config; /** * @abstract * @param {?} date * @return {?} */ DateHelperService.prototype.getISOWeek = function (date) { }; /** * @abstract * @return {?} */ DateHelperService.prototype.getFirstDayOfWeek = function () { }; /** * @abstract * @param {?} date * @param {?} formatStr * @return {?} */ DateHelperService.prototype.format = function (date, formatStr) { }; } /** * DateHelper that handles date formats with date-fns */ var DateHelperByDateFns = /** @class */ (function (_super) { tslib_1.__extends(DateHelperByDateFns, _super); function DateHelperByDateFns() { return _super !== null && _super.apply(this, arguments) || this; } /** * @param {?} date * @return {?} */ DateHelperByDateFns.prototype.getISOWeek = /** * @param {?} date * @return {?} */ function (date) { return fnsGetISOWeek(date); }; // TODO: Use date-fns's "weekStartsOn" to support different locale when "config.firstDayOfWeek" is null // when v2.0 is ready: https://github.com/date-fns/date-fns/blob/v2.0.0-alpha.27/src/locale/en-US/index.js#L23 // TODO: Use date-fns's "weekStartsOn" to support different locale when "config.firstDayOfWeek" is null // when v2.0 is ready: https://github.com/date-fns/date-fns/blob/v2.0.0-alpha.27/src/locale/en-US/index.js#L23 /** * @return {?} */ DateHelperByDateFns.prototype.getFirstDayOfWeek = // TODO: Use date-fns's "weekStartsOn" to support different locale when "config.firstDayOfWeek" is null // when v2.0 is ready: https://github.com/date-fns/date-fns/blob/v2.0.0-alpha.27/src/locale/en-US/index.js#L23 /** * @return {?} */ function () { return this.config.firstDayOfWeek == null ? 1 : this.config.firstDayOfWeek; }; /** * Format a date * @see https://date-fns.org/docs/format#description * @param date Date * @param formatStr format string */ /** * Format a date * @see https://date-fns.org/docs/format#description * @param {?} date Date * @param {?} formatStr format string * @return {?} */ DateHelperByDateFns.prototype.format = /** * Format a date * @see https://date-fns.org/docs/format#description * @param {?} date Date * @param {?} formatStr format string * @return {?} */ function (date, formatStr) { return fnsFormat(date, formatStr, { locale: this.i18n.getDateLocale() }); }; /** @nocollapse */ DateHelperByDateFns.ngInjectableDef = i0.defineInjectable({ factory: function DateHelperByDateFns_Factory() { return DATE_HELPER_SERVICE_FACTORY(i0.inject(i0.INJECTOR), i0.inject(i1.NZ_DATE_CONFIG, 8), i0.inject(i2.DatePipe)); }, token: DateHelperByDateFns, providedIn: "root" }); return DateHelperByDateFns; }(DateHelperService)); export { DateHelperByDateFns }; /** * DateHelper that handles date formats with angular's date-pipe * [BUG] Use DatePipe may cause non-standard week bug, see: https://github.com/NG-ZORRO/ng-zorro-antd/issues/2406 * * @deprecated Maybe removed in next major version due to this serious bug */ var DateHelperByDatePipe = /** @class */ (function (_super) { tslib_1.__extends(DateHelperByDatePipe, _super); function DateHelperByDatePipe(i18n, config, datePipe) { var _this = _super.call(this, i18n, config) || this; _this.datePipe = datePipe; return _this; } /** * @param {?} date * @return {?} */ DateHelperByDatePipe.prototype.getISOWeek = /** * @param {?} date * @return {?} */ function (date) { return +this.format(date, 'w'); }; /** * @return {?} */ DateHelperByDatePipe.prototype.getFirstDayOfWeek = /** * @return {?} */ function () { if (this.config.firstDayOfWeek === undefined) { /** @type {?} */ var locale = this.i18n.getLocaleId(); return locale && ['zh-cn', 'zh-tw'].indexOf(locale.toLowerCase()) > -1 ? 1 : 0; } return this.config.firstDayOfWeek; }; /** * @param {?} date * @param {?} formatStr * @return {?} */ DateHelperByDatePipe.prototype.format = /** * @param {?} date * @param {?} formatStr * @return {?} */ function (date, formatStr) { return date ? (/** @type {?} */ (this.datePipe.transform(date, formatStr, undefined, this.i18n.getLocaleId()))) : ''; }; /** * Compatible translate the moment-like format pattern to angular's pattern * Why? For now, we need to support the existing language formats in AntD, and AntD uses the default temporal syntax. * * TODO: compare and complete all format patterns * Each format docs as below: * @link https://momentjs.com/docs/#/displaying/format/ * @link https://angular.io/api/common/DatePipe#description * @param format input format pattern */ /** * Compatible translate the moment-like format pattern to angular's pattern * Why? For now, we need to support the existing language formats in AntD, and AntD uses the default temporal syntax. * * TODO: compare and complete all format patterns * Each format docs as below: * @link https://momentjs.com/docs/#/displaying/format/ / https://angular.io/api/common/DatePipe#description * @param {?} format input format pattern * @return {?} */ DateHelperByDatePipe.prototype.transCompatFormat = /** * Compatible translate the moment-like format pattern to angular's pattern * Why? For now, we need to support the existing language formats in AntD, and AntD uses the default temporal syntax. * * TODO: compare and complete all format patterns * Each format docs as below: * @link https://momentjs.com/docs/#/displaying/format/ / https://angular.io/api/common/DatePipe#description * @param {?} format input format pattern * @return {?} */ function (format) { return (format && format .replace(/Y/g, 'y') // only support y, yy, yyy, yyyy .replace(/D/g, 'd')); // d, dd represent of D, DD for momentjs, others are not support }; /** @nocollapse */ DateHelperByDatePipe.ctorParameters = function () { return [ { type: NzI18nService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NZ_DATE_CONFIG,] }] }, { type: DatePipe } ]; }; /** @nocollapse */ DateHelperByDatePipe.ngInjectableDef = i0.defineInjectable({ factory: function DateHelperByDatePipe_Factory() { return DATE_HELPER_SERVICE_FACTORY(i0.inject(i0.INJECTOR), i0.inject(i1.NZ_DATE_CONFIG, 8), i0.inject(i2.DatePipe)); }, token: DateHelperByDatePipe, providedIn: "root" }); return DateHelperByDatePipe; }(DateHelperService)); export { DateHelperByDatePipe }; if (false) { /** * @type {?} * @private */ DateHelperByDatePipe.prototype.datePipe; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-helper.service.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["i18n/date-helper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Inject, Injectable, Injector, Optional } from '@angular/core';\nimport fnsFormat from 'date-fns/format';\nimport fnsGetISOWeek from 'date-fns/get_iso_week';\nimport fnsParse from 'date-fns/parse';\nimport { mergeDateConfig, NzDateConfig, NZ_DATE_CONFIG } from './date-config';\nimport { NzI18nService } from './nz-i18n.service';\n\nexport function DATE_HELPER_SERVICE_FACTORY(\n  injector: Injector,\n  config: NzDateConfig,\n  datePipe: DatePipe\n): DateHelperService {\n  const i18n = injector.get(NzI18nService);\n  return i18n.getDateLocale()\n    ? new DateHelperByDateFns(i18n, config)\n    : new DateHelperByDatePipe(i18n, config, datePipe);\n}\n\n/**\n * Abstract DateHelperService(Token via Class)\n * Compatibility: compact for original usage by default which using DatePipe\n */\n@Injectable({\n  providedIn: 'root',\n  useFactory: DATE_HELPER_SERVICE_FACTORY,\n  deps: [Injector, [new Optional(), NZ_DATE_CONFIG], DatePipe]\n})\nexport abstract class DateHelperService {\n  relyOnDatePipe: boolean = this instanceof DateHelperByDatePipe; // Indicate whether this service is rely on DatePipe\n\n  constructor(protected i18n: NzI18nService, @Optional() @Inject(NZ_DATE_CONFIG) protected config: NzDateConfig) {\n    this.config = mergeDateConfig(this.config);\n  }\n\n  abstract getISOWeek(date: Date): number;\n  abstract getFirstDayOfWeek(): WeekDayIndex;\n  abstract format(date: Date, formatStr: string): string;\n\n  parseDate(text: string): Date | undefined {\n    if (!text) {\n      return;\n    }\n    return fnsParse(text);\n  }\n\n  parseTime(text: string): Date | undefined {\n    if (!text) {\n      return;\n    }\n    return fnsParse(`1970-01-01 ${text}`);\n  }\n}\n\n/**\n * DateHelper that handles date formats with date-fns\n */\nexport class DateHelperByDateFns extends DateHelperService {\n  getISOWeek(date: Date): number {\n    return fnsGetISOWeek(date);\n  }\n\n  // TODO: Use date-fns's \"weekStartsOn\" to support different locale when \"config.firstDayOfWeek\" is null\n  // when v2.0 is ready: https://github.com/date-fns/date-fns/blob/v2.0.0-alpha.27/src/locale/en-US/index.js#L23\n  getFirstDayOfWeek(): 0 | 1 | 2 | 3 | 4 | 5 | 6 {\n    return this.config.firstDayOfWeek == null ? 1 : this.config.firstDayOfWeek;\n  }\n\n  /**\n   * Format a date\n   * @see https://date-fns.org/docs/format#description\n   * @param date Date\n   * @param formatStr format string\n   */\n  format(date: Date, formatStr: string): string {\n    return fnsFormat(date, formatStr, { locale: this.i18n.getDateLocale() });\n  }\n}\n\n/**\n * DateHelper that handles date formats with angular's date-pipe\n * [BUG] Use DatePipe may cause non-standard week bug, see: https://github.com/NG-ZORRO/ng-zorro-antd/issues/2406\n *\n * @deprecated Maybe removed in next major version due to this serious bug\n */\nexport class DateHelperByDatePipe extends DateHelperService {\n  constructor(\n    i18n: NzI18nService,\n    @Optional() @Inject(NZ_DATE_CONFIG) config: NzDateConfig,\n    private datePipe: DatePipe\n  ) {\n    super(i18n, config);\n  }\n\n  getISOWeek(date: Date): number {\n    return +this.format(date, 'w');\n  }\n\n  getFirstDayOfWeek(): WeekDayIndex {\n    if (this.config.firstDayOfWeek === undefined) {\n      const locale = this.i18n.getLocaleId();\n      return locale && ['zh-cn', 'zh-tw'].indexOf(locale.toLowerCase()) > -1 ? 1 : 0;\n    }\n    return this.config.firstDayOfWeek;\n  }\n\n  format(date: Date, formatStr: string): string {\n    return date ? this.datePipe.transform(date, formatStr, undefined, this.i18n.getLocaleId())! : '';\n  }\n\n  /**\n   * Compatible translate the moment-like format pattern to angular's pattern\n   * Why? For now, we need to support the existing language formats in AntD, and AntD uses the default temporal syntax.\n   *\n   * TODO: compare and complete all format patterns\n   * Each format docs as below:\n   * @link https://momentjs.com/docs/#/displaying/format/\n   * @link https://angular.io/api/common/DatePipe#description\n   * @param format input format pattern\n   */\n  transCompatFormat(format: string): string {\n    return (\n      format &&\n      format\n        .replace(/Y/g, 'y') // only support y, yy, yyy, yyyy\n        .replace(/D/g, 'd')\n    ); // d, dd represent of D, DD for momentjs, others are not support\n  }\n}\n\n////////////\n\nexport type WeekDayIndex = 0 | 1 | 2 | 3 | 4 | 5 | 6;\n"]}