@cause-911/material
Version:
Run `npm install @cause-911/material --save` to add this library to your project
168 lines • 14.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, HostListener, Input } from '@angular/core';
export class MenuSidebarComponent {
/**
* @param {?} element
*/
constructor(element) {
this.menuItems = [];
this.version = '';
this.keepMenuExpanded = false;
this.hostElement = (/** @type {?} */ (element.nativeElement));
this.hostElement.addEventListener('mouseover', (/**
* @param {?} e
* @return {?}
*/
(e) => this.onMouseOver(e)));
this.hostElement.addEventListener('mouseout', (/**
* @param {?} e
* @return {?}
*/
(e) => this.onMouseOut(e)));
this.setDisplayMenu();
}
/**
* @return {?}
*/
ngOnInit() {
}
/**
* @param {?} e
* @return {?}
*/
onResize(e) {
this.setDisplayMenu();
}
/**
* @return {?}
*/
onMenuItemClick() {
if (window.innerWidth < 1000) {
this.hideOnMobile();
}
}
/**
* @return {?}
*/
hideOnMobile() {
this.hostElement.classList.remove('mobile');
this.hostElement.classList.add('hidden');
}
/**
* @return {?}
*/
showOnMobile() {
this.hostElement.classList.remove('hidden');
this.hostElement.classList.add('mobile');
}
/**
* @return {?}
*/
onToggleCollapse() {
if (this.keepMenuExpanded) {
this.onCollpseMenu();
this.hostElement.classList.remove('keepExpanded');
}
else {
this.onExpandedMenu();
this.hostElement.classList.add('keepExpanded');
}
this.keepMenuExpanded = !this.keepMenuExpanded;
localStorage.setItem('cause-menu-status', this.keepMenuExpanded ? 'expanded' : 'collapsed');
}
/**
* @private
* @return {?}
*/
setDisplayMenu() {
this.hostElement.className = '';
if (window.innerWidth < 1000) {
this.hostElement.classList.add('hidden');
}
else {
if (localStorage.getItem('cause-menu-status') === 'expanded') {
this.keepMenuExpanded = true;
this.hostElement.classList.add('keepExpanded');
}
this.hostElement.classList.add(this.keepMenuExpanded ? 'expanded' : 'collapsed');
}
}
/**
* @private
* @param {?} e
* @return {?}
*/
onMouseOver(e) {
if (!this.keepMenuExpanded) {
this.onExpandedMenu();
}
e.stopPropagation();
}
/**
* @private
* @param {?} e
* @return {?}
*/
onMouseOut(e) {
if (!this.keepMenuExpanded) {
this.onCollpseMenu();
}
e.stopPropagation();
}
/**
* @private
* @return {?}
*/
onExpandedMenu() {
if (window.innerWidth >= 1000) {
this.hostElement.classList.remove('collapsed');
this.hostElement.classList.add('expanded');
}
}
/**
* @private
* @return {?}
*/
onCollpseMenu() {
if (window.innerWidth >= 1000) {
this.hostElement.classList.remove('expanded');
this.hostElement.classList.add('collapsed');
}
}
}
MenuSidebarComponent.decorators = [
{ type: Component, args: [{
selector: 'cause-menu-sidebar',
template: "<div>\n <button mat-icon-button class=\"close\" (click)=\"hideOnMobile()\">\n <mat-icon>clear</mat-icon>\n </button>\n <ng-content select=\"[header]\"></ng-content>\n</div>\n<div>\n <ng-content select=\"[beforeMenu]\"></ng-content>\n <cause-menu-vertical #menu [menuItems]=\"menuItems\" (itemClick)=\"onMenuItemClick()\"></cause-menu-vertical>\n <ng-content select=\"[afterMenu]\"></ng-content>\n</div>\n<div *ngIf=\"version\" class=\"version\">\n <div class=\"double-arrow\" (click)=\"onToggleCollapse()\"></div>\n <span class=\"full\">{{'material.version' | translate}} {{version}}</span>\n <span class=\"abbr\">{{version}}</span>\n</div>\n",
styles: [":host{height:100%;flex-direction:column;display:flex;transition:.1s ease-out;overflow:hidden;scrollbar-width:5px;scrollbar-color:rgba(0,0,0,.1) rgba(0,0,0,.2)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{border-radius:5px;-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.1)}::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(0,0,0,.2);outline:#708090 solid 1px}:host>div{flex:1}:host>div:first-child{flex:0 0 auto}:host>div:nth-child(2){flex-grow:1;overflow:hidden auto}:host>div:last-child{max-height:1em}:host.hidden{width:0;min-width:0;max-width:0}:host.mobile{width:275px;min-width:275px;max-width:275px;position:absolute;z-index:10}:host.collapsed{width:75px;min-width:75px;max-width:75px}:host.expanded{width:275px;min-width:275px;max-width:275px}:host .close{display:none}:host.mobile .close{right:0;display:inline-block;position:absolute}.double-arrow{height:2.9em;line-height:2.9em;cursor:pointer;position:absolute;opacity:.25;margin-top:-1em}.double-arrow:hover{opacity:1}:host.collapsed .double-arrow:before,:host.expanded .double-arrow:before{font-family:\"Material Icons\";content:\"double_arrow\";font-size:2.9em;text-align:right}:host.collapsed .double-arrow{margin-left:10px}:host.expanded .double-arrow{margin-left:200px}:host.collapsed ::ng-deep .menu-caption,:host.collapsed ::ng-deep .submenu{display:none}:host.keepExpanded .double-arrow{transform:rotate(180deg);opacity:1}.version{bottom:0;padding:1em}.abbr,.full{display:none}:host.collapsed .abbr{display:inline}:host.expanded .full,:host.mobile .full{display:inline}@media only screen and (max-width:1000px){.double-arrow{display:none}}"]
}] }
];
/** @nocollapse */
MenuSidebarComponent.ctorParameters = () => [
{ type: ElementRef }
];
MenuSidebarComponent.propDecorators = {
menuItems: [{ type: Input }],
version: [{ type: Input }],
onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
};
if (false) {
/** @type {?} */
MenuSidebarComponent.prototype.menuItems;
/** @type {?} */
MenuSidebarComponent.prototype.version;
/**
* @type {?}
* @private
*/
MenuSidebarComponent.prototype.hostElement;
/**
* @type {?}
* @private
*/
MenuSidebarComponent.prototype.keepMenuExpanded;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-sidebar.component.js","sourceRoot":"ng://@cause-911/material/","sources":["lib/menu-sidebar/menu-sidebar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {MenuItem} from '../shared/models/menu-item';\nimport {BreakpointObserver} from '@angular/cdk/layout';\n\n@Component({\n    selector: 'cause-menu-sidebar',\n    templateUrl: './menu-sidebar.component.html',\n    styleUrls: ['./menu-sidebar.component.scss']\n})\nexport class MenuSidebarComponent implements OnInit {\n    @Input() menuItems: MenuItem[] = [];\n    @Input() version = '';\n\n    private hostElement: HTMLDivElement;\n    private keepMenuExpanded = false;\n\n    constructor(element: ElementRef) {\n        this.hostElement = element.nativeElement as HTMLDivElement;\n        this.hostElement.addEventListener('mouseover', (e) => this.onMouseOver(e));\n        this.hostElement.addEventListener('mouseout', (e) => this.onMouseOut(e));\n\n        this.setDisplayMenu();\n    }\n\n    ngOnInit() {\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(e) {\n        this.setDisplayMenu();\n    }\n\n    onMenuItemClick() {\n        if (window.innerWidth < 1000) {\n            this.hideOnMobile();\n        }\n    }\n\n    hideOnMobile() {\n        this.hostElement.classList.remove('mobile');\n        this.hostElement.classList.add('hidden');\n    }\n\n    showOnMobile() {\n        this.hostElement.classList.remove('hidden');\n        this.hostElement.classList.add('mobile');\n    }\n\n    onToggleCollapse() {\n        if (this.keepMenuExpanded) {\n            this.onCollpseMenu();\n            this.hostElement.classList.remove('keepExpanded');\n        } else {\n            this.onExpandedMenu();\n            this.hostElement.classList.add('keepExpanded');\n        }\n\n        this.keepMenuExpanded = !this.keepMenuExpanded;\n        localStorage.setItem('cause-menu-status', this.keepMenuExpanded ? 'expanded' : 'collapsed');\n    }\n\n    private setDisplayMenu() {\n        this.hostElement.className = '';\n\n        if (window.innerWidth < 1000) {\n            this.hostElement.classList.add('hidden');\n        } else {\n            if (localStorage.getItem('cause-menu-status') === 'expanded') {\n                this.keepMenuExpanded = true;\n                this.hostElement.classList.add('keepExpanded');\n            }\n\n            this.hostElement.classList.add(this.keepMenuExpanded ? 'expanded' : 'collapsed');\n        }\n    }\n\n    private onMouseOver(e) {\n        if (!this.keepMenuExpanded) {\n            this.onExpandedMenu();\n        }\n\n        e.stopPropagation();\n    }\n\n    private onMouseOut(e) {\n        if (!this.keepMenuExpanded) {\n            this.onCollpseMenu();\n        }\n\n        e.stopPropagation();\n    }\n\n    private onExpandedMenu() {\n        if (window.innerWidth >= 1000) {\n            this.hostElement.classList.remove('collapsed');\n            this.hostElement.classList.add('expanded');\n        }\n    }\n\n    private onCollpseMenu() {\n        if (window.innerWidth >= 1000) {\n            this.hostElement.classList.remove('expanded');\n            this.hostElement.classList.add('collapsed');\n        }\n    }\n}\n"]}