UNPKG

sidenav-menu-arrows

Version:
252 lines (251 loc) 27.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter } from '@angular/core'; import { Router } from '@angular/router'; import { trigger, style, transition, animate, state, group } from '@angular/animations'; import { MultilevelMenuService } from './../multilevel-menu.service'; import { CONSTANT } from './../constants'; export class ListItemComponent { /** * @param {?} router * @param {?} multilevelMenuService */ constructor(router, multilevelMenuService) { this.router = router; this.multilevelMenuService = multilevelMenuService; this.level = 1; this.nodeConfiguration = null; this.selectedItem = new EventEmitter(); this.isSelected = false; this.expanded = false; this.firstInitializer = false; this.selectedListClasses = { [CONSTANT.DEFAULT_LIST_CLASS_NAME]: true, [CONSTANT.SELECTED_LIST_CLASS_NAME]: false, [CONSTANT.ACTIVE_ITEM_CLASS_NAME]: false, }; } /** * @return {?} */ ngOnChanges() { this.nodeChildren = this.node && this.node.items ? this.node.items.filter(n => !n.hidden) : []; if (this.selectedNode !== undefined && this.selectedNode !== null) { this.setSelectedClass(this.multilevelMenuService.recursiveCheckId(this.node, this.selectedNode.id)); } } /** * @param {?} isFound * @return {?} */ setSelectedClass(isFound) { if (isFound) { if (!this.firstInitializer) { this.expanded = true; } this.isSelected = this.nodeConfiguration.highlightOnSelect || this.selectedNode.items === undefined ? true : false; } else { this.isSelected = false; if (this.nodeConfiguration.collapseOnSelect) { this.expanded = false; } } this.selectedListClasses = { [CONSTANT.DEFAULT_LIST_CLASS_NAME]: true, [CONSTANT.SELECTED_LIST_CLASS_NAME]: this.isSelected, [CONSTANT.ACTIVE_ITEM_CLASS_NAME]: this.selectedNode.id === this.node.id, }; this.setClasses(); } /** * @return {?} */ getPaddingAtStart() { return this.nodeConfiguration.paddingAtStart ? true : false; } /** * @return {?} */ getListStyle() { /** @type {?} */ const styles = { background: CONSTANT.DEFAULT_LIST_BACKGROUND_COLOR, color: CONSTANT.DEFAULT_LIST_FONT_COLOR }; if (this.nodeConfiguration.listBackgroundColor !== null) { styles.background = this.nodeConfiguration.listBackgroundColor; } if (this.isSelected) { this.nodeConfiguration.selectedListFontColor !== null ? styles.color = this.nodeConfiguration.selectedListFontColor : styles.color = CONSTANT.DEFAULT_SELECTED_FONT_COLOR; } else if (this.nodeConfiguration.fontColor !== null) { styles.color = this.nodeConfiguration.fontColor; } return styles; } /** * @param {?} node * @return {?} */ getListIcon(node) { if (node.icon !== null && node.icon !== undefined && node.icon !== '') { return `icon`; } else if (node.faIcon !== null && node.faIcon !== undefined && node.faIcon !== '') { return `faicon`; } else if (node.imageIcon !== null && node.imageIcon !== undefined && node.imageIcon !== '') { return `imageicon`; } else if (node.svgIcon !== null && node.svgIcon !== undefined && node.svgIcon !== '') { return `svgicon`; } else { return ``; } } /** * @return {?} */ hasItems() { return this.nodeChildren.length > 0 ? true : false; } /** * @return {?} */ isRtlLayout() { return this.nodeConfiguration.rtlLayout; } /** * @return {?} */ setClasses() { this.classes = { ['level-' + this.level]: true, 'amml-submenu': this.hasItems() && this.getPaddingAtStart() }; } /** * @param {?} node * @return {?} */ expand(node) { this.expanded = !this.expanded; this.firstInitializer = true; this.setClasses(); if (this.nodeConfiguration.interfaceWithRoute !== null && this.nodeConfiguration.interfaceWithRoute && node.link !== undefined && node.link) { if (node.externalRedirect !== undefined && node.externalRedirect) { window.location.href = node.link; } else { this.router.navigate([node.link]); } } else if (node.onSelected && typeof node.onSelected === 'function') { node.onSelected(node); this.selectedListItem(node); } else if (node.items === undefined || this.nodeConfiguration.collapseOnSelect) { this.selectedListItem(node); } } /** * @param {?} node * @return {?} */ selectedListItem(node) { this.selectedItem.emit(node); } } ListItemComponent.decorators = [ { type: Component, args: [{ selector: 'ng-list-item', template: "<mat-list-item matRipple [ngClass]=\"selectedListClasses\" *ngIf=\"!node.hidden\" (click)=\"expand(node)\" title=\"{{node.label}}\"\r\n [ngStyle]=\"getListStyle()\">\r\n <div class=\"anml-data\" [dir]=\"isRtlLayout() ? 'rtl' : 'ltr'\">\r\n <div class=\"icon-container\" [ngSwitch]=\"getListIcon(node)\">\r\n <span *ngSwitchCase=\"'faicon'\" class=\"amml-icon amml-icon-fa\">\r\n <i [ngClass]=\"node.faIcon\"></i>\r\n </span>\r\n <mat-icon *ngSwitchCase=\"'icon'\" class=\"amml-icon\">\r\n {{node.icon}}\r\n </mat-icon>\r\n <mat-icon *ngSwitchCase=\"'svgicon'\" svgIcon=\"{{node.svgIcon}}\" class=\"amml-icon amml-svg-icon\">\r\n </mat-icon>\r\n <img matListAvatar *ngSwitchCase=\"'imageicon'\" class=\"amml-icon\" src=\"{{node.imageIcon}}\" alt=\"{{node.label}}\"/>\r\n </div>\r\n <span class=\"label\">{{node.label}}</span>\r\n </div>\r\n <div class=\"amml-icon-arrow-container\" *ngIf='hasItems()'>\r\n <mat-icon *ngIf='!isRtlLayout()' [@isExpandedLTR]=\"expanded ? 'yes' : 'no'\">\r\n keyboard_arrow_down\r\n </mat-icon>\r\n <mat-icon *ngIf='isRtlLayout()' [@isExpandedRTL]=\"expanded ? 'yes' : 'no'\">\r\n keyboard_arrow_down\r\n </mat-icon>\r\n </div>\r\n</mat-list-item>\r\n\r\n<mat-divider></mat-divider>\r\n\r\n<div *ngIf=\"hasItems() && expanded\" [@slideInOut] [dir]=\"isRtlLayout() ? 'rtl' : 'ltr'\" [ngClass]=\"classes\">\r\n <ng-list-item *ngFor=\"let singleNode of nodeChildren\"\r\n [nodeConfiguration]='nodeConfiguration'\r\n [node]='singleNode'\r\n [level]=\"level + 1\"\r\n [selectedNode]='selectedNode'\r\n (selectedItem)=\"selectedListItem($event)\">\r\n </ng-list-item>\r\n</div>\r\n", animations: [ trigger('slideInOut', [ state('in', style({ height: '*', opacity: 0 })), transition(':leave', [ style({ height: '*', opacity: 0.2 }), group([ animate(200, style({ height: 0 })), animate('200ms ease-out', style({ opacity: 0 })) ]) ]), transition(':enter', [ style({ height: '0', opacity: 0 }), group([ animate(200, style({ height: '*' })), animate('400ms ease-out', style({ opacity: 1 })) ]) ]) ]), trigger('isExpandedLTR', [ state('no', style({ transform: 'rotate(0deg)' })), state('yes', style({ transform: 'rotate(-180deg)', })), transition('no => yes', animate(200)), transition('yes => no', animate(200)) ]), trigger('isExpandedRTL', [ state('no', style({ transform: 'rotate(0deg)' })), state('yes', style({ transform: 'rotate(180deg)', })), transition('no => yes', animate(200)), transition('yes => no', animate(200)) ]) ], styles: [".amml-item{line-height:48px;position:relative;cursor:pointer}.anml-data{width:100%;text-transform:capitalize;display:flex;justify-content:flex-start;height:48px}.amml-icon-fa{font-size:20px}.amml-icon,.label{line-height:48px}.amml-svg-icon{line-height:57px;width:22px;height:22px}.amml-icon-arrow-container{direction:ltr;display:flex;align-items:center}div[dir=ltr] .amml-icon{margin-right:16px}div[dir=ltr].amml-submenu,div[dir=rtl] .amml-icon{margin-left:16px}div[dir=rtl].amml-submenu{margin-right:16px}"] }] } ]; /** @nocollapse */ ListItemComponent.ctorParameters = () => [ { type: Router }, { type: MultilevelMenuService } ]; ListItemComponent.propDecorators = { node: [{ type: Input }], level: [{ type: Input }], selectedNode: [{ type: Input }], nodeConfiguration: [{ type: Input }], selectedItem: [{ type: Output }] }; if (false) { /** @type {?} */ ListItemComponent.prototype.node; /** @type {?} */ ListItemComponent.prototype.level; /** @type {?} */ ListItemComponent.prototype.selectedNode; /** @type {?} */ ListItemComponent.prototype.nodeConfiguration; /** @type {?} */ ListItemComponent.prototype.selectedItem; /** @type {?} */ ListItemComponent.prototype.isSelected; /** @type {?} */ ListItemComponent.prototype.nodeChildren; /** @type {?} */ ListItemComponent.prototype.classes; /** @type {?} */ ListItemComponent.prototype.selectedListClasses; /** @type {?} */ ListItemComponent.prototype.expanded; /** @type {?} */ ListItemComponent.prototype.firstInitializer; /** * @type {?} * @private */ ListItemComponent.prototype.router; /** * @type {?} * @private */ ListItemComponent.prototype.multilevelMenuService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-item.component.js","sourceRoot":"ng://ng-material-multilevel-menu/","sources":["lib/list-item/list-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnChanges, Input, Output, EventEmitter } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { trigger, style, transition, animate, state, group } from '@angular/animations';\r\n\r\nimport { MultilevelMenuService } from './../multilevel-menu.service';\r\n\r\nimport { Configuration, MultilevelNodes, ListStyle } from './../app.model';\r\nimport { CONSTANT } from './../constants';\r\n\r\n@Component({\r\n  selector: 'ng-list-item',\r\n  templateUrl: './list-item.component.html',\r\n  styleUrls: ['./list-item.component.css'],\r\n  animations: [\r\n    trigger('slideInOut', [\r\n      state('in', style({ height: '*', opacity: 0 })),\r\n      transition(':leave', [\r\n        style({ height: '*', opacity: 0.2 }),\r\n        group([\r\n          animate(200, style({ height: 0 })),\r\n          animate('200ms ease-out', style({ opacity: 0 }))\r\n        ])\r\n      ]),\r\n      transition(':enter', [\r\n        style({ height: '0', opacity: 0 }),\r\n        group([\r\n          animate(200, style({ height: '*' })),\r\n          animate('400ms ease-out', style({ opacity: 1 }))\r\n        ])\r\n      ])\r\n    ]),\r\n    trigger('isExpandedLTR', [\r\n      state('no', style({ transform: 'rotate(-90deg)' })),\r\n      state('yes', style({ transform: 'rotate(0deg)', })),\r\n\r\n      transition('no => yes',\r\n        animate(200)\r\n      ),\r\n      transition('yes => no',\r\n        animate(200)\r\n      )\r\n    ]),\r\n    trigger('isExpandedRTL', [\r\n      state('no', style({ transform: 'rotate(90deg)' })),\r\n      state('yes', style({ transform: 'rotate(0deg)', })),\r\n\r\n      transition('no => yes',\r\n        animate(200)\r\n      ),\r\n      transition('yes => no',\r\n        animate(200)\r\n      )\r\n    ])\r\n  ]\r\n})\r\nexport class ListItemComponent implements OnChanges {\r\n  @Input() node: MultilevelNodes;\r\n  @Input() level = 1;\r\n  @Input() selectedNode: MultilevelNodes;\r\n  @Input() nodeConfiguration: Configuration = null;\r\n  @Output() selectedItem = new EventEmitter<MultilevelNodes>();\r\n  isSelected = false;\r\n  nodeChildren: MultilevelNodes[];\r\n  classes: { [index: string]: boolean };\r\n  selectedListClasses: { [index: string]: boolean };\r\n  expanded = false;\r\n  firstInitializer = false;\r\n  constructor(\r\n    private router: Router,\r\n    private multilevelMenuService: MultilevelMenuService\r\n  ) {\r\n    this.selectedListClasses = {\r\n      [CONSTANT.DEFAULT_LIST_CLASS_NAME]: true,\r\n      [CONSTANT.SELECTED_LIST_CLASS_NAME]: false,\r\n      [CONSTANT.ACTIVE_ITEM_CLASS_NAME]: false,\r\n    };\r\n  }\r\n  ngOnChanges() {\r\n    this.nodeChildren = this.node && this.node.items ? this.node.items.filter(n => !n.hidden) : [];\r\n    if (this.selectedNode !== undefined && this.selectedNode !== null) {\r\n      this.setSelectedClass(this.multilevelMenuService.recursiveCheckId(this.node, this.selectedNode.id));\r\n    }\r\n  }\r\n  setSelectedClass(isFound: boolean): void {\r\n    if (isFound) {\r\n      if (!this.firstInitializer) {\r\n        this.expanded = true;\r\n      }\r\n      this.isSelected = this.nodeConfiguration.highlightOnSelect || this.selectedNode.items === undefined ? true : false;\r\n    } else {\r\n      this.isSelected = false;\r\n      if (this.nodeConfiguration.collapseOnSelect) {\r\n        this.expanded = false;\r\n      }\r\n    }\r\n    this.selectedListClasses = {\r\n      [CONSTANT.DEFAULT_LIST_CLASS_NAME]: true,\r\n      [CONSTANT.SELECTED_LIST_CLASS_NAME]: this.isSelected,\r\n      [CONSTANT.ACTIVE_ITEM_CLASS_NAME]: this.selectedNode.id === this.node.id,\r\n    };\r\n    this.setClasses();\r\n  }\r\n  getPaddingAtStart(): boolean {\r\n    return this.nodeConfiguration.paddingAtStart ? true : false;\r\n  }\r\n  getListStyle(): ListStyle {\r\n    const styles = {\r\n      background: CONSTANT.DEFAULT_LIST_BACKGROUND_COLOR,\r\n      color: CONSTANT.DEFAULT_LIST_FONT_COLOR\r\n    };\r\n    if (this.nodeConfiguration.listBackgroundColor !== null) {\r\n      styles.background = this.nodeConfiguration.listBackgroundColor;\r\n    }\r\n    if (this.isSelected) {\r\n      this.nodeConfiguration.selectedListFontColor !== null ?\r\n        styles.color = this.nodeConfiguration.selectedListFontColor : styles.color = CONSTANT.DEFAULT_SELECTED_FONT_COLOR;\r\n    } else if (this.nodeConfiguration.fontColor !== null) {\r\n      styles.color = this.nodeConfiguration.fontColor;\r\n    }\r\n    return styles;\r\n  }\r\n  getListIcon(node: MultilevelNodes): string {\r\n    if (node.icon !== null && node.icon !== undefined && node.icon !== '') {\r\n      return `icon`;\r\n    } else if (node.faIcon !== null && node.faIcon !== undefined && node.faIcon !== '') {\r\n      return `faicon`;\r\n    } else if (node.imageIcon !== null && node.imageIcon !== undefined && node.imageIcon !== '') {\r\n      return `imageicon`;\r\n    } else if (node.svgIcon !== null && node.svgIcon !== undefined && node.svgIcon !== '') {\r\n      return `svgicon`;\r\n    } else {\r\n      return ``;\r\n    }\r\n  }\r\n  hasItems(): boolean {\r\n    return this.nodeChildren.length > 0 ? true : false;\r\n  }\r\n  isRtlLayout(): boolean {\r\n    return this.nodeConfiguration.rtlLayout;\r\n  }\r\n  setClasses(): void {\r\n    this.classes = {\r\n      ['level-' + this.level]: true,\r\n      'amml-submenu': this.hasItems() && this.getPaddingAtStart()\r\n    };\r\n  }\r\n  expand(node: MultilevelNodes): void {\r\n    this.expanded = !this.expanded;\r\n    this.firstInitializer = true;\r\n    this.setClasses();\r\n    if (this.nodeConfiguration.interfaceWithRoute !== null\r\n      && this.nodeConfiguration.interfaceWithRoute\r\n      && node.link !== undefined\r\n      && node.link\r\n    ) {\r\n      if (node.externalRedirect !== undefined && node.externalRedirect) {\r\n        window.location.href = node.link;\r\n      } else {\r\n        this.router.navigate([node.link]);\r\n      }\r\n    } else if (node.onSelected && typeof node.onSelected === 'function') {\r\n      node.onSelected(node);\r\n      this.selectedListItem(node);\r\n    } else if (node.items === undefined || this.nodeConfiguration.collapseOnSelect) {\r\n      this.selectedListItem(node);\r\n    }\r\n  }\r\n  selectedListItem(node: MultilevelNodes): void {\r\n    this.selectedItem.emit(node);\r\n  }\r\n}\r\n"]}