UNPKG

ng-zorro-antd

Version:

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

299 lines 22.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Host, Input, NgZone, Optional, Output, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { MediaMatcher } from '@angular/cdk/layout'; import { Platform } from '@angular/cdk/platform'; import { fromEvent, Subject } from 'rxjs'; import { auditTime, takeUntil } from 'rxjs/operators'; import { InputBoolean } from 'ng-zorro-antd/core'; import { NzLayoutComponent } from './nz-layout.component'; var NzSiderComponent = /** @class */ (function () { function NzSiderComponent(nzLayoutComponent, mediaMatcher, ngZone, platform, cdr, renderer, elementRef) { this.nzLayoutComponent = nzLayoutComponent; this.mediaMatcher = mediaMatcher; this.ngZone = ngZone; this.platform = platform; this.cdr = cdr; this.below = false; this.destroy$ = new Subject(); this.dimensionMap = { xs: '480px', sm: '576px', md: '768px', lg: '992px', xl: '1200px', xxl: '1600px' }; this.nzWidth = 200; this.nzTheme = 'dark'; this.nzCollapsedWidth = 80; this.nzReverseArrow = false; this.nzCollapsible = false; this.nzCollapsed = false; this.nzCollapsedChange = new EventEmitter(); renderer.addClass(elementRef.nativeElement, 'ant-layout-sider'); } Object.defineProperty(NzSiderComponent.prototype, "flexSetting", { get: /** * @return {?} */ function () { if (this.nzCollapsed) { return "0 0 " + this.nzCollapsedWidth + "px"; } else { return "0 0 " + this.nzWidth + "px"; } }, enumerable: true, configurable: true }); Object.defineProperty(NzSiderComponent.prototype, "widthSetting", { get: /** * @return {?} */ function () { if (this.nzCollapsed) { return this.nzCollapsedWidth; } else { return this.nzWidth; } }, enumerable: true, configurable: true }); /** * @return {?} */ NzSiderComponent.prototype.watchMatchMedia = /** * @return {?} */ function () { var _this = this; if (this.nzBreakpoint) { /** @type {?} */ var matchBelow = this.mediaMatcher.matchMedia("(max-width: " + this.dimensionMap[this.nzBreakpoint] + ")").matches; this.below = matchBelow; this.nzCollapsed = matchBelow; this.nzCollapsedChange.emit(matchBelow); this.ngZone.run((/** * @return {?} */ function () { _this.cdr.markForCheck(); })); } }; /** * @return {?} */ NzSiderComponent.prototype.toggleCollapse = /** * @return {?} */ function () { this.nzCollapsed = !this.nzCollapsed; this.nzCollapsedChange.emit(this.nzCollapsed); }; Object.defineProperty(NzSiderComponent.prototype, "isZeroTrigger", { get: /** * @return {?} */ function () { return (this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth === 0 && ((this.nzBreakpoint && this.below) || !this.nzBreakpoint)); }, enumerable: true, configurable: true }); Object.defineProperty(NzSiderComponent.prototype, "isSiderTrigger", { get: /** * @return {?} */ function () { return this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth !== 0; }, enumerable: true, configurable: true }); /** * @return {?} */ NzSiderComponent.prototype.ngOnInit = /** * @return {?} */ function () { if (this.nzLayoutComponent) { this.nzLayoutComponent.initSider(); } }; /** * @return {?} */ NzSiderComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; if (this.platform.isBrowser) { Promise.resolve().then((/** * @return {?} */ function () { return _this.watchMatchMedia(); })); this.ngZone.runOutsideAngular((/** * @return {?} */ function () { fromEvent(window, 'resize') .pipe(auditTime(16), takeUntil(_this.destroy$)) .subscribe((/** * @return {?} */ function () { return _this.watchMatchMedia(); })); })); } }; /** * @return {?} */ NzSiderComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); if (this.nzLayoutComponent) { this.nzLayoutComponent.destroySider(); } }; NzSiderComponent.decorators = [ { type: Component, args: [{ selector: 'nz-sider', exportAs: 'nzSider', preserveWhitespaces: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ant-layout-sider-children\">\n <ng-content></ng-content>\n</div>\n<span class=\"ant-layout-sider-zero-width-trigger\" *ngIf=\"isZeroTrigger\" (click)=\"toggleCollapse()\">\n <ng-template [ngTemplateOutlet]=\"nzZeroTrigger || zeroTrigger\"></ng-template>\n</span>\n<div class=\"ant-layout-sider-trigger\"\n *ngIf=\"isSiderTrigger\"\n (click)=\"toggleCollapse()\"\n [style.width.px]=\"nzCollapsed ? nzCollapsedWidth : nzWidth\">\n <ng-template [ngTemplateOutlet]=\"nzTrigger\"></ng-template>\n</div>\n<ng-template #defaultTrigger>\n <i nz-icon [type]=\"nzCollapsed ? 'right' : 'left'\" *ngIf=\"!nzReverseArrow\"></i>\n <i nz-icon [type]=\"nzCollapsed ? 'left' : 'right'\" *ngIf=\"nzReverseArrow\"></i>\n</ng-template>\n<ng-template #zeroTrigger>\n <i nz-icon type=\"bars\"></i>\n</ng-template>", host: { '[class.ant-layout-sider-zero-width]': 'nzCollapsed && nzCollapsedWidth === 0', '[class.ant-layout-sider-light]': "nzTheme === 'light'", '[class.ant-layout-sider-collapsed]': 'nzCollapsed', '[style.flex]': 'flexSetting', '[style.max-width.px]': 'widthSetting', '[style.min-width.px]': 'widthSetting', '[style.width.px]': 'widthSetting' } }] } ]; /** @nocollapse */ NzSiderComponent.ctorParameters = function () { return [ { type: NzLayoutComponent, decorators: [{ type: Optional }, { type: Host }] }, { type: MediaMatcher }, { type: NgZone }, { type: Platform }, { type: ChangeDetectorRef }, { type: Renderer2 }, { type: ElementRef } ]; }; NzSiderComponent.propDecorators = { nzWidth: [{ type: Input }], nzTheme: [{ type: Input }], nzCollapsedWidth: [{ type: Input }], nzBreakpoint: [{ type: Input }], nzZeroTrigger: [{ type: Input }], nzTrigger: [{ type: Input }, { type: ViewChild, args: ['defaultTrigger',] }], nzReverseArrow: [{ type: Input }], nzCollapsible: [{ type: Input }], nzCollapsed: [{ type: Input }], nzCollapsedChange: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzSiderComponent.prototype, "nzReverseArrow", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzSiderComponent.prototype, "nzCollapsible", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzSiderComponent.prototype, "nzCollapsed", void 0); return NzSiderComponent; }()); export { NzSiderComponent }; if (false) { /** * @type {?} * @private */ NzSiderComponent.prototype.below; /** * @type {?} * @private */ NzSiderComponent.prototype.destroy$; /** * @type {?} * @private */ NzSiderComponent.prototype.dimensionMap; /** @type {?} */ NzSiderComponent.prototype.nzWidth; /** @type {?} */ NzSiderComponent.prototype.nzTheme; /** @type {?} */ NzSiderComponent.prototype.nzCollapsedWidth; /** @type {?} */ NzSiderComponent.prototype.nzBreakpoint; /** @type {?} */ NzSiderComponent.prototype.nzZeroTrigger; /** @type {?} */ NzSiderComponent.prototype.nzTrigger; /** @type {?} */ NzSiderComponent.prototype.nzReverseArrow; /** @type {?} */ NzSiderComponent.prototype.nzCollapsible; /** @type {?} */ NzSiderComponent.prototype.nzCollapsed; /** @type {?} */ NzSiderComponent.prototype.nzCollapsedChange; /** * @type {?} * @private */ NzSiderComponent.prototype.nzLayoutComponent; /** * @type {?} * @private */ NzSiderComponent.prototype.mediaMatcher; /** * @type {?} * @private */ NzSiderComponent.prototype.ngZone; /** * @type {?} * @private */ NzSiderComponent.prototype.platform; /** * @type {?} * @private */ NzSiderComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-sider.component.js","sourceRoot":"ng://ng-zorro-antd/layout/","sources":["nz-sider.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 {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\nimport { MediaMatcher } from '@angular/cdk/layout';\nimport { Platform } from '@angular/cdk/platform';\nimport { fromEvent, Subject } from 'rxjs';\nimport { auditTime, takeUntil } from 'rxjs/operators';\n\nimport { InputBoolean } from 'ng-zorro-antd/core';\n\nimport { NzLayoutComponent } from './nz-layout.component';\n\nexport type NzBreakPoint = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl';\n\n@Component({\n  selector: 'nz-sider',\n  exportAs: 'nzSider',\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './nz-sider.component.html',\n  host: {\n    '[class.ant-layout-sider-zero-width]': 'nzCollapsed && nzCollapsedWidth === 0',\n    '[class.ant-layout-sider-light]': `nzTheme === 'light'`,\n    '[class.ant-layout-sider-collapsed]': 'nzCollapsed',\n    '[style.flex]': 'flexSetting',\n    '[style.max-width.px]': 'widthSetting',\n    '[style.min-width.px]': 'widthSetting',\n    '[style.width.px]': 'widthSetting'\n  }\n})\nexport class NzSiderComponent implements OnInit, AfterViewInit, OnDestroy {\n  private below = false;\n  private destroy$ = new Subject();\n  private dimensionMap = {\n    xs: '480px',\n    sm: '576px',\n    md: '768px',\n    lg: '992px',\n    xl: '1200px',\n    xxl: '1600px'\n  };\n  @Input() nzWidth = 200;\n  @Input() nzTheme: 'light' | 'dark' = 'dark';\n  @Input() nzCollapsedWidth = 80;\n  @Input() nzBreakpoint: NzBreakPoint;\n  @Input() nzZeroTrigger: TemplateRef<void>;\n  @Input() @ViewChild('defaultTrigger') nzTrigger: TemplateRef<void>;\n  @Input() @InputBoolean() nzReverseArrow = false;\n  @Input() @InputBoolean() nzCollapsible = false;\n  @Input() @InputBoolean() nzCollapsed = false;\n  @Output() readonly nzCollapsedChange = new EventEmitter();\n\n  get flexSetting(): string {\n    if (this.nzCollapsed) {\n      return `0 0 ${this.nzCollapsedWidth}px`;\n    } else {\n      return `0 0 ${this.nzWidth}px`;\n    }\n  }\n\n  get widthSetting(): number {\n    if (this.nzCollapsed) {\n      return this.nzCollapsedWidth;\n    } else {\n      return this.nzWidth;\n    }\n  }\n\n  watchMatchMedia(): void {\n    if (this.nzBreakpoint) {\n      const matchBelow = this.mediaMatcher.matchMedia(`(max-width: ${this.dimensionMap[this.nzBreakpoint]})`).matches;\n      this.below = matchBelow;\n      this.nzCollapsed = matchBelow;\n      this.nzCollapsedChange.emit(matchBelow);\n      this.ngZone.run(() => {\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  toggleCollapse(): void {\n    this.nzCollapsed = !this.nzCollapsed;\n    this.nzCollapsedChange.emit(this.nzCollapsed);\n  }\n\n  get isZeroTrigger(): boolean {\n    return (\n      this.nzCollapsible &&\n      this.nzTrigger &&\n      this.nzCollapsedWidth === 0 &&\n      ((this.nzBreakpoint && this.below) || !this.nzBreakpoint)\n    );\n  }\n\n  get isSiderTrigger(): boolean {\n    return this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth !== 0;\n  }\n\n  constructor(\n    @Optional() @Host() private nzLayoutComponent: NzLayoutComponent,\n    private mediaMatcher: MediaMatcher,\n    private ngZone: NgZone,\n    private platform: Platform,\n    private cdr: ChangeDetectorRef,\n    renderer: Renderer2,\n    elementRef: ElementRef\n  ) {\n    renderer.addClass(elementRef.nativeElement, 'ant-layout-sider');\n  }\n\n  ngOnInit(): void {\n    if (this.nzLayoutComponent) {\n      this.nzLayoutComponent.initSider();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.platform.isBrowser) {\n      Promise.resolve().then(() => this.watchMatchMedia());\n      this.ngZone.runOutsideAngular(() => {\n        fromEvent(window, 'resize')\n          .pipe(\n            auditTime(16),\n            takeUntil(this.destroy$)\n          )\n          .subscribe(() => this.watchMatchMedia());\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    if (this.nzLayoutComponent) {\n      this.nzLayoutComponent.destroySider();\n    }\n  }\n}\n"]}