UNPKG

@nebular/theme

Version:
83 lines 3.2 kB
/** * @license * Copyright Akveo. All Rights Reserved. * Licensed under the MIT License. See License.txt in the project root for license information. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; import { Injectable } from '@angular/core'; import { Subject } from 'rxjs'; import { share } from 'rxjs/operators'; /** * Sidebar service. * * Root module service to control the sidebar from any part of the app. * * Allows you to change sidebar state dynamically from any part of the app: * @stacked-example(Sidebar State, sidebar/sidebar-toggle.component) */ var NbSidebarService = /** @class */ (function () { function NbSidebarService() { this.toggle$ = new Subject(); this.expand$ = new Subject(); this.collapse$ = new Subject(); } /** * Subscribe to toggle events * * @returns Observable<{ compact: boolean, tag: string }> */ NbSidebarService.prototype.onToggle = function () { return this.toggle$.pipe(share()); }; /** * Subscribe to expand events * @returns Observable<{ tag: string }> */ NbSidebarService.prototype.onExpand = function () { return this.expand$.pipe(share()); }; /** * Subscribe to collapse evens * @returns Observable<{ tag: string }> */ NbSidebarService.prototype.onCollapse = function () { return this.collapse$.pipe(share()); }; /** * Toggle a sidebar * @param {boolean} compact * @param {string} tag If you have multiple sidebars on the page, mark them with `tag` input property and pass it here * to specify which sidebar you want to control */ NbSidebarService.prototype.toggle = function (compact, tag) { if (compact === void 0) { compact = false; } this.toggle$.next({ compact: compact, tag: tag }); }; /** * Expands a sidebar * @param {string} tag If you have multiple sidebars on the page, mark them with `tag` input property and pass it here * to specify which sidebar you want to control */ NbSidebarService.prototype.expand = function (tag) { this.expand$.next({ tag: tag }); }; /** * Collapses a sidebar * @param {string} tag If you have multiple sidebars on the page, mark them with `tag` input property and pass it here * to specify which sidebar you want to control */ NbSidebarService.prototype.collapse = function (tag) { this.collapse$.next({ tag: tag }); }; NbSidebarService = __decorate([ Injectable() ], NbSidebarService); return NbSidebarService; }()); export { NbSidebarService }; //# sourceMappingURL=sidebar.service.js.map