ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
226 lines • 17.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: row.directive.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __read } 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 { MediaMatcher } from '@angular/cdk/layout';
import { Platform } from '@angular/cdk/platform';
import { Directive, ElementRef, Input, NgZone, Renderer2 } from '@angular/core';
import { gridResponsiveMap, NzBreakpointService } from 'ng-zorro-antd/core/services';
import { ReplaySubject, Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
var NzRowDirective = /** @class */ (function () {
function NzRowDirective(elementRef, renderer, mediaMatcher, ngZone, platform, breakpointService) {
this.elementRef = elementRef;
this.renderer = renderer;
this.mediaMatcher = mediaMatcher;
this.ngZone = ngZone;
this.platform = platform;
this.breakpointService = breakpointService;
this.nzAlign = null;
this.nzJustify = null;
this.nzGutter = null;
this.actualGutter$ = new ReplaySubject(1);
this.destroy$ = new Subject();
}
/**
* @return {?}
*/
NzRowDirective.prototype.getGutter = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var results = [0, 0];
/** @type {?} */
var gutter = this.nzGutter || 0;
/** @type {?} */
var normalizedGutter = Array.isArray(gutter) ? gutter : [gutter, 0];
normalizedGutter.forEach((/**
* @param {?} g
* @param {?} index
* @return {?}
*/
function (g, index) {
if (typeof g === 'object') {
results[index] = 0;
Object.keys(gridResponsiveMap).map((/**
* @param {?} screen
* @return {?}
*/
function (screen) {
/** @type {?} */
var bp = (/** @type {?} */ (screen));
if (_this.mediaMatcher.matchMedia(gridResponsiveMap[bp]).matches && g[bp]) {
results[index] = (/** @type {?} */ ((/** @type {?} */ (g))[bp]));
}
}));
}
else {
results[index] = g || 0;
}
}));
return results;
};
/**
* @return {?}
*/
NzRowDirective.prototype.setGutterStyle = /**
* @return {?}
*/
function () {
var _this = this;
var _a = __read(this.getGutter(), 2), horizontalGutter = _a[0], verticalGutter = _a[1];
this.actualGutter$.next([horizontalGutter, verticalGutter]);
/** @type {?} */
var renderGutter = (/**
* @param {?} name
* @param {?} gutter
* @return {?}
*/
function (name, gutter) {
/** @type {?} */
var nativeElement = _this.elementRef.nativeElement;
_this.renderer.setStyle(nativeElement, name, "-" + gutter / 2 + "px");
});
if (horizontalGutter > 0) {
renderGutter('margin-left', horizontalGutter);
renderGutter('margin-right', horizontalGutter);
}
if (verticalGutter > 0) {
renderGutter('margin-top', verticalGutter);
renderGutter('margin-bottom', verticalGutter);
}
};
/**
* @return {?}
*/
NzRowDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.setGutterStyle();
};
/**
* @param {?} changes
* @return {?}
*/
NzRowDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.nzGutter) {
this.setGutterStyle();
}
};
/**
* @return {?}
*/
NzRowDirective.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.platform.isBrowser) {
this.breakpointService
.subscribe(gridResponsiveMap)
.pipe(takeUntil(this.destroy$))
.subscribe((/**
* @return {?}
*/
function () {
_this.setGutterStyle();
}));
}
};
/**
* @return {?}
*/
NzRowDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy$.next();
this.destroy$.complete();
};
NzRowDirective.decorators = [
{ type: Directive, args: [{
selector: '[nz-row],nz-row,nz-form-item',
exportAs: 'nzRow',
host: {
'[class.ant-row]': "true",
'[class.ant-row-top]': "nzAlign === 'top'",
'[class.ant-row-middle]': "nzAlign === 'middle'",
'[class.ant-row-bottom]': "nzAlign === 'bottom'",
'[class.ant-row-start]': "nzJustify === 'start'",
'[class.ant-row-end]': "nzJustify === 'end'",
'[class.ant-row-center]': "nzJustify === 'center'",
'[class.ant-row-space-around]': "nzJustify === 'space-around'",
'[class.ant-row-space-between]': "nzJustify === 'space-between'"
}
},] }
];
/** @nocollapse */
NzRowDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 },
{ type: MediaMatcher },
{ type: NgZone },
{ type: Platform },
{ type: NzBreakpointService }
]; };
NzRowDirective.propDecorators = {
nzType: [{ type: Input }],
nzAlign: [{ type: Input }],
nzJustify: [{ type: Input }],
nzGutter: [{ type: Input }]
};
return NzRowDirective;
}());
export { NzRowDirective };
if (false) {
/**
* @deprecated don't need nzType="flex" after 9.0
* @type {?}
*/
NzRowDirective.prototype.nzType;
/** @type {?} */
NzRowDirective.prototype.nzAlign;
/** @type {?} */
NzRowDirective.prototype.nzJustify;
/** @type {?} */
NzRowDirective.prototype.nzGutter;
/** @type {?} */
NzRowDirective.prototype.actualGutter$;
/**
* @type {?}
* @private
*/
NzRowDirective.prototype.destroy$;
/** @type {?} */
NzRowDirective.prototype.elementRef;
/** @type {?} */
NzRowDirective.prototype.renderer;
/** @type {?} */
NzRowDirective.prototype.mediaMatcher;
/** @type {?} */
NzRowDirective.prototype.ngZone;
/** @type {?} */
NzRowDirective.prototype.platform;
/**
* @type {?}
* @private
*/
NzRowDirective.prototype.breakpointService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row.directive.js","sourceRoot":"ng://ng-zorro-antd/grid/","sources":["row.directive.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 { MediaMatcher } from '@angular/cdk/layout';\nimport { Platform } from '@angular/cdk/platform';\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\nimport { gridResponsiveMap, NzBreakpointKey, NzBreakpointService } from 'ng-zorro-antd/core/services';\nimport { IndexableObject } from 'ng-zorro-antd/core/types';\nimport { ReplaySubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nexport type NzJustify = 'start' | 'end' | 'center' | 'space-around' | 'space-between';\nexport type NzAlign = 'top' | 'middle' | 'bottom';\n\n@Directive({\n  selector: '[nz-row],nz-row,nz-form-item',\n  exportAs: 'nzRow',\n  host: {\n    '[class.ant-row]': `true`,\n    '[class.ant-row-top]': `nzAlign === 'top'`,\n    '[class.ant-row-middle]': `nzAlign === 'middle'`,\n    '[class.ant-row-bottom]': `nzAlign === 'bottom'`,\n    '[class.ant-row-start]': `nzJustify === 'start'`,\n    '[class.ant-row-end]': `nzJustify === 'end'`,\n    '[class.ant-row-center]': `nzJustify === 'center'`,\n    '[class.ant-row-space-around]': `nzJustify === 'space-around'`,\n    '[class.ant-row-space-between]': `nzJustify === 'space-between'`\n  }\n})\nexport class NzRowDirective implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  /**\n   * @deprecated don't need nzType=\"flex\" after 9.0\n   */\n  @Input() nzType: 'flex' | null;\n  @Input() nzAlign: NzAlign | null = null;\n  @Input() nzJustify: NzJustify | null = null;\n  @Input() nzGutter: number | IndexableObject | [number, number] | [IndexableObject, IndexableObject] | null = null;\n\n  readonly actualGutter$ = new ReplaySubject<[number, number]>(1);\n\n  private readonly destroy$ = new Subject();\n\n  getGutter(): [number, number] {\n    const results: [number, number] = [0, 0];\n    const gutter = this.nzGutter || 0;\n    const normalizedGutter = Array.isArray(gutter) ? gutter : [gutter, 0];\n    normalizedGutter.forEach((g, index) => {\n      if (typeof g === 'object') {\n        results[index] = 0;\n        Object.keys(gridResponsiveMap).map((screen: string) => {\n          const bp = screen as NzBreakpointKey;\n          if (this.mediaMatcher.matchMedia(gridResponsiveMap[bp]).matches && g[bp]) {\n            results[index] = g![bp] as number;\n          }\n        });\n      } else {\n        results[index] = g || 0;\n      }\n    });\n    return results;\n  }\n\n  setGutterStyle(): void {\n    const [horizontalGutter, verticalGutter] = this.getGutter();\n    this.actualGutter$.next([horizontalGutter, verticalGutter]);\n    const renderGutter = (name: string, gutter: number) => {\n      const nativeElement = this.elementRef.nativeElement;\n      this.renderer.setStyle(nativeElement, name, `-${gutter / 2}px`);\n    };\n    if (horizontalGutter > 0) {\n      renderGutter('margin-left', horizontalGutter);\n      renderGutter('margin-right', horizontalGutter);\n    }\n    if (verticalGutter > 0) {\n      renderGutter('margin-top', verticalGutter);\n      renderGutter('margin-bottom', verticalGutter);\n    }\n  }\n\n  constructor(\n    public elementRef: ElementRef,\n    public renderer: Renderer2,\n    public mediaMatcher: MediaMatcher,\n    public ngZone: NgZone,\n    public platform: Platform,\n    private breakpointService: NzBreakpointService\n  ) {}\n\n  ngOnInit(): void {\n    this.setGutterStyle();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzGutter) {\n      this.setGutterStyle();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.platform.isBrowser) {\n      this.breakpointService\n        .subscribe(gridResponsiveMap)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe(() => {\n          this.setGutterStyle();\n        });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}