UNPKG

ng-zorro-antd-mobile

Version:

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

317 lines 26.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewEncapsulation, Input, Output, EventEmitter } from '@angular/core'; import { Subject } from 'rxjs'; import { LocaleProviderService } from '../locale-provider/locale-provider.service'; import { takeUntil } from 'rxjs/operators'; /** * @record */ function LocaleValue() { } if (false) { /** @type {?} */ LocaleValue.prototype.okText; /** @type {?} */ LocaleValue.prototype.cancelText; } export class MenuComponent { /** * @param {?} _localeProviderService */ constructor(_localeProviderService) { this._localeProviderService = _localeProviderService; this.prefixCls = 'am-menu'; this.subMenuPrefixCls = 'am-sub-menu'; this.radioPrefixCls = 'am-radio'; this.multiSelectMenuBtnsCls = 'am-multi-select-btns'; this.menuSelectContanerPrefixCls = 'am-menu-select-container'; this.locale = { okText: '', cancelText: '' }; this._data = []; this._unsubscribe$ = new Subject(); this.level = 2; this.value = []; this.height = document.documentElement.clientHeight / 2; this.multiSelect = false; this.onChange = new EventEmitter(); this.onOk = new EventEmitter(); this.onCancel = new EventEmitter(); } /** * @return {?} */ get data() { return this._data; } /** * @param {?} v * @return {?} */ set data(v) { this._data = v; this.initData(); } /** * @return {?} */ onMenuOk() { this.onOk.emit(this.value); } /** * @return {?} */ onMenuCancel() { this.onCancel.emit(); } /** * @return {?} */ getNewFsv() { /** @type {?} */ let firstValue = ''; if (this.value && this.value.length) { firstValue = (/** @type {?} */ (this.value[0])); } else if (this._data && this._data.length && !this._data[0].isLeaf) { firstValue = this._data[0].value; } return firstValue; } /** * @param {?} dataItem * @return {?} */ onClickFirstLevelItem(dataItem) { this.firstLevelSelectValue = dataItem.value; if (dataItem.isLeaf && this.onChange) { this.onChange.emit([dataItem.value]); } this.initData(); } /** * @param {?} dataItem * @return {?} */ onClickSubMenuItem(dataItem) { this.value = this.getSelectValue(dataItem); this.initData(); setTimeout((/** * @return {?} */ () => { this.onChange.emit(this.value); }), 300); } /** * @param {?} dataItem * @return {?} */ getSelectValue(dataItem) { if (this.multiSelect) { if (this.value && this.value.length > 0) { if (this.level === 2 && this.value[0] !== this.firstLevelSelectValue) { return [this.firstLevelSelectValue, [dataItem.value]]; } else { if (this.level == 1) { /** @type {?} */ const chosenValues = Array.from(this.value); /** @type {?} */ const existIndex = chosenValues.indexOf(dataItem.value); if (existIndex === -1) { chosenValues.push(dataItem.value); } else { chosenValues.splice(existIndex, 1); } return chosenValues; } else { /** @type {?} */ const chosenValues = Array.from(this.value[1]); /** @type {?} */ const existIndex = chosenValues.indexOf(dataItem.value); if (existIndex === -1) { chosenValues.push(dataItem.value); } else { chosenValues.splice(existIndex, 1); } return [this.firstLevelSelectValue, chosenValues]; } } } else { return this.level === 2 ? [this.firstLevelSelectValue, [dataItem.value]] : [dataItem.value]; } } return this.level === 2 ? [this.firstLevelSelectValue, dataItem.value] : [dataItem.value]; } /** * @return {?} */ initData() { this.subMenuData = this._data; if (this.level === 2) { /** @type {?} */ let parent = this._data; if (this.firstLevelSelectValue && this.firstLevelSelectValue !== '') { parent = this._data.filter((/** * @param {?} dataItem * @return {?} */ dataItem => dataItem.value === this.firstLevelSelectValue)); } if (parent[0] && parent[0].children && parent[0].isLeaf !== true) { this.subMenuData = parent[0].children; } else { this.subMenuData = []; } } /** @type {?} */ let subValue = (this.value && this.value.length > 0 && [...this.value]) || []; if (this.level === 2 && subValue.length > 1) { subValue.shift(); if (this.multiSelect) { subValue = (/** @type {?} */ (subValue[0])); } } this.subSelInitItem = this.subMenuData .filter((/** * @param {?} dataItem * @return {?} */ dataItem => subValue.indexOf(dataItem.value) !== -1)) .map((/** * @param {?} item * @return {?} */ item => { return item.value; })); /** @type {?} */ const parentValue = this.value && this.value.length > 1 && this.level === 2 ? this.value[0] : null; this.showSelect = true; if (this.level === 2 && parentValue !== this.firstLevelSelectValue) { this.showSelect = false; } } /** * @param {?} dataItem * @return {?} */ getClass(dataItem) { return this.dataItemSelected(dataItem) ? this.prefixCls + '-selected' : ''; } /** * @param {?} dataItem * @return {?} */ dataItemSelected(dataItem) { return dataItem.value === this.firstLevelSelectValue; } /** * @return {?} */ ngOnInit() { this._localeProviderService.localeChange.pipe(takeUntil(this._unsubscribe$)).subscribe((/** * @param {?} _ * @return {?} */ _ => { this.locale = (/** @type {?} */ (this._localeProviderService.getLocaleSubObj('Menu'))); })); this.firstLevelSelectValue = this.getNewFsv(); this.heightStyle = { height: this.height + 'px' }; this.initData(); } /** * @return {?} */ ngOnDestroy() { this._unsubscribe$.next(); this._unsubscribe$.complete(); } } MenuComponent.decorators = [ { type: Component, args: [{ selector: 'Menu, nzm-menu', template: "<Flex class=\"{{ prefixCls }}\" [ngStyle]=\"heightStyle\" [direction]=\"'column'\" [align]=\"'stretch'\">\n <Flex class=\"{{ menuSelectContanerPrefixCls }}\" [align]=\"'start'\">\n <FlexItem *ngIf=\"level == 2\">\n <List role=\"tablist\">\n <ListItem\n role=\"tab\"\n *ngFor=\"let dataItem of data; let i = index\"\n [className]=\"getClass(dataItem)\"\n (click)=\"onClickFirstLevelItem(dataItem)\"\n >\n {{ dataItem.label }}\n </ListItem>\n </List>\n </FlexItem>\n\n <FlexItem role=\"tabpanel\" aria-hidden=\"false\" class=\"{{ menuSelectContanerPrefixCls }}-submenu\">\n <SubMenu\n [subMenuPrefixCls]=\"subMenuPrefixCls\"\n [radioPrefixCls]=\"radioPrefixCls\"\n [subMenuData]=\"subMenuData\"\n [selItem]=\"subSelInitItem\"\n [showSelect]=\"showSelect\"\n [multiSelect]=\"multiSelect\"\n (onSel)=\"onClickSubMenuItem($event)\"\n >\n </SubMenu>\n </FlexItem>\n </Flex>\n\n <div *ngIf=\"multiSelect\" class=\"{{ multiSelectMenuBtnsCls }}\">\n <a Button [className]=\"'am-multi-select-btns-btn'\" [inline]=\"true\" (onClick)=\"onMenuCancel()\">\n {{ locale.cancelText }}\n </a>\n <a Button [className]=\"'am-multi-select-btns-btn'\" [inline]=\"true\" [type]=\"'primary'\" (onClick)=\"onMenuOk()\">\n {{ locale.okText }}\n </a>\n </div>\n</Flex>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ MenuComponent.ctorParameters = () => [ { type: LocaleProviderService } ]; MenuComponent.propDecorators = { data: [{ type: Input }], level: [{ type: Input }], value: [{ type: Input }], height: [{ type: Input }], multiSelect: [{ type: Input }], onChange: [{ type: Output }], onOk: [{ type: Output }], onCancel: [{ type: Output }] }; if (false) { /** @type {?} */ MenuComponent.prototype.prefixCls; /** @type {?} */ MenuComponent.prototype.subMenuPrefixCls; /** @type {?} */ MenuComponent.prototype.radioPrefixCls; /** @type {?} */ MenuComponent.prototype.multiSelectMenuBtnsCls; /** @type {?} */ MenuComponent.prototype.menuSelectContanerPrefixCls; /** @type {?} */ MenuComponent.prototype.firstLevelSelectValue; /** @type {?} */ MenuComponent.prototype.heightStyle; /** @type {?} */ MenuComponent.prototype.subMenuData; /** @type {?} */ MenuComponent.prototype.showSelect; /** @type {?} */ MenuComponent.prototype.subSelInitItem; /** @type {?} */ MenuComponent.prototype.locale; /** * @type {?} * @private */ MenuComponent.prototype._data; /** * @type {?} * @private */ MenuComponent.prototype._unsubscribe$; /** @type {?} */ MenuComponent.prototype.level; /** @type {?} */ MenuComponent.prototype.value; /** @type {?} */ MenuComponent.prototype.height; /** @type {?} */ MenuComponent.prototype.multiSelect; /** @type {?} */ MenuComponent.prototype.onChange; /** @type {?} */ MenuComponent.prototype.onOk; /** @type {?} */ MenuComponent.prototype.onCancel; /** * @type {?} * @private */ MenuComponent.prototype._localeProviderService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["menu/menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewEncapsulation, Input, Output, EventEmitter, OnDestroy } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { LocaleProviderService } from '../locale-provider/locale-provider.service';\nimport { takeUntil } from 'rxjs/operators';\n\ninterface LocaleValue {\n  okText: string;\n  cancelText: string;\n}\n\n@Component({\n  selector: 'Menu, nzm-menu',\n  templateUrl: './menu.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class MenuComponent implements OnInit, OnDestroy {\n  prefixCls: string = 'am-menu';\n  subMenuPrefixCls: string = 'am-sub-menu';\n  radioPrefixCls: string = 'am-radio';\n  multiSelectMenuBtnsCls: string = 'am-multi-select-btns';\n  menuSelectContanerPrefixCls: string = 'am-menu-select-container';\n  firstLevelSelectValue: number | string;\n  heightStyle: object;\n  subMenuData: Array<any>;\n  showSelect: boolean;\n  subSelInitItem: object;\n  locale: LocaleValue = {\n    okText: '',\n    cancelText: ''\n  };\n\n  private _data: Array<any> = [];\n  private _unsubscribe$: Subject<void> = new Subject<void>();\n\n  @Input()\n  get data() {\n    return this._data;\n  }\n  set data(v) {\n    this._data = v;\n    this.initData();\n  }\n  @Input()\n  level: number = 2;\n  @Input()\n  value: Array<any> = [];\n  @Input()\n  height: number = document.documentElement.clientHeight / 2;\n  @Input()\n  multiSelect: boolean = false;\n  @Output()\n  onChange: EventEmitter<any> = new EventEmitter<any>();\n  @Output()\n  onOk: EventEmitter<any> = new EventEmitter<any>();\n  @Output()\n  onCancel: EventEmitter<any> = new EventEmitter<any>();\n\n  constructor(private _localeProviderService: LocaleProviderService) {}\n\n  onMenuOk() {\n    this.onOk.emit(this.value);\n  }\n\n  onMenuCancel() {\n    this.onCancel.emit();\n  }\n\n  getNewFsv() {\n    let firstValue = '';\n    if (this.value && this.value.length) {\n      firstValue = this.value[0] as string;\n    } else if (this._data && this._data.length && !this._data[0].isLeaf) {\n      firstValue = this._data[0].value;\n    }\n    return firstValue;\n  }\n\n  onClickFirstLevelItem(dataItem) {\n    this.firstLevelSelectValue = dataItem.value;\n    if (dataItem.isLeaf && this.onChange) {\n      this.onChange.emit([dataItem.value]);\n    }\n    this.initData();\n  }\n\n  onClickSubMenuItem(dataItem) {\n    this.value = this.getSelectValue(dataItem);\n    this.initData();\n    setTimeout(() => {\n      this.onChange.emit(this.value);\n    }, 300);\n  }\n\n  getSelectValue(dataItem) {\n    if (this.multiSelect) {\n      if (this.value && this.value.length > 0) {\n        if (this.level === 2 && this.value[0] !== this.firstLevelSelectValue) {\n          return [this.firstLevelSelectValue, [dataItem.value]];\n        } else {\n          if (this.level == 1) {\n            const chosenValues = Array.from(this.value);\n            const existIndex = chosenValues.indexOf(dataItem.value);\n            if (existIndex === -1) {\n              chosenValues.push(dataItem.value);\n            } else {\n              chosenValues.splice(existIndex, 1);\n            }\n            return chosenValues;\n          } else {\n            const chosenValues = Array.from(this.value[1]);\n            const existIndex = chosenValues.indexOf(dataItem.value);\n            if (existIndex === -1) {\n              chosenValues.push(dataItem.value);\n            } else {\n              chosenValues.splice(existIndex, 1);\n            }\n            return [this.firstLevelSelectValue, chosenValues];\n          }\n        }\n      } else {\n        return this.level === 2 ? [this.firstLevelSelectValue, [dataItem.value]] : [dataItem.value];\n      }\n    }\n    return this.level === 2 ? [this.firstLevelSelectValue, dataItem.value] : [dataItem.value];\n  }\n\n  initData() {\n    this.subMenuData = this._data;\n    if (this.level === 2) {\n      let parent = this._data;\n      if (this.firstLevelSelectValue && this.firstLevelSelectValue !== '') {\n        parent = this._data.filter(dataItem => dataItem.value === this.firstLevelSelectValue);\n      }\n      if (parent[0] && parent[0].children && parent[0].isLeaf !== true) {\n        this.subMenuData = parent[0].children;\n      } else {\n        this.subMenuData = [];\n      }\n    }\n\n    let subValue = (this.value && this.value.length > 0 && [...this.value]) || [];\n    if (this.level === 2 && subValue.length > 1) {\n      subValue.shift();\n      if (this.multiSelect) {\n        subValue = subValue[0] as string[];\n      }\n    }\n\n    this.subSelInitItem = this.subMenuData\n      .filter(dataItem => subValue.indexOf(dataItem.value) !== -1)\n      .map(item => {\n        return item.value;\n      });\n\n    const parentValue = this.value && this.value.length > 1 && this.level === 2 ? this.value[0] : null;\n\n    this.showSelect = true;\n    if (this.level === 2 && parentValue !== this.firstLevelSelectValue) {\n      this.showSelect = false;\n    }\n  }\n\n  getClass(dataItem) {\n    return this.dataItemSelected(dataItem) ? this.prefixCls + '-selected' : '';\n  }\n\n  dataItemSelected(dataItem) {\n    return dataItem.value === this.firstLevelSelectValue;\n  }\n\n  ngOnInit() {\n    this._localeProviderService.localeChange.pipe(takeUntil(this._unsubscribe$)).subscribe(_ => {\n      this.locale = <LocaleValue>this._localeProviderService.getLocaleSubObj('Menu');\n    });\n\n    this.firstLevelSelectValue = this.getNewFsv();\n\n    this.heightStyle = {\n      height: this.height + 'px'\n    };\n    this.initData();\n  }\n\n  ngOnDestroy() {\n    this._unsubscribe$.next();\n    this._unsubscribe$.complete();\n  }\n}\n"]}