ng-zorro-antd-yj
Version:
An enterprise-class UI components based on Ant Design and Angular
244 lines • 20.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { ContentChildren, Directive, ElementRef, EventEmitter, Input, Optional, Output, QueryList, SkipSelf } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NzUpdateHostClassService } from '../core/services/update-host-class.service';
import { InputBoolean } from '../core/util/convert';
import { NzMenuDropdownService } from '../dropdown/nz-menu-dropdown.service';
import { NzMenuItemDirective } from './nz-menu-item.directive';
import { NzMenuMenuService } from './nz-menu-menu.service';
import { NzMenuService } from './nz-menu.service';
import { NzSubMenuComponent } from './nz-submenu.component';
/**
* @param {?} dropService
* @param {?} menuService
* @return {?}
*/
export function NzMenuFactory(dropService, menuService) {
return dropService ? dropService : menuService;
}
export class NzMenuDirective {
/**
* @param {?} elementRef
* @param {?} nzMenuService
* @param {?} nzUpdateHostClassService
*/
constructor(elementRef, nzMenuService, nzUpdateHostClassService) {
this.elementRef = elementRef;
this.nzMenuService = nzMenuService;
this.nzUpdateHostClassService = nzUpdateHostClassService;
this.destroy$ = new Subject();
this.listOfOpenedNzSubMenuComponent = [];
this.nzInlineIndent = 24;
this.nzTheme = 'light';
this.nzMode = 'vertical';
this.nzInDropDown = false;
this.nzInlineCollapsed = false;
this.nzSelectable = !this.nzMenuService.isInDropDown;
this.nzClick = new EventEmitter();
}
/**
* @return {?}
*/
updateInlineCollapse() {
if (this.listOfNzMenuItemDirective) {
if (this.nzInlineCollapsed) {
this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter((/**
* @param {?} submenu
* @return {?}
*/
submenu => submenu.nzOpen));
this.listOfNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
submenu => submenu.setOpenState(false)));
this.nzMode = 'vertical';
}
else {
this.listOfOpenedNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
submenu => submenu.setOpenState(true)));
this.listOfOpenedNzSubMenuComponent = [];
this.nzMode = this.cacheMode;
}
this.nzMenuService.setMode(this.nzMode);
}
}
/**
* @return {?}
*/
setClassMap() {
/** @type {?} */
const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu' : 'ant-menu';
this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, {
[`${prefixName}`]: true,
[`${prefixName}-root`]: true,
[`${prefixName}-${this.nzTheme}`]: true,
[`${prefixName}-${this.nzMode}`]: true,
[`${prefixName}-inline-collapsed`]: this.nzInlineCollapsed
});
}
/**
* @return {?}
*/
ngOnInit() {
this.setClassMap();
this.nzMenuService.menuItemClick$.pipe(takeUntil(this.destroy$)).subscribe((/**
* @param {?} menu
* @return {?}
*/
menu => {
this.nzClick.emit(menu);
if (this.nzSelectable) {
this.listOfNzMenuItemDirective.forEach((/**
* @param {?} item
* @return {?}
*/
item => item.setSelectedState(item === menu)));
}
}));
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.cacheMode = this.nzMode;
this.updateInlineCollapse();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.nzInlineCollapsed) {
this.updateInlineCollapse();
}
if (changes.nzInlineIndent) {
this.nzMenuService.setInlineIndent(this.nzInlineIndent);
}
if (changes.nzInDropDown) {
this.nzMenuService.isInDropDown = this.nzInDropDown;
}
if (changes.nzTheme) {
this.nzMenuService.setTheme(this.nzTheme);
}
if (changes.nzMode) {
this.nzMenuService.setMode(this.nzMode);
if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) {
this.listOfNzSubMenuComponent.forEach((/**
* @param {?} submenu
* @return {?}
*/
submenu => submenu.setOpenState(false)));
}
}
if (changes.nzTheme || changes.nzMode || changes.nzInlineCollapsed) {
this.setClassMap();
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
}
}
NzMenuDirective.decorators = [
{ type: Directive, args: [{
selector: '[nz-menu]',
providers: [
NzUpdateHostClassService,
NzMenuMenuService,
{
provide: NzMenuService,
useFactory: NzMenuFactory,
deps: [[new SkipSelf(), new Optional(), NzMenuDropdownService], NzMenuMenuService]
}
]
},] }
];
/** @nocollapse */
NzMenuDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: NzMenuService },
{ type: NzUpdateHostClassService }
];
NzMenuDirective.propDecorators = {
listOfNzMenuItemDirective: [{ type: ContentChildren, args: [NzMenuItemDirective, { descendants: true },] }],
listOfNzSubMenuComponent: [{ type: ContentChildren, args: [NzSubMenuComponent, { descendants: true },] }],
nzInlineIndent: [{ type: Input }],
nzTheme: [{ type: Input }],
nzMode: [{ type: Input }],
nzInDropDown: [{ type: Input }],
nzInlineCollapsed: [{ type: Input }],
nzSelectable: [{ type: Input }],
nzClick: [{ type: Output }]
};
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzMenuDirective.prototype, "nzInDropDown", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzMenuDirective.prototype, "nzInlineCollapsed", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzMenuDirective.prototype, "nzSelectable", void 0);
if (false) {
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.destroy$;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.cacheMode;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.listOfOpenedNzSubMenuComponent;
/** @type {?} */
NzMenuDirective.prototype.listOfNzMenuItemDirective;
/** @type {?} */
NzMenuDirective.prototype.listOfNzSubMenuComponent;
/** @type {?} */
NzMenuDirective.prototype.nzInlineIndent;
/** @type {?} */
NzMenuDirective.prototype.nzTheme;
/** @type {?} */
NzMenuDirective.prototype.nzMode;
/** @type {?} */
NzMenuDirective.prototype.nzInDropDown;
/** @type {?} */
NzMenuDirective.prototype.nzInlineCollapsed;
/** @type {?} */
NzMenuDirective.prototype.nzSelectable;
/** @type {?} */
NzMenuDirective.prototype.nzClick;
/** @type {?} */
NzMenuDirective.prototype.elementRef;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.nzMenuService;
/**
* @type {?}
* @private
*/
NzMenuDirective.prototype.nzUpdateHostClassService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-menu.directive.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["menu/nz-menu.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  SkipSelf\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NzUpdateHostClassService } from '../core/services/update-host-class.service';\nimport { NzDirectionVHIType } from '../core/types/direction';\nimport { InputBoolean } from '../core/util/convert';\nimport { NzMenuDropdownService } from '../dropdown/nz-menu-dropdown.service';\nimport { NzMenuItemDirective } from './nz-menu-item.directive';\nimport { NzMenuMenuService } from './nz-menu-menu.service';\nimport { NzMenuService } from './nz-menu.service';\nimport { NzSubMenuComponent } from './nz-submenu.component';\n\nexport function NzMenuFactory(dropService: NzMenuDropdownService, menuService: NzMenuMenuService): NzMenuService {\n  return dropService ? dropService : menuService;\n}\n\n@Directive({\n  selector: '[nz-menu]',\n  providers: [\n    NzUpdateHostClassService,\n    NzMenuMenuService,\n    {\n      provide: NzMenuService,\n      useFactory: NzMenuFactory,\n      deps: [[new SkipSelf(), new Optional(), NzMenuDropdownService], NzMenuMenuService]\n    }\n  ]\n})\nexport class NzMenuDirective implements AfterContentInit, OnInit, OnChanges, OnDestroy {\n  private destroy$ = new Subject();\n  private cacheMode: NzDirectionVHIType;\n  private listOfOpenedNzSubMenuComponent: NzSubMenuComponent[] = [];\n  @ContentChildren(NzMenuItemDirective, { descendants: true }) listOfNzMenuItemDirective: QueryList<\n    NzMenuItemDirective\n  >;\n  @ContentChildren(NzSubMenuComponent, { descendants: true }) listOfNzSubMenuComponent: QueryList<NzSubMenuComponent>;\n  @Input() nzInlineIndent = 24;\n  @Input() nzTheme: 'light' | 'dark' = 'light';\n  @Input() nzMode: NzDirectionVHIType = 'vertical';\n  @Input() @InputBoolean() nzInDropDown = false;\n  @Input() @InputBoolean() nzInlineCollapsed = false;\n  @Input() @InputBoolean() nzSelectable = !this.nzMenuService.isInDropDown;\n  @Output() readonly nzClick = new EventEmitter<NzMenuItemDirective>();\n\n  updateInlineCollapse(): void {\n    if (this.listOfNzMenuItemDirective) {\n      if (this.nzInlineCollapsed) {\n        this.listOfOpenedNzSubMenuComponent = this.listOfNzSubMenuComponent.filter(submenu => submenu.nzOpen);\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenState(false));\n        this.nzMode = 'vertical';\n      } else {\n        this.listOfOpenedNzSubMenuComponent.forEach(submenu => submenu.setOpenState(true));\n        this.listOfOpenedNzSubMenuComponent = [];\n        this.nzMode = this.cacheMode;\n      }\n      this.nzMenuService.setMode(this.nzMode);\n    }\n  }\n\n  setClassMap(): void {\n    const prefixName = this.nzMenuService.isInDropDown ? 'ant-dropdown-menu' : 'ant-menu';\n    this.nzUpdateHostClassService.updateHostClass(this.elementRef.nativeElement, {\n      [`${prefixName}`]: true,\n      [`${prefixName}-root`]: true,\n      [`${prefixName}-${this.nzTheme}`]: true,\n      [`${prefixName}-${this.nzMode}`]: true,\n      [`${prefixName}-inline-collapsed`]: this.nzInlineCollapsed\n    });\n  }\n\n  constructor(\n    public elementRef: ElementRef,\n    private nzMenuService: NzMenuService,\n    private nzUpdateHostClassService: NzUpdateHostClassService\n  ) {}\n\n  ngOnInit(): void {\n    this.setClassMap();\n    this.nzMenuService.menuItemClick$.pipe(takeUntil(this.destroy$)).subscribe(menu => {\n      this.nzClick.emit(menu);\n      if (this.nzSelectable) {\n        this.listOfNzMenuItemDirective.forEach(item => item.setSelectedState(item === menu));\n      }\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.cacheMode = this.nzMode;\n    this.updateInlineCollapse();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzInlineCollapsed) {\n      this.updateInlineCollapse();\n    }\n    if (changes.nzInlineIndent) {\n      this.nzMenuService.setInlineIndent(this.nzInlineIndent);\n    }\n    if (changes.nzInDropDown) {\n      this.nzMenuService.isInDropDown = this.nzInDropDown;\n    }\n    if (changes.nzTheme) {\n      this.nzMenuService.setTheme(this.nzTheme);\n    }\n    if (changes.nzMode) {\n      this.nzMenuService.setMode(this.nzMode);\n      if (!changes.nzMode.isFirstChange() && this.listOfNzSubMenuComponent) {\n        this.listOfNzSubMenuComponent.forEach(submenu => submenu.setOpenState(false));\n      }\n    }\n    if (changes.nzTheme || changes.nzMode || changes.nzInlineCollapsed) {\n      this.setClassMap();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}