ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
262 lines • 19.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
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 '../core/util/convert';
import { NzLayoutComponent } from './nz-layout.component';
export class NzSiderComponent {
/**
* @param {?} nzLayoutComponent
* @param {?} mediaMatcher
* @param {?} ngZone
* @param {?} platform
* @param {?} cdr
* @param {?} renderer
* @param {?} elementRef
*/
constructor(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');
}
/**
* @return {?}
*/
get flexSetting() {
if (this.nzCollapsed) {
return `0 0 ${this.nzCollapsedWidth}px`;
}
else {
return `0 0 ${this.nzWidth}px`;
}
}
/**
* @return {?}
*/
get widthSetting() {
if (this.nzCollapsed) {
return this.nzCollapsedWidth;
}
else {
return this.nzWidth;
}
}
/**
* @return {?}
*/
watchMatchMedia() {
if (this.nzBreakpoint) {
/** @type {?} */
const 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 {?}
*/
() => {
this.cdr.markForCheck();
}));
}
}
/**
* @return {?}
*/
toggleCollapse() {
this.nzCollapsed = !this.nzCollapsed;
this.nzCollapsedChange.emit(this.nzCollapsed);
}
/**
* @return {?}
*/
get isZeroTrigger() {
return this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth === 0 && ((this.nzBreakpoint && this.below) || (!this.nzBreakpoint));
}
/**
* @return {?}
*/
get isSiderTrigger() {
return this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth !== 0;
}
/**
* @return {?}
*/
ngOnInit() {
if (this.nzLayoutComponent) {
this.nzLayoutComponent.initSider();
}
}
/**
* @return {?}
*/
ngAfterViewInit() {
if (this.platform.isBrowser) {
Promise.resolve().then((/**
* @return {?}
*/
() => this.watchMatchMedia()));
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
fromEvent(window, 'resize')
.pipe(auditTime(16), takeUntil(this.destroy$))
.subscribe((/**
* @return {?}
*/
() => this.watchMatchMedia()));
}));
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
if (this.nzLayoutComponent) {
this.nzLayoutComponent.destroySider();
}
}
}
NzSiderComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-sider',
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 = () => [
{ 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);
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/","sources":["layout/nz-sider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\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';\nimport { InputBoolean } from '../core/util/convert';\nimport { NzLayoutComponent } from './nz-layout.component';\n\nexport type NzBreakPoint = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl';\n\n@Component({\n  selector           : 'nz-sider',\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 this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth === 0 && ((this.nzBreakpoint && this.below) || (!this.nzBreakpoint));\n  }\n\n  get isSiderTrigger(): boolean {\n    return this.nzCollapsible && this.nzTrigger && this.nzCollapsedWidth !== 0;\n  }\n\n  constructor(@Optional() @Host() private nzLayoutComponent: NzLayoutComponent, private mediaMatcher: MediaMatcher, private ngZone: NgZone, private platform: Platform, private cdr: ChangeDetectorRef, renderer: Renderer2, elementRef: ElementRef) {\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(auditTime(16), takeUntil(this.destroy$))\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}\n"]}