UNPKG

ng-zorro-antd

Version:

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

210 lines 23.3 kB
import { NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, Component, ContentChildren, Input, ViewEncapsulation, booleanAttribute } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { NzOutletModule } from 'ng-zorro-antd/core/outlet'; import { NzIconModule } from 'ng-zorro-antd/icon'; import { NzTimelineItemComponent } from './timeline-item.component'; import { TimelineService } from './timeline.service'; import * as i0 from "@angular/core"; import * as i1 from "./timeline.service"; import * as i2 from "@angular/cdk/bidi"; import * as i3 from "ng-zorro-antd/core/outlet"; import * as i4 from "ng-zorro-antd/icon"; export class NzTimelineComponent { constructor(cdr, timelineService, directionality) { this.cdr = cdr; this.timelineService = timelineService; this.directionality = directionality; this.nzMode = 'left'; this.nzReverse = false; this.isPendingBoolean = false; this.timelineItems = []; this.dir = 'ltr'; this.hasLabelItem = false; this.destroy$ = new Subject(); } ngOnChanges(changes) { const { nzMode, nzReverse, nzPending } = changes; if (simpleChangeActivated(nzMode) || simpleChangeActivated(nzReverse)) { this.updateChildren(); } if (nzPending) { this.isPendingBoolean = nzPending.currentValue === true; } } ngOnInit() { this.timelineService.check$.pipe(takeUntil(this.destroy$)).subscribe(() => { this.cdr.markForCheck(); }); this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction) => { this.dir = direction; this.cdr.detectChanges(); }); this.dir = this.directionality.value; } ngAfterContentInit() { this.updateChildren(); this.listOfItems.changes.pipe(takeUntil(this.destroy$)).subscribe(() => { this.updateChildren(); }); } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } updateChildren() { if (this.listOfItems && this.listOfItems.length) { const length = this.listOfItems.length; let hasLabelItem = false; this.listOfItems.forEach((item, index) => { item.isLast = !this.nzReverse ? index === length - 1 : index === 0; item.position = getInferredTimelineItemPosition(index, this.nzMode); if (!hasLabelItem && item.nzLabel) { hasLabelItem = true; } item.detectChanges(); }); this.timelineItems = this.nzReverse ? this.listOfItems.toArray().reverse() : this.listOfItems.toArray(); this.hasLabelItem = hasLabelItem; } else { this.timelineItems = []; this.hasLabelItem = false; } this.cdr.markForCheck(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzTimelineComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TimelineService }, { token: i2.Directionality }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzTimelineComponent, isStandalone: true, selector: "nz-timeline", inputs: { nzMode: "nzMode", nzPending: "nzPending", nzPendingDot: "nzPendingDot", nzReverse: ["nzReverse", "nzReverse", booleanAttribute] }, providers: [TimelineService], queries: [{ propertyName: "listOfItems", predicate: NzTimelineItemComponent }], exportAs: ["nzTimeline"], usesOnChanges: true, ngImport: i0, template: ` <ul class="ant-timeline" [class.ant-timeline-label]="hasLabelItem" [class.ant-timeline-right]="!hasLabelItem && nzMode === 'right'" [class.ant-timeline-alternate]="nzMode === 'alternate' || nzMode === 'custom'" [class.ant-timeline-pending]="!!nzPending" [class.ant-timeline-reverse]="nzReverse" [class.ant-timeline-rtl]="dir === 'rtl'" > <!-- pending dot (reversed) --> @if (nzReverse) { <ng-container [ngTemplateOutlet]="pendingTemplate"></ng-container> } <!-- timeline items --> @for (item of timelineItems; track item) { <ng-template [ngTemplateOutlet]="item.template"></ng-template> } @if (!nzReverse) { <ng-container [ngTemplateOutlet]="pendingTemplate"></ng-container> } <!-- pending dot --> </ul> <ng-template #pendingTemplate> @if (nzPending) { <li class="ant-timeline-item ant-timeline-item-pending"> <div class="ant-timeline-item-tail"></div> <div class="ant-timeline-item-head ant-timeline-item-head-custom ant-timeline-item-head-blue"> <ng-container *nzStringTemplateOutlet="nzPendingDot"> {{ nzPendingDot }} @if (!nzPendingDot) { <span nz-icon nzType="loading"></span> } </ng-container> </div> <div class="ant-timeline-item-content"> <ng-container *nzStringTemplateOutlet="nzPending"> {{ isPendingBoolean ? '' : nzPending }} </ng-container> </div> </li> } </ng-template> <!-- Grasp items --> <ng-content></ng-content> `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: NzOutletModule }, { kind: "directive", type: i3.NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }, { kind: "ngmodule", type: NzIconModule }, { kind: "directive", type: i4.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzTimelineComponent, decorators: [{ type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, selector: 'nz-timeline', providers: [TimelineService], exportAs: 'nzTimeline', template: ` <ul class="ant-timeline" [class.ant-timeline-label]="hasLabelItem" [class.ant-timeline-right]="!hasLabelItem && nzMode === 'right'" [class.ant-timeline-alternate]="nzMode === 'alternate' || nzMode === 'custom'" [class.ant-timeline-pending]="!!nzPending" [class.ant-timeline-reverse]="nzReverse" [class.ant-timeline-rtl]="dir === 'rtl'" > <!-- pending dot (reversed) --> @if (nzReverse) { <ng-container [ngTemplateOutlet]="pendingTemplate"></ng-container> } <!-- timeline items --> @for (item of timelineItems; track item) { <ng-template [ngTemplateOutlet]="item.template"></ng-template> } @if (!nzReverse) { <ng-container [ngTemplateOutlet]="pendingTemplate"></ng-container> } <!-- pending dot --> </ul> <ng-template #pendingTemplate> @if (nzPending) { <li class="ant-timeline-item ant-timeline-item-pending"> <div class="ant-timeline-item-tail"></div> <div class="ant-timeline-item-head ant-timeline-item-head-custom ant-timeline-item-head-blue"> <ng-container *nzStringTemplateOutlet="nzPendingDot"> {{ nzPendingDot }} @if (!nzPendingDot) { <span nz-icon nzType="loading"></span> } </ng-container> </div> <div class="ant-timeline-item-content"> <ng-container *nzStringTemplateOutlet="nzPending"> {{ isPendingBoolean ? '' : nzPending }} </ng-container> </div> </li> } </ng-template> <!-- Grasp items --> <ng-content></ng-content> `, imports: [NgTemplateOutlet, NzOutletModule, NzIconModule], standalone: true }] }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.TimelineService }, { type: i2.Directionality }], propDecorators: { listOfItems: [{ type: ContentChildren, args: [NzTimelineItemComponent] }], nzMode: [{ type: Input }], nzPending: [{ type: Input }], nzPendingDot: [{ type: Input }], nzReverse: [{ type: Input, args: [{ transform: booleanAttribute }] }] } }); function simpleChangeActivated(simpleChange) { return !!(simpleChange && (simpleChange.previousValue !== simpleChange.currentValue || simpleChange.isFirstChange())); } function getInferredTimelineItemPosition(index, mode) { return mode === 'custom' ? undefined : mode === 'left' ? 'left' : mode === 'right' ? 'right' : mode === 'alternate' && index % 2 === 0 ? 'left' : 'right'; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeline.component.js","sourceRoot":"","sources":["../../../components/timeline/timeline.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  SimpleChange,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation,\n  booleanAttribute\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\n\nimport { NzTimelineItemComponent } from './timeline-item.component';\nimport { TimelineService } from './timeline.service';\nimport { NzTimelineMode, NzTimelinePosition } from './typings';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  selector: 'nz-timeline',\n  providers: [TimelineService],\n  exportAs: 'nzTimeline',\n  template: `\n    <ul\n      class=\"ant-timeline\"\n      [class.ant-timeline-label]=\"hasLabelItem\"\n      [class.ant-timeline-right]=\"!hasLabelItem && nzMode === 'right'\"\n      [class.ant-timeline-alternate]=\"nzMode === 'alternate' || nzMode === 'custom'\"\n      [class.ant-timeline-pending]=\"!!nzPending\"\n      [class.ant-timeline-reverse]=\"nzReverse\"\n      [class.ant-timeline-rtl]=\"dir === 'rtl'\"\n    >\n      <!-- pending dot (reversed) -->\n      @if (nzReverse) {\n        <ng-container [ngTemplateOutlet]=\"pendingTemplate\"></ng-container>\n      }\n      <!-- timeline items -->\n      @for (item of timelineItems; track item) {\n        <ng-template [ngTemplateOutlet]=\"item.template\"></ng-template>\n      }\n      @if (!nzReverse) {\n        <ng-container [ngTemplateOutlet]=\"pendingTemplate\"></ng-container>\n      }\n      <!-- pending dot -->\n    </ul>\n    <ng-template #pendingTemplate>\n      @if (nzPending) {\n        <li class=\"ant-timeline-item ant-timeline-item-pending\">\n          <div class=\"ant-timeline-item-tail\"></div>\n          <div class=\"ant-timeline-item-head ant-timeline-item-head-custom ant-timeline-item-head-blue\">\n            <ng-container *nzStringTemplateOutlet=\"nzPendingDot\">\n              {{ nzPendingDot }}\n              @if (!nzPendingDot) {\n                <span nz-icon nzType=\"loading\"></span>\n              }\n            </ng-container>\n          </div>\n          <div class=\"ant-timeline-item-content\">\n            <ng-container *nzStringTemplateOutlet=\"nzPending\">\n              {{ isPendingBoolean ? '' : nzPending }}\n            </ng-container>\n          </div>\n        </li>\n      }\n    </ng-template>\n    <!-- Grasp items -->\n    <ng-content></ng-content>\n  `,\n  imports: [NgTemplateOutlet, NzOutletModule, NzIconModule],\n  standalone: true\n})\nexport class NzTimelineComponent implements AfterContentInit, OnChanges, OnDestroy, OnInit {\n  @ContentChildren(NzTimelineItemComponent) listOfItems!: QueryList<NzTimelineItemComponent>;\n\n  @Input() nzMode: NzTimelineMode = 'left';\n  @Input() nzPending?: string | boolean | TemplateRef<void>;\n  @Input() nzPendingDot?: string | TemplateRef<void>;\n  @Input({ transform: booleanAttribute }) nzReverse: boolean = false;\n\n  isPendingBoolean: boolean = false;\n  timelineItems: NzTimelineItemComponent[] = [];\n  dir: Direction = 'ltr';\n  hasLabelItem = false;\n\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private timelineService: TimelineService,\n    private directionality: Directionality\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzMode, nzReverse, nzPending } = changes;\n\n    if (simpleChangeActivated(nzMode) || simpleChangeActivated(nzReverse)) {\n      this.updateChildren();\n    }\n\n    if (nzPending) {\n      this.isPendingBoolean = nzPending.currentValue === true;\n    }\n  }\n\n  ngOnInit(): void {\n    this.timelineService.check$.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n\n    this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction: Direction) => {\n      this.dir = direction;\n      this.cdr.detectChanges();\n    });\n\n    this.dir = this.directionality.value;\n  }\n\n  ngAfterContentInit(): void {\n    this.updateChildren();\n\n    this.listOfItems.changes.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.updateChildren();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private updateChildren(): void {\n    if (this.listOfItems && this.listOfItems.length) {\n      const length = this.listOfItems.length;\n      let hasLabelItem = false;\n\n      this.listOfItems.forEach((item: NzTimelineItemComponent, index: number) => {\n        item.isLast = !this.nzReverse ? index === length - 1 : index === 0;\n        item.position = getInferredTimelineItemPosition(index, this.nzMode);\n\n        if (!hasLabelItem && item.nzLabel) {\n          hasLabelItem = true;\n        }\n\n        item.detectChanges();\n      });\n\n      this.timelineItems = this.nzReverse ? this.listOfItems.toArray().reverse() : this.listOfItems.toArray();\n      this.hasLabelItem = hasLabelItem;\n    } else {\n      this.timelineItems = [];\n      this.hasLabelItem = false;\n    }\n\n    this.cdr.markForCheck();\n  }\n}\n\nfunction simpleChangeActivated(simpleChange?: SimpleChange): boolean {\n  return !!(simpleChange && (simpleChange.previousValue !== simpleChange.currentValue || simpleChange.isFirstChange()));\n}\n\nfunction getInferredTimelineItemPosition(index: number, mode: NzTimelineMode): NzTimelinePosition | undefined {\n  return mode === 'custom'\n    ? undefined\n    : mode === 'left'\n      ? 'left'\n      : mode === 'right'\n        ? 'right'\n        : mode === 'alternate' && index % 2 === 0\n          ? 'left'\n          : 'right';\n}\n"]}