@alauda-fe/common
Version:
Alauda frontend team common codes.
115 lines • 14.5 kB
JavaScript
/**
* @packageDocumentation
* @module utils
*/
import { ChangeDetectorRef, Injectable, Pipe, } from '@angular/core';
import dayjs from 'dayjs';
import { Subject, takeUntil } from 'rxjs';
import { TranslateService } from '../../translate/public-api';
import { DATE_FORMAT, DATE_TIME_FORMAT } from '../constants/public-api';
import { TimeService } from '../services/public-api';
import { FIELD_NOT_AVAILABLE_PLACEHOLDER, isFieldNotAvailable, } from './field-not-available.pipe';
import * as i0 from "@angular/core";
import * as i1 from "../services/public-api";
import * as i2 from "../../translate/public-api";
const MILLISECONDS_SECOND = 1000;
const MILLISECONDS_MINUTE = MILLISECONDS_SECOND * 60;
const MILLISECONDS_HOUR = MILLISECONDS_MINUTE * 60;
const MILLISECONDS_DAY = MILLISECONDS_HOUR * 24;
const MILLISECONDS_WEEK = MILLISECONDS_DAY * 7;
export class RelativeTimePipe {
constructor(cdr, time, translate) {
this.cdr = cdr;
this.time = time;
this.translate = translate;
this.destroy$$ = new Subject();
this.translate.locale$
.pipe(takeUntil(this.destroy$$))
.subscribe(() => this.cdr.markForCheck());
}
ngOnDestroy() {
this.destroy$$.next();
this.destroy$$.complete();
if (this.timerId) {
clearTimeout(this.timerId);
}
}
transform(value) {
if (isFieldNotAvailable(value)) {
return FIELD_NOT_AVAILABLE_PLACEHOLDER;
}
const currentTime = Date.now();
const givenTime = dayjs(value).valueOf();
const distance = currentTime - givenTime;
if (distance >= MILLISECONDS_WEEK) {
return this.time.format(value, DATE_FORMAT);
}
this.checkDistance(distance);
return distance < MILLISECONDS_MINUTE
? this.translate.get('just_now')
: this.time.distance(givenTime, currentTime);
}
checkDistance(distance) {
if (distance < MILLISECONDS_MINUTE) {
return this.startTimer(MILLISECONDS_SECOND);
}
if (distance < MILLISECONDS_HOUR) {
return this.startTimer(MILLISECONDS_MINUTE);
}
if (distance < MILLISECONDS_DAY) {
return this.startTimer(MILLISECONDS_HOUR);
}
return this.startTimer(MILLISECONDS_DAY);
}
startTimer(timeout) {
clearTimeout(this.timerId);
this.timerId = window.setTimeout(() => this.cdr.markForCheck(), timeout);
}
static { this.ɵfac = function RelativeTimePipe_Factory(t) { return new (t || RelativeTimePipe)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef, 16), i0.ɵɵdirectiveInject(i1.TimeService, 16), i0.ɵɵdirectiveInject(i2.TranslateService, 16)); }; }
static { this.ɵpipe = /*@__PURE__*/ i0.ɵɵdefinePipe({ name: "aclRelativeTime", type: RelativeTimePipe, pure: false, standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RelativeTimePipe, [{
type: Pipe,
args: [{ name: 'aclRelativeTime', pure: false, standalone: true }]
}], () => [{ type: i0.ChangeDetectorRef }, { type: i1.TimeService }, { type: i2.TranslateService }], null); })();
export class DateTimePipe {
constructor(time) {
this.time = time;
}
transform(value, utc = false) {
if (!value?.toString().trim()) {
return FIELD_NOT_AVAILABLE_PLACEHOLDER;
}
return this.time.format(utc ? dayjs.utc(value) : value, this.format);
}
static { this.ɵfac = function DateTimePipe_Factory(t) { return new (t || DateTimePipe)(i0.ɵɵinject(i1.TimeService)); }; }
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: DateTimePipe, factory: DateTimePipe.ɵfac }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DateTimePipe, [{
type: Injectable
}], () => [{ type: i1.TimeService }], null); })();
export class StandardTimePipe extends DateTimePipe {
constructor() {
super(...arguments);
this.format = DATE_TIME_FORMAT;
}
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵStandardTimePipe_BaseFactory; return function StandardTimePipe_Factory(t) { return (ɵStandardTimePipe_BaseFactory || (ɵStandardTimePipe_BaseFactory = i0.ɵɵgetInheritedFactory(StandardTimePipe)))(t || StandardTimePipe); }; })(); }
static { this.ɵpipe = /*@__PURE__*/ i0.ɵɵdefinePipe({ name: "aclStandardTime", type: StandardTimePipe, pure: true, standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(StandardTimePipe, [{
type: Pipe,
args: [{ name: 'aclStandardTime', standalone: true }]
}], null, null); })();
export class StandardDatePipe extends DateTimePipe {
constructor() {
super(...arguments);
this.format = DATE_FORMAT;
}
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵStandardDatePipe_BaseFactory; return function StandardDatePipe_Factory(t) { return (ɵStandardDatePipe_BaseFactory || (ɵStandardDatePipe_BaseFactory = i0.ɵɵgetInheritedFactory(StandardDatePipe)))(t || StandardDatePipe); }; })(); }
static { this.ɵpipe = /*@__PURE__*/ i0.ɵɵdefinePipe({ name: "aclStandardDate", type: StandardDatePipe, pure: true, standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(StandardDatePipe, [{
type: Pipe,
args: [{ name: 'aclStandardDate', standalone: true }]
}], null, null); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.pipe.js","sourceRoot":"","sources":["../../../../../../libs/common/src/core/pipes/time.pipe.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACL,iBAAiB,EACjB,UAAU,EAEV,IAAI,GAEL,MAAM,eAAe,CAAC;AACvB,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EACL,+BAA+B,EAC/B,mBAAmB,GACpB,MAAM,4BAA4B,CAAC;;;;AAEpC,MAAM,mBAAmB,GAAG,IAAI,CAAC;AACjC,MAAM,mBAAmB,GAAG,mBAAmB,GAAG,EAAE,CAAC;AACrD,MAAM,iBAAiB,GAAG,mBAAmB,GAAG,EAAE,CAAC;AACnD,MAAM,gBAAgB,GAAG,iBAAiB,GAAG,EAAE,CAAC;AAChD,MAAM,iBAAiB,GAAG,gBAAgB,GAAG,CAAC,CAAC;AAG/C,MAAM,OAAO,gBAAgB;IAK3B,YACmB,GAAsB,EACtB,IAAiB,EACjB,SAA2B;QAF3B,QAAG,GAAH,GAAG,CAAmB;QACtB,SAAI,GAAJ,IAAI,CAAa;QACjB,cAAS,GAAT,SAAS,CAAkB;QAP7B,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAS/C,IAAI,CAAC,SAAS,CAAC,OAAO;aACnB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAiB;QACzB,IAAI,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/B,OAAO,+BAA+B,CAAC;QACzC,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;QAEzC,MAAM,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAC;QAEzC,IAAI,QAAQ,IAAI,iBAAiB,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAE7B,OAAO,QAAQ,GAAG,mBAAmB;YACnC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC;YAChC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IACjD,CAAC;IAES,aAAa,CAAC,QAAgB;QACtC,IAAI,QAAQ,GAAG,mBAAmB,EAAE,CAAC;YACnC,OAAO,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,QAAQ,GAAG,iBAAiB,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,QAAQ,GAAG,gBAAgB,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;QAC5C,CAAC;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;IAC3C,CAAC;IAEO,UAAU,CAAC,OAAe;QAChC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,OAAO,CAAC,CAAC;IAC3E,CAAC;iFAhEU,gBAAgB;yFAAhB,gBAAgB;;iFAAhB,gBAAgB;cAD5B,IAAI;eAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE;;AAqEhE,MAAM,OAAgB,YAAY;IAGhC,YAA6B,IAAiB;QAAjB,SAAI,GAAJ,IAAI,CAAa;IAAG,CAAC;IAElD,SAAS,CAAC,KAAiB,EAAE,GAAG,GAAG,KAAK;QACtC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC;YAC9B,OAAO,+BAA+B,CAAC;QACzC,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACvE,CAAC;6EAXmB,YAAY;uEAAZ,YAAY,WAAZ,YAAY;;iFAAZ,YAAY;cADjC,UAAU;;AAgBX,MAAM,OAAO,gBAAiB,SAAQ,YAAY;IADlD;;QAEW,WAAM,GAAG,gBAAgB,CAAC;KACpC;oOAFY,gBAAgB,SAAhB,gBAAgB;yFAAhB,gBAAgB;;iFAAhB,gBAAgB;cAD5B,IAAI;eAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,UAAU,EAAE,IAAI,EAAE;;AAMnD,MAAM,OAAO,gBAAiB,SAAQ,YAAY;IADlD;;QAEW,WAAM,GAAG,WAAW,CAAC;KAC/B;oOAFY,gBAAgB,SAAhB,gBAAgB;yFAAhB,gBAAgB;;iFAAhB,gBAAgB;cAD5B,IAAI;eAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,UAAU,EAAE,IAAI,EAAE","sourcesContent":["/**\n * @packageDocumentation\n * @module utils\n */\n\nimport {\n  ChangeDetectorRef,\n  Injectable,\n  OnDestroy,\n  Pipe,\n  PipeTransform,\n} from '@angular/core';\nimport dayjs, { ConfigType } from 'dayjs';\nimport { Subject, takeUntil } from 'rxjs';\n\nimport { TranslateService } from '../../translate/public-api';\nimport { DATE_FORMAT, DATE_TIME_FORMAT } from '../constants/public-api';\nimport { TimeService } from '../services/public-api';\n\nimport {\n  FIELD_NOT_AVAILABLE_PLACEHOLDER,\n  isFieldNotAvailable,\n} from './field-not-available.pipe';\n\nconst MILLISECONDS_SECOND = 1000;\nconst MILLISECONDS_MINUTE = MILLISECONDS_SECOND * 60;\nconst MILLISECONDS_HOUR = MILLISECONDS_MINUTE * 60;\nconst MILLISECONDS_DAY = MILLISECONDS_HOUR * 24;\nconst MILLISECONDS_WEEK = MILLISECONDS_DAY * 7;\n\n@Pipe({ name: 'aclRelativeTime', pure: false, standalone: true })\nexport class RelativeTimePipe implements PipeTransform, OnDestroy {\n  private readonly destroy$$ = new Subject<void>();\n\n  private timerId: number;\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    private readonly time: TimeService,\n    private readonly translate: TranslateService,\n  ) {\n    this.translate.locale$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => this.cdr.markForCheck());\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n\n    if (this.timerId) {\n      clearTimeout(this.timerId);\n    }\n  }\n\n  transform(value: ConfigType) {\n    if (isFieldNotAvailable(value)) {\n      return FIELD_NOT_AVAILABLE_PLACEHOLDER;\n    }\n\n    const currentTime = Date.now();\n    const givenTime = dayjs(value).valueOf();\n\n    const distance = currentTime - givenTime;\n\n    if (distance >= MILLISECONDS_WEEK) {\n      return this.time.format(value, DATE_FORMAT);\n    }\n\n    this.checkDistance(distance);\n\n    return distance < MILLISECONDS_MINUTE\n      ? this.translate.get('just_now')\n      : this.time.distance(givenTime, currentTime);\n  }\n\n  protected checkDistance(distance: number) {\n    if (distance < MILLISECONDS_MINUTE) {\n      return this.startTimer(MILLISECONDS_SECOND);\n    }\n\n    if (distance < MILLISECONDS_HOUR) {\n      return this.startTimer(MILLISECONDS_MINUTE);\n    }\n\n    if (distance < MILLISECONDS_DAY) {\n      return this.startTimer(MILLISECONDS_HOUR);\n    }\n\n    return this.startTimer(MILLISECONDS_DAY);\n  }\n\n  private startTimer(timeout: number) {\n    clearTimeout(this.timerId);\n    this.timerId = window.setTimeout(() => this.cdr.markForCheck(), timeout);\n  }\n}\n\n@Injectable()\nexport abstract class DateTimePipe implements PipeTransform {\n  abstract format: string;\n\n  constructor(private readonly time: TimeService) {}\n\n  transform(value: ConfigType, utc = false) {\n    if (!value?.toString().trim()) {\n      return FIELD_NOT_AVAILABLE_PLACEHOLDER;\n    }\n\n    return this.time.format(utc ? dayjs.utc(value) : value, this.format);\n  }\n}\n\n@Pipe({ name: 'aclStandardTime', standalone: true })\nexport class StandardTimePipe extends DateTimePipe implements PipeTransform {\n  override format = DATE_TIME_FORMAT;\n}\n\n@Pipe({ name: 'aclStandardDate', standalone: true })\nexport class StandardDatePipe extends DateTimePipe implements PipeTransform {\n  override format = DATE_FORMAT;\n}\n"]}