UNPKG

ng-zorro-antd

Version:

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

170 lines 15.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { Platform } from '@angular/cdk/platform'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, ElementRef, Input, QueryList, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { reverseChildNodes } from 'ng-zorro-antd/core'; import { NzTimelineItemComponent } from './nz-timeline-item.component'; export class NzTimelineComponent { /** * @param {?} cdr * @param {?} platform */ constructor(cdr, platform) { this.cdr = cdr; this.platform = platform; this.nzReverse = false; this.isPendingBoolean = false; this.destroy$ = new Subject(); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { /** @type {?} */ const modeChanges = changes.nzMode; /** @type {?} */ const reverseChanges = changes.nzReverse; /** @type {?} */ const pendingChanges = changes.nzPending; if (modeChanges && (modeChanges.previousValue !== modeChanges.currentValue || modeChanges.isFirstChange())) { this.updateChildren(); } if (reverseChanges && reverseChanges.previousValue !== reverseChanges.currentValue && !reverseChanges.isFirstChange()) { this.reverseChildTimelineDots(); } if (pendingChanges) { this.isPendingBoolean = pendingChanges.currentValue === true; } } /** * @return {?} */ ngAfterContentInit() { this.updateChildren(); if (this.listOfTimeLine) { this.listOfTimeLine.changes.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ () => { this.updateChildren(); })); } } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } /** * @private * @return {?} */ updateChildren() { if (this.listOfTimeLine && this.listOfTimeLine.length) { /** @type {?} */ const length = this.listOfTimeLine.length; this.listOfTimeLine.toArray().forEach((/** * @param {?} item * @param {?} index * @return {?} */ (item, index) => { item.isLast = !this.nzReverse ? index === length - 1 : index === 0; item.position = this.nzMode === 'left' || !this.nzMode ? undefined : this.nzMode === 'right' ? 'right' : this.nzMode === 'alternate' && index % 2 === 0 ? 'left' : 'right'; item.detectChanges(); })); this.cdr.markForCheck(); } } /** * @private * @return {?} */ reverseChildTimelineDots() { if (this.platform.isBrowser) { reverseChildNodes((/** @type {?} */ (this.timeline.nativeElement))); this.updateChildren(); } } } NzTimelineComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, selector: 'nz-timeline', exportAs: 'nzTimeline', template: "<ul\n class=\"ant-timeline\"\n [class.ant-timeline-right]=\"nzMode === 'right'\"\n [class.ant-timeline-alternate]=\"nzMode === 'alternate'\"\n [class.ant-timeline-pending]=\"!!nzPending\"\n [class.ant-timeline-reverse]=\"nzReverse\"\n #timeline>\n <!-- User inserted timeline dots. -->\n <ng-content></ng-content>\n <!-- Pending dot. -->\n <li *ngIf=\"nzPending\" 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 }}<i *ngIf=\"!nzPendingDot\" nz-icon nzType=\"loading\"></i>\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</ul>\n" }] } ]; /** @nocollapse */ NzTimelineComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: Platform } ]; NzTimelineComponent.propDecorators = { timeline: [{ type: ViewChild, args: ['timeline', { static: false },] }], listOfTimeLine: [{ type: ContentChildren, args: [NzTimelineItemComponent,] }], _pendingContent: [{ type: ContentChild, args: ['pending', { static: false },] }], nzMode: [{ type: Input }], nzPending: [{ type: Input }], nzPendingDot: [{ type: Input }], nzReverse: [{ type: Input }] }; if (false) { /** @type {?} */ NzTimelineComponent.prototype.timeline; /** @type {?} */ NzTimelineComponent.prototype.listOfTimeLine; /** @type {?} */ NzTimelineComponent.prototype._pendingContent; /** @type {?} */ NzTimelineComponent.prototype.nzMode; /** @type {?} */ NzTimelineComponent.prototype.nzPending; /** @type {?} */ NzTimelineComponent.prototype.nzPendingDot; /** @type {?} */ NzTimelineComponent.prototype.nzReverse; /** @type {?} */ NzTimelineComponent.prototype.isPendingBoolean; /** * @type {?} * @private */ NzTimelineComponent.prototype.destroy$; /** * @type {?} * @private */ NzTimelineComponent.prototype.cdr; /** * @type {?} * @private */ NzTimelineComponent.prototype.platform; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-timeline.component.js","sourceRoot":"ng://ng-zorro-antd/timeline/","sources":["nz-timeline.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\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 { Platform } from '@angular/cdk/platform';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { reverseChildNodes } from 'ng-zorro-antd/core';\n\nimport { NzTimelineItemComponent } from './nz-timeline-item.component';\n\nexport type NzTimelineMode = 'left' | 'alternate' | 'right';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  selector: 'nz-timeline',\n  exportAs: 'nzTimeline',\n  templateUrl: './nz-timeline.component.html'\n})\nexport class NzTimelineComponent implements AfterContentInit, OnChanges, OnDestroy {\n  @ViewChild('timeline', { static: false }) timeline: ElementRef<HTMLElement>;\n  @ContentChildren(NzTimelineItemComponent) listOfTimeLine: QueryList<NzTimelineItemComponent>;\n  @ContentChild('pending', { static: false }) _pendingContent: TemplateRef<void>;\n\n  @Input() nzMode: NzTimelineMode;\n  @Input() nzPending: string | boolean | TemplateRef<void>;\n  @Input() nzPendingDot: string | TemplateRef<void>;\n  @Input() nzReverse: boolean = false;\n\n  isPendingBoolean: boolean = false;\n\n  private destroy$ = new Subject<void>();\n\n  constructor(private cdr: ChangeDetectorRef, private platform: Platform) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const modeChanges = changes.nzMode;\n    const reverseChanges = changes.nzReverse;\n    const pendingChanges = changes.nzPending;\n\n    if (modeChanges && (modeChanges.previousValue !== modeChanges.currentValue || modeChanges.isFirstChange())) {\n      this.updateChildren();\n    }\n    if (\n      reverseChanges &&\n      reverseChanges.previousValue !== reverseChanges.currentValue &&\n      !reverseChanges.isFirstChange()\n    ) {\n      this.reverseChildTimelineDots();\n    }\n    if (pendingChanges) {\n      this.isPendingBoolean = pendingChanges.currentValue === true;\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.updateChildren();\n    if (this.listOfTimeLine) {\n      this.listOfTimeLine.changes.pipe(takeUntil(this.destroy$)).subscribe(() => {\n        this.updateChildren();\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private updateChildren(): void {\n    if (this.listOfTimeLine && this.listOfTimeLine.length) {\n      const length = this.listOfTimeLine.length;\n      this.listOfTimeLine.toArray().forEach((item, index) => {\n        item.isLast = !this.nzReverse ? index === length - 1 : index === 0;\n        item.position =\n          this.nzMode === 'left' || !this.nzMode\n            ? undefined\n            : this.nzMode === 'right'\n            ? 'right'\n            : this.nzMode === 'alternate' && index % 2 === 0\n            ? 'left'\n            : 'right';\n        item.detectChanges();\n      });\n      this.cdr.markForCheck();\n    }\n  }\n\n  private reverseChildTimelineDots(): void {\n    if (this.platform.isBrowser) {\n      reverseChildNodes(this.timeline.nativeElement as HTMLElement);\n      this.updateChildren();\n    }\n  }\n}\n"]}