| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | // #docregion
 | 
					
						
							| 
									
										
										
										
											2016-05-03 14:06:32 +02:00
										 |  |  | import { Component, Directive, Input, QueryList, | 
					
						
							|  |  |  |         ViewContainerRef, TemplateRef, ContentChildren } from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | @Directive({ | 
					
						
							| 
									
										
										
										
											2016-06-13 00:41:33 +02:00
										 |  |  |   selector: '[uiPane]' | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | }) | 
					
						
							| 
									
										
										
										
											2016-06-13 00:41:33 +02:00
										 |  |  | export class UiPaneDirective { | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  |   @Input() title: string; | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |   private _active: boolean = false; | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   constructor(public viewContainer: ViewContainerRef, | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |               public templateRef: TemplateRef<any>) { } | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @Input() set active(active: boolean) { | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |     if (active === this._active) { return; } | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  |     this._active = active; | 
					
						
							|  |  |  |     if (active) { | 
					
						
							|  |  |  |       this.viewContainer.createEmbeddedView(this.templateRef); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       this.viewContainer.remove(0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get active(): boolean { | 
					
						
							|  |  |  |     return this._active; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'ui-tabs', | 
					
						
							|  |  |  |   template: `
 | 
					
						
							|  |  |  |     <ul class="nav nav-tabs"> | 
					
						
							| 
									
										
										
										
											2016-04-29 01:36:35 +01:00
										 |  |  |       <li *ngFor="let pane of panes" | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  |           (click)="select(pane)" | 
					
						
							|  |  |  |           role="presentation" [class.active]="pane.active"> | 
					
						
							| 
									
										
										
										
											2016-01-22 02:40:37 -08:00
										 |  |  |         <a>{{pane.title}}</a> | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  |       </li> | 
					
						
							|  |  |  |     </ul> | 
					
						
							|  |  |  |     <ng-content></ng-content> | 
					
						
							| 
									
										
										
										
											2016-01-22 02:40:37 -08:00
										 |  |  |     `,
 | 
					
						
							| 
									
										
										
										
											2016-04-27 11:28:22 -07:00
										 |  |  |     styles: ['a { cursor: pointer; cursor: hand; }'] | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | }) | 
					
						
							| 
									
										
										
										
											2016-06-13 00:41:33 +02:00
										 |  |  | export class UiTabsComponent { | 
					
						
							|  |  |  |   @ContentChildren(UiPaneDirective) panes: QueryList<UiPaneDirective>; | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-13 00:41:33 +02:00
										 |  |  |   select(pane: UiPaneDirective) { | 
					
						
							|  |  |  |     this.panes.toArray().forEach((p: UiPaneDirective) => p.active = p === pane); | 
					
						
							| 
									
										
										
										
											2015-12-15 12:34:29 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 |