@cause-911/material
Version:
Run `npm install @cause-911/material --save` to add this library to your project
209 lines • 16.2 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';
var MenuSidebarComponent = /** @class */ (function () {
function MenuSidebarComponent(element) {
var _this = this;
this.menuItems = [];
this.version = '';
this.keepMenuExpanded = false;
this.hostElement = (/** @type {?} */ (element.nativeElement));
this.hostElement.addEventListener('mouseover', (/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.onMouseOver(e); }));
this.hostElement.addEventListener('mouseout', (/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.onMouseOut(e); }));
this.setDisplayMenu();
}
/**
* @return {?}
*/
MenuSidebarComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
};
/**
* @param {?} e
* @return {?}
*/
MenuSidebarComponent.prototype.onResize = /**
* @param {?} e
* @return {?}
*/
function (e) {
this.setDisplayMenu();
};
/**
* @return {?}
*/
MenuSidebarComponent.prototype.onMenuItemClick = /**
* @return {?}
*/
function () {
if (window.innerWidth < 1000) {
this.hideOnMobile();
}
};
/**
* @return {?}
*/
MenuSidebarComponent.prototype.hideOnMobile = /**
* @return {?}
*/
function () {
this.hostElement.classList.remove('mobile');
this.hostElement.classList.add('hidden');
};
/**
* @return {?}
*/
MenuSidebarComponent.prototype.showOnMobile = /**
* @return {?}
*/
function () {
this.hostElement.classList.remove('hidden');
this.hostElement.classList.add('mobile');
};
/**
* @return {?}
*/
MenuSidebarComponent.prototype.onToggleCollapse = /**
* @return {?}
*/
function () {
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 {?}
*/
MenuSidebarComponent.prototype.setDisplayMenu = /**
* @private
* @return {?}
*/
function () {
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 {?}
*/
MenuSidebarComponent.prototype.onMouseOver = /**
* @private
* @param {?} e
* @return {?}
*/
function (e) {
if (!this.keepMenuExpanded) {
this.onExpandedMenu();
}
e.stopPropagation();
};
/**
* @private
* @param {?} e
* @return {?}
*/
MenuSidebarComponent.prototype.onMouseOut = /**
* @private
* @param {?} e
* @return {?}
*/
function (e) {
if (!this.keepMenuExpanded) {
this.onCollpseMenu();
}
e.stopPropagation();
};
/**
* @private
* @return {?}
*/
MenuSidebarComponent.prototype.onExpandedMenu = /**
* @private
* @return {?}
*/
function () {
if (window.innerWidth >= 1000) {
this.hostElement.classList.remove('collapsed');
this.hostElement.classList.add('expanded');
}
};
/**
* @private
* @return {?}
*/
MenuSidebarComponent.prototype.onCollpseMenu = /**
* @private
* @return {?}
*/
function () {
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 = function () { return [
{ type: ElementRef }
]; };
MenuSidebarComponent.propDecorators = {
menuItems: [{ type: Input }],
version: [{ type: Input }],
onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
};
return MenuSidebarComponent;
}());
export { MenuSidebarComponent };
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"]}