Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 1 | import * as $ from 'jquery'; |
Matteo Scandolo | 4222a43 | 2017-01-23 12:18:40 -0800 | [diff] [blame] | 2 | import {IXosComponentInjectorService} from '../services/helpers/component-injector.helpers'; |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 3 | |
| 4 | export interface IXosSidePanelService { |
| 5 | open(): void; |
| 6 | close(): void; |
| 7 | injectComponent(componentName: string, attributes?: any, transclude?: string): void; |
Matteo Scandolo | 5053cbe | 2017-01-31 17:37:56 -0800 | [diff] [blame] | 8 | removeInjectedComponents(): void; |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 9 | } |
| 10 | |
| 11 | export class XosSidePanel implements IXosSidePanelService { |
Matteo Scandolo | 5053cbe | 2017-01-31 17:37:56 -0800 | [diff] [blame] | 12 | static $inject = ['$rootScope', '$compile', '$timeout', 'XosComponentInjector']; |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 13 | public sidePanelElName = 'xos-side-panel'; |
| 14 | public sidePanelElClass = '.xos-side-panel'; |
| 15 | public sidePanelEl: JQuery; |
| 16 | |
| 17 | constructor ( |
| 18 | private $rootScope: ng.IRootScopeService, |
Matteo Scandolo | 4222a43 | 2017-01-23 12:18:40 -0800 | [diff] [blame] | 19 | private $compile: ng.ICompileService, |
Matteo Scandolo | 5053cbe | 2017-01-31 17:37:56 -0800 | [diff] [blame] | 20 | private $timeout: ng.ITimeoutService, |
Matteo Scandolo | 4222a43 | 2017-01-23 12:18:40 -0800 | [diff] [blame] | 21 | private XosComponentInjector: IXosComponentInjectorService |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 22 | ) { |
| 23 | this.sidePanelEl = $(`${this.sidePanelElName} > ${this.sidePanelElClass}`); |
| 24 | } |
| 25 | |
| 26 | public open() { |
| 27 | $(`${this.sidePanelElName} > ${this.sidePanelElClass}`).addClass('open'); |
| 28 | }; |
| 29 | |
| 30 | public close() { |
| 31 | $(`${this.sidePanelElName} > ${this.sidePanelElClass}`).removeClass('open'); |
| 32 | }; |
| 33 | |
| 34 | public injectComponent(componentName: string, attributes?: any, transclude?: string) { |
Matteo Scandolo | 4222a43 | 2017-01-23 12:18:40 -0800 | [diff] [blame] | 35 | this.XosComponentInjector.injectComponent('#side-panel-container', componentName, attributes, transclude, true); |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 36 | this.open(); |
| 37 | } |
Matteo Scandolo | 5053cbe | 2017-01-31 17:37:56 -0800 | [diff] [blame] | 38 | |
| 39 | public removeInjectedComponents() { |
| 40 | this.close(); |
| 41 | this.$timeout(() => { |
| 42 | this.XosComponentInjector.removeInjectedComponents('#side-panel-container'); |
| 43 | }, 500); |
| 44 | } |
Matteo Scandolo | 9d7940c | 2017-01-19 18:28:43 -0800 | [diff] [blame] | 45 | } |