UNPKG

@cause-911/material

Version:

Run `npm install @cause-911/material --save` to add this library to your project

209 lines 16.2 kB
/** * @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"]}