UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

115 lines 14.5 kB
/** * @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":"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","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"]}