ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
317 lines • 26.8 kB
JavaScript
/**
* @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"]}