Socket
Socket
Sign inDemoInstall

ngc-scrolling-tabs

Package Overview
Dependencies
10
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.0.6 to 1.0.7

21

bundles/ngc-scrolling-tabs.umd.js

@@ -217,3 +217,2 @@ (function (global, factory) {

this.trackOpenTab = true;
this.scrollBarWidths = 52;
this.selectedTabChanged = new core.EventEmitter();

@@ -238,3 +237,3 @@ this.tabs = [];

function () {
// if there is a param of tabId and we want to track open tabs, mark the open tab as active
// if there is a param of tabId and we want to track open tabs mark the open tab as active
if (_this.route.snapshot.queryParams.tabId && _this.trackOpenTab) {

@@ -246,3 +245,4 @@ _this.markTabAsActive(_this.route.snapshot.queryParams.tabId);

}
if (_this.scrollToActive) {
// scroll to the active tab if setting is true and the tabs are larger than the window
if (_this.scrollToActive && _this.hasHiddenTabs()) {
_this.scrollToActiveTab();

@@ -410,3 +410,2 @@ }

this.firstVisibleTabIndex = activeTab;
// change the view to set the active tab as first tab on the left
for (var i = 0; i < activeTab; i++) {

@@ -419,2 +418,11 @@ if (this.tabList.nativeElement.children[i]) {

/**
* @return {?}
*/
ScrollingTabsComponent.prototype.hasHiddenTabs = /**
* @return {?}
*/
function () {
return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;
};
/**
* @param {?} tabId

@@ -468,3 +476,3 @@ * @return {?}

changeDetection: core.ChangeDetectionStrategy.OnPush,
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
}] }

@@ -484,3 +492,2 @@ ];

trackOpenTab: [{ type: core.Input }],
scrollBarWidths: [{ type: core.Input }],
selectedTabChanged: [{ type: core.Output }],

@@ -503,4 +510,2 @@ windowResize: [{ type: core.HostListener, args: ['window:resize',] }]

/** @type {?} */
ScrollingTabsComponent.prototype.scrollBarWidths;
/** @type {?} */
ScrollingTabsComponent.prototype.selectedTabChanged;

@@ -507,0 +512,0 @@ /** @type {?} */

@@ -15,3 +15,3 @@ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/router"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngc-scrolling-tabs",["exports","@angular/core","@angular/router","@angular/common"],e):e((t=t||self)["ngc-scrolling-tabs"]={},t.ng.core,t.ng.router,t.ng.common)}(this,(function(t,e,r,i){"use strict";

and limitations under the License.
***************************************************************************** */function n(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}}var a=function(){function t(t,r,i){this.changeDetector=t,this.route=r,this.router=i,this.firstTabActive=!0,this.scrollToActive=!0,this.trackOpenTab=!0,this.scrollBarWidths=52,this.selectedTabChanged=new e.EventEmitter,this.tabs=[],this.leftOffset=0,this.firstVisibleTabIndex=-1,this.showLeftArrow=!1,this.showRightArrow=!1}return t.prototype.ngAfterViewInit=function(){var t=this;setTimeout((function(){t.route.snapshot.queryParams.tabId&&t.trackOpenTab?t.markTabAsActive(t.route.snapshot.queryParams.tabId):t.firstTabActive&&t.markFirstTabActive(),t.scrollToActive&&t.scrollToActiveTab(),t.redrawTabs(),t.changeDetector.detectChanges()}),0)},t.prototype.addTab=function(t){this.tabs.push(t)},t.prototype.removeTab=function(t){var e=this.tabs.indexOf(t);-1!==e&&this.tabs.splice(e,1)},t.prototype.windowResize=function(){this.redrawTabs()},t.prototype.redrawTabs=function(){this.widthOfList()+this.leftOffset>this.navWrapper.nativeElement.offsetWidth?this.showRightArrow=!0:this.showRightArrow=!1,this.leftOffset<0?this.showLeftArrow=!0:this.showLeftArrow=!1},t.prototype.widthOfList=function(){var t,e,r=0;try{for(var i=n(this.tabList.nativeElement.children),a=i.next();!a.done;a=i.next()){r+=a.value.offsetWidth}}catch(e){t={error:e}}finally{try{a&&!a.done&&(e=i.return)&&e.call(i)}finally{if(t)throw t.error}}return r},t.prototype.onScrollerLeftClick=function(){this.firstVisibleTabIndex--,this.leftOffset+=this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth,this.redrawTabs()},t.prototype.onScrollerRightClick=function(){this.leftOffset-=this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth,this.firstVisibleTabIndex++,this.redrawTabs()},t.prototype.onSelectedTabChanged=function(t){this.markTabAsActive(t.id),this.trackOpenTab&&this.pushCurrentTabToParam(t),this.selectedTabChanged.emit(t)},t.prototype.markFirstTabActive=function(){!this.tabs.find((function(t){return t.active}))&&this.tabs.length>0&&(this.tabs[0].active=!0)},t.prototype.scrollToActiveTab=function(){var t=this.tabs.findIndex((function(t){return t.active}));this.firstVisibleTabIndex=t;for(var e=0;e<t;e++)this.tabList.nativeElement.children[e]&&(this.leftOffset-=this.tabList.nativeElement.children[e].offsetWidth)},t.prototype.markTabAsActive=function(t){var e,r;try{for(var i=n(this.tabs),a=i.next();!a.done;a=i.next()){var s=a.value;s.active=!1,s.id===t&&(s.active=!0)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(e)throw e.error}}},t.prototype.pushCurrentTabToParam=function(t){this.router.navigate([],{relativeTo:this.route,queryParams:{tabId:t.id},queryParamsHandling:"merge"})},t.decorators=[{type:e.Component,args:[{selector:"ngc-scrolling-tabs",template:'<div class="wrap-selector">\n <div class="nav-tabs-boxed">\n <div class="scroller scroller-left" (click)="onScrollerLeftClick()" *ngIf="showLeftArrow">\n <svg class="arrow-img" xmlns="http://www.w3.org/2000/svg" version="1.0" width="157.000000pt" height="263.000000pt"\n viewBox="0 0 157.000000 263.000000" preserveAspectRatio="xMidYMid meet">\n <g transform="translate(0.000000,263.000000) scale(0.100000,-0.100000)" fill="currentColor" stroke="none">\n <path d="M653 1967 l-603 -602 0 -45 0 -45 603 -602 c710 -711 628 -655 764 -520 79 79 83 85 83 127 l0 45 -497 497 -498 498 498 498 497 497 0 45 c0 42 -4 48 -83 127 -136 135 -54 191 -764 -520z" />\n </g>\n </svg>\n </div>\n <div class="scroller scroller-right" (click)="onScrollerRightClick()" *ngIf="showRightArrow">\n <svg class="arrow-img" xmlns="http://www.w3.org/2000/svg" version="1.0" width="157.000000pt" height="263.000000pt"\n viewBox="0 0 157.000000 263.000000" preserveAspectRatio="xMidYMid meet">\n <g transform="translate(0.000000,263.000000) scale(0.100000,-0.100000)" fill="currentColor" stroke="none">\n <path d="M153 2477 c-79 -79 -83 -85 -83 -127 l0 -45 497 -497 498 -498 -498 -498 -497 -497 0 -45 c0 -42 4 -48 83 -127 136 -135 54 -191 764 520 l603 602 0 45 0 45 -603 602 c-710 711 -628 655 -764 520z" />\n </g>\n </svg>\n </div>\n <div class="nav-wrapper" #navWrapper>\n <ul class="nav nav-tabs list" role="tablist" #tabList [style.left.px]="leftOffset">\n <li *ngFor="let tab of tabs" class="nav-item">\n <a [ngClass]="tab.getTabClasses()" data-toggle="tab" href="javascript:void(0)" role="tab"\n attr.aria-controls="{{tab.title}}" (click)="onSelectedTabChanged(tab)">{{tab.title}}</a>\n </li>\n </ul>\n </div>\n <div class="tab-content">\n <ng-content></ng-content>\n </div>\n </div>\n</div>',changeDetection:e.ChangeDetectionStrategy.OnPush,styles:[".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]}]}],t.ctorParameters=function(){return[{type:e.ChangeDetectorRef},{type:r.ActivatedRoute},{type:r.Router}]},t.propDecorators={navWrapper:[{type:e.ViewChild,args:["navWrapper",{static:!1}]}],tabList:[{type:e.ViewChild,args:["tabList",{static:!1}]}],firstTabActive:[{type:e.Input}],scrollToActive:[{type:e.Input}],trackOpenTab:[{type:e.Input}],scrollBarWidths:[{type:e.Input}],selectedTabChanged:[{type:e.Output}],windowResize:[{type:e.HostListener,args:["window:resize"]}]},t}();var s=function(){function t(t,e,r){this.tabs=t,this.elementRef=e,this.renderer=r,this.active=!1}return t.prototype.ngOnInit=function(){this.tabs.addTab(this),this.renderer.addClass(this.elementRef.nativeElement,"tab-pane"),this.renderer.setAttribute(this.elementRef.nativeElement,"role","tabpanel")},t.prototype.ngOnDestroy=function(){this.tabs.removeTab(this)},t.prototype.getTabClasses=function(){return{"nav-link":!0,active:this.active}},t.decorators=[{type:e.Directive,args:[{selector:"[ngcScrollingTab], ngcScrollingTab"}]}],t.ctorParameters=function(){return[{type:a},{type:e.ElementRef},{type:e.Renderer2}]},t.propDecorators={id:[{type:e.Input}],title:[{type:e.Input}],active:[{type:e.HostBinding,args:["class.active"]},{type:e.Input}]},t}();var o=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{imports:[i.CommonModule],declarations:[a,s],exports:[a,s]}]}],t}();t.ScrollingTabsComponent=a,t.ScrollingTabsModule=o,t.ɵa=s,Object.defineProperty(t,"__esModule",{value:!0})}));
***************************************************************************** */function n(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}}var a=function(){function t(t,r,i){this.changeDetector=t,this.route=r,this.router=i,this.firstTabActive=!0,this.scrollToActive=!0,this.trackOpenTab=!0,this.selectedTabChanged=new e.EventEmitter,this.tabs=[],this.leftOffset=0,this.firstVisibleTabIndex=-1,this.showLeftArrow=!1,this.showRightArrow=!1}return t.prototype.ngAfterViewInit=function(){var t=this;setTimeout((function(){t.route.snapshot.queryParams.tabId&&t.trackOpenTab?t.markTabAsActive(t.route.snapshot.queryParams.tabId):t.firstTabActive&&t.markFirstTabActive(),t.scrollToActive&&t.hasHiddenTabs()&&t.scrollToActiveTab(),t.redrawTabs(),t.changeDetector.detectChanges()}),0)},t.prototype.addTab=function(t){this.tabs.push(t)},t.prototype.removeTab=function(t){var e=this.tabs.indexOf(t);-1!==e&&this.tabs.splice(e,1)},t.prototype.windowResize=function(){this.redrawTabs()},t.prototype.redrawTabs=function(){this.widthOfList()+this.leftOffset>this.navWrapper.nativeElement.offsetWidth?this.showRightArrow=!0:this.showRightArrow=!1,this.leftOffset<0?this.showLeftArrow=!0:this.showLeftArrow=!1},t.prototype.widthOfList=function(){var t,e,r=0;try{for(var i=n(this.tabList.nativeElement.children),a=i.next();!a.done;a=i.next()){r+=a.value.offsetWidth}}catch(e){t={error:e}}finally{try{a&&!a.done&&(e=i.return)&&e.call(i)}finally{if(t)throw t.error}}return r},t.prototype.onScrollerLeftClick=function(){this.firstVisibleTabIndex--,this.leftOffset+=this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth,this.redrawTabs()},t.prototype.onScrollerRightClick=function(){this.leftOffset-=this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth,this.firstVisibleTabIndex++,this.redrawTabs()},t.prototype.onSelectedTabChanged=function(t){this.markTabAsActive(t.id),this.trackOpenTab&&this.pushCurrentTabToParam(t),this.selectedTabChanged.emit(t)},t.prototype.markFirstTabActive=function(){!this.tabs.find((function(t){return t.active}))&&this.tabs.length>0&&(this.tabs[0].active=!0)},t.prototype.scrollToActiveTab=function(){var t=this.tabs.findIndex((function(t){return t.active}));this.firstVisibleTabIndex=t;for(var e=0;e<t;e++)this.tabList.nativeElement.children[e]&&(this.leftOffset-=this.tabList.nativeElement.children[e].offsetWidth)},t.prototype.hasHiddenTabs=function(){return this.widthOfList()>this.navWrapper.nativeElement.offsetWidth},t.prototype.markTabAsActive=function(t){var e,r;try{for(var i=n(this.tabs),a=i.next();!a.done;a=i.next()){var s=a.value;s.active=!1,s.id===t&&(s.active=!0)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(e)throw e.error}}},t.prototype.pushCurrentTabToParam=function(t){this.router.navigate([],{relativeTo:this.route,queryParams:{tabId:t.id},queryParamsHandling:"merge"})},t.decorators=[{type:e.Component,args:[{selector:"ngc-scrolling-tabs",template:'<div class="wrap-selector">\n <div class="nav-tabs-boxed">\n <div class="scroller scroller-left" (click)="onScrollerLeftClick()" *ngIf="showLeftArrow">\n <svg class="arrow-img" xmlns="http://www.w3.org/2000/svg" version="1.0" width="157.000000pt" height="263.000000pt"\n viewBox="0 0 157.000000 263.000000" preserveAspectRatio="xMidYMid meet">\n <g transform="translate(0.000000,263.000000) scale(0.100000,-0.100000)" fill="currentColor" stroke="none">\n <path d="M653 1967 l-603 -602 0 -45 0 -45 603 -602 c710 -711 628 -655 764 -520 79 79 83 85 83 127 l0 45 -497 497 -498 498 498 498 497 497 0 45 c0 42 -4 48 -83 127 -136 135 -54 191 -764 -520z" />\n </g>\n </svg>\n </div>\n <div class="scroller scroller-right" (click)="onScrollerRightClick()" *ngIf="showRightArrow">\n <svg class="arrow-img" xmlns="http://www.w3.org/2000/svg" version="1.0" width="157.000000pt" height="263.000000pt"\n viewBox="0 0 157.000000 263.000000" preserveAspectRatio="xMidYMid meet">\n <g transform="translate(0.000000,263.000000) scale(0.100000,-0.100000)" fill="currentColor" stroke="none">\n <path d="M153 2477 c-79 -79 -83 -85 -83 -127 l0 -45 497 -497 498 -498 -498 -498 -497 -497 0 -45 c0 -42 4 -48 83 -127 136 -135 54 -191 764 520 l603 602 0 45 0 45 -603 602 c-710 711 -628 655 -764 520z" />\n </g>\n </svg>\n </div>\n <div class="nav-wrapper" #navWrapper>\n <ul class="nav nav-tabs list" role="tablist" #tabList [style.left.px]="leftOffset">\n <li *ngFor="let tab of tabs" class="nav-item">\n <a [ngClass]="tab.getTabClasses()" data-toggle="tab" href="javascript:void(0)" role="tab"\n attr.aria-controls="{{tab.title}}" (click)="onSelectedTabChanged(tab)">{{tab.title}}</a>\n </li>\n </ul>\n </div>\n <div class="tab-content">\n <ng-content></ng-content>\n </div>\n </div>\n</div>',changeDetection:e.ChangeDetectionStrategy.OnPush,styles:[".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]}]}],t.ctorParameters=function(){return[{type:e.ChangeDetectorRef},{type:r.ActivatedRoute},{type:r.Router}]},t.propDecorators={navWrapper:[{type:e.ViewChild,args:["navWrapper",{static:!1}]}],tabList:[{type:e.ViewChild,args:["tabList",{static:!1}]}],firstTabActive:[{type:e.Input}],scrollToActive:[{type:e.Input}],trackOpenTab:[{type:e.Input}],selectedTabChanged:[{type:e.Output}],windowResize:[{type:e.HostListener,args:["window:resize"]}]},t}();var s=function(){function t(t,e,r){this.tabs=t,this.elementRef=e,this.renderer=r,this.active=!1}return t.prototype.ngOnInit=function(){this.tabs.addTab(this),this.renderer.addClass(this.elementRef.nativeElement,"tab-pane"),this.renderer.setAttribute(this.elementRef.nativeElement,"role","tabpanel")},t.prototype.ngOnDestroy=function(){this.tabs.removeTab(this)},t.prototype.getTabClasses=function(){return{"nav-link":!0,active:this.active}},t.decorators=[{type:e.Directive,args:[{selector:"[ngcScrollingTab], ngcScrollingTab"}]}],t.ctorParameters=function(){return[{type:a},{type:e.ElementRef},{type:e.Renderer2}]},t.propDecorators={id:[{type:e.Input}],title:[{type:e.Input}],active:[{type:e.HostBinding,args:["class.active"]},{type:e.Input}]},t}();var o=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{imports:[i.CommonModule],declarations:[a,s],exports:[a,s]}]}],t}();t.ScrollingTabsComponent=a,t.ScrollingTabsModule=o,t.ɵa=s,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=ngc-scrolling-tabs.umd.min.js.map

@@ -21,3 +21,2 @@ /**

this.trackOpenTab = true;
this.scrollBarWidths = 52;
this.selectedTabChanged = new EventEmitter();

@@ -38,3 +37,3 @@ this.tabs = [];

() => {
// if there is a param of tabId and we want to track open tabs, mark the open tab as active
// if there is a param of tabId and we want to track open tabs mark the open tab as active
if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {

@@ -46,3 +45,4 @@ this.markTabAsActive(this.route.snapshot.queryParams.tabId);

}
if (this.scrollToActive) {
// scroll to the active tab if setting is true and the tabs are larger than the window
if (this.scrollToActive && this.hasHiddenTabs()) {
this.scrollToActiveTab();

@@ -166,3 +166,2 @@ }

this.firstVisibleTabIndex = activeTab;
// change the view to set the active tab as first tab on the left
for (let i = 0; i < activeTab; i++) {

@@ -175,2 +174,8 @@ if (this.tabList.nativeElement.children[i]) {

/**
* @return {?}
*/
hasHiddenTabs() {
return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;
}
/**
* @param {?} tabId

@@ -206,3 +211,3 @@ * @return {?}

changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
}] }

@@ -222,3 +227,2 @@ ];

trackOpenTab: [{ type: Input }],
scrollBarWidths: [{ type: Input }],
selectedTabChanged: [{ type: Output }],

@@ -239,4 +243,2 @@ windowResize: [{ type: HostListener, args: ['window:resize',] }]

/** @type {?} */
ScrollingTabsComponent.prototype.scrollBarWidths;
/** @type {?} */
ScrollingTabsComponent.prototype.selectedTabChanged;

@@ -269,2 +271,2 @@ /** @type {?} */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolling-tabs.component.js","sourceRoot":"ng://ngc-scrolling-tabs/","sources":["lib/scrolling-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef,\n         ViewChild, AfterViewInit, HostListener, Input, Output, EventEmitter } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\n\nimport { ScrollingTabDirective } from './scrolling-tab.directive';\n\n@Component({\n  selector: 'ngc-scrolling-tabs',\n  templateUrl: './scrolling-tabs.component.html',\n  styleUrls: ['./scrolling-tabs.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollingTabsComponent implements AfterViewInit {\n  @ViewChild('navWrapper', { static: false }) navWrapper: ElementRef;\n  @ViewChild('tabList', { static: false }) tabList: ElementRef;\n\n  @Input() firstTabActive = true;\n  @Input() scrollToActive = true;\n  @Input() trackOpenTab = true;\n  @Input() scrollBarWidths = 52;\n  @Output() selectedTabChanged = new EventEmitter<ScrollingTabDirective>();\n\n  tabs: ScrollingTabDirective[] = [];\n  leftOffset = 0;\n  firstVisibleTabIndex = -1;\n  showLeftArrow = false;\n  showRightArrow = false;\n\n  constructor(private changeDetector: ChangeDetectorRef, private route: ActivatedRoute, private router: Router) { }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      // if there is a param of tabId and we want to track open tabs, mark the open tab as active\n      if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {\n        this.markTabAsActive(this.route.snapshot.queryParams.tabId);\n      } else if (this.firstTabActive) { // if we should mark the first tab as active if a active tab is not specified\n        this.markFirstTabActive();\n      }\n\n      if (this.scrollToActive) {\n        this.scrollToActiveTab();\n      }\n      this.redrawTabs();\n      this.changeDetector.detectChanges();\n    }, 0);\n  }\n\n  addTab(tab: ScrollingTabDirective) {\n    this.tabs.push(tab);\n  }\n\n  removeTab(tab: ScrollingTabDirective) {\n    const index = this.tabs.indexOf(tab);\n    if (index !== -1) {\n      this.tabs.splice(index, 1);\n    }\n  }\n\n  @HostListener('window:resize')\n  windowResize() {\n    this.redrawTabs();\n  }\n\n  redrawTabs() {\n    // Take the total width of the list. Subtract how far right we are and see if that is greater than the\n    // width of the current display\n    if (this.widthOfList() + this.leftOffset > this.navWrapper.nativeElement.offsetWidth) {\n      this.showRightArrow = true;\n    } else {\n      this.showRightArrow = false;\n    }\n\n    // see if we have scrolled right and we are not at the left most position\n    if (this.leftOffset < 0) {\n      this.showLeftArrow = true;\n    } else {\n      this.showLeftArrow = false;\n    }\n  }\n\n  widthOfList() {\n    let totalWidth = 0;\n    for (const li of this.tabList.nativeElement.children) {\n      totalWidth += li.offsetWidth;\n    }\n    return totalWidth;\n  }\n\n  onScrollerLeftClick() {\n    // we need to go left for the width of the previous tab\n    this.firstVisibleTabIndex--;\n    // when moving left the left offset increases\n    this.leftOffset += this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    this.redrawTabs();\n  }\n\n  onScrollerRightClick() {\n    // when moving right you descrease the left offset. We want to go right the length of the current tab\n    this.leftOffset -= this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    // change the index of the visible tab now that we have moved\n    this.firstVisibleTabIndex++;\n    this.redrawTabs();\n  }\n\n  onSelectedTabChanged(tab: ScrollingTabDirective) {\n    this.markTabAsActive(tab.id);\n    if (this.trackOpenTab) {\n      this.pushCurrentTabToParam(tab);\n    }\n    this.selectedTabChanged.emit(tab);\n  }\n\n  markFirstTabActive() {\n    const activeTab = this.tabs.find(t => t.active);\n    //  if there is no active tab and we have tabs set first one to active\n    if (!activeTab && this.tabs.length > 0) {\n      this.tabs[0].active = true;\n    }\n  }\n\n  scrollToActiveTab() {\n    const activeTab = this.tabs.findIndex(t => t.active);\n    this.firstVisibleTabIndex = activeTab;\n\n    // change the view to set the active tab as first tab on the left\n    for (let i = 0; i < activeTab; i++) {\n      if (this.tabList.nativeElement.children[i]) {\n        this.leftOffset -= this.tabList.nativeElement.children[i].offsetWidth;\n      }\n    }\n  }\n\n  markTabAsActive(tabId: any) {\n    for (const t of this.tabs) {\n      t.active = false;\n      if (t.id === tabId) {\n        t.active = true;\n      }\n    }\n  }\n\n  pushCurrentTabToParam(tab: ScrollingTabDirective) {\n    this.router.navigate([], {\n      relativeTo: this.route,\n      queryParams: {\n        tabId: tab.id\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolling-tabs.component.js","sourceRoot":"ng://ngc-scrolling-tabs/","sources":["lib/scrolling-tabs.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,UAAU,EACjE,SAAS,EAAiB,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAUzD,MAAM,OAAO,sBAAsB;;;;;;IAejC,YAAoB,cAAiC,EAAU,KAAqB,EAAU,MAAc;QAAxF,mBAAc,GAAd,cAAc,CAAmB;QAAU,UAAK,GAAL,KAAK,CAAgB;QAAU,WAAM,GAAN,MAAM,CAAQ;QAXnG,mBAAc,GAAG,IAAI,CAAC;QACtB,mBAAc,GAAG,IAAI,CAAC;QACtB,iBAAY,GAAG,IAAI,CAAC;QACnB,uBAAkB,GAAG,IAAI,YAAY,EAAyB,CAAC;QAEzE,SAAI,GAA4B,EAAE,CAAC;QACnC,eAAU,GAAG,CAAC,CAAC;QACf,yBAAoB,GAAG,CAAC,CAAC,CAAC;QAC1B,kBAAa,GAAG,KAAK,CAAC;QACtB,mBAAc,GAAG,KAAK,CAAC;IAEyF,CAAC;;;;IAEjH,eAAe;QACb,UAAU;;;QAAC,GAAG,EAAE;YACd,0FAA0F;YAC1F,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE;gBAC9D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aAC7D;iBAAM,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,6EAA6E;gBAC7G,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;YAED,sFAAsF;YACtF,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE;gBAC/C,IAAI,CAAC,iBAAiB,EAAE,CAAC;aAC1B;YACD,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACtC,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;;;;IAED,MAAM,CAAC,GAA0B;QAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACtB,CAAC;;;;;IAED,SAAS,CAAC,GAA0B;;cAC5B,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QACpC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;YAChB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;SAC5B;IACH,CAAC;;;;IAGD,YAAY;QACV,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;;;;IAED,UAAU;QACR,sGAAsG;QACtG,+BAA+B;QAC/B,IAAI,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,EAAE;YACpF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC7B;QAED,yEAAyE;QACzE,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC5B;IACH,CAAC;;;;IAED,WAAW;;YACL,UAAU,GAAG,CAAC;QAClB,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,EAAE;YACpD,UAAU,IAAI,EAAE,CAAC,WAAW,CAAC;SAC9B;QACD,OAAO,UAAU,CAAC;IACpB,CAAC;;;;IAED,mBAAmB;QACjB,uDAAuD;QACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,6CAA6C;QAC7C,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,WAAW,CAAC;QAC9F,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;;;;IAED,oBAAoB;QAClB,qGAAqG;QACrG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,WAAW,CAAC;QAC9F,6DAA6D;QAC7D,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;;;;;IAED,oBAAoB,CAAC,GAA0B;QAC7C,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC;SACjC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC;;;;IAED,kBAAkB;;cACV,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAC;QAC/C,sEAAsE;QACtE,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACtC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;SAC5B;IACH,CAAC;;;;IAED,iBAAiB;;cACT,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAC;QACpD,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC;QACtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;gBAC1C,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;aACvE;SACF;IACH,CAAC;;;;IAED,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;IACxE,CAAC;;;;;IAED,eAAe,CAAC,KAAU;QACxB,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE;YACzB,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;YACjB,IAAI,CAAC,CAAC,EAAE,KAAK,KAAK,EAAE;gBAClB,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;aACjB;SACF;IACH,CAAC;;;;;IAED,qBAAqB,CAAC,GAA0B;QAC9C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE;YACvB,UAAU,EAAE,IAAI,CAAC,KAAK;YACtB,WAAW,EAAE;gBACX,KAAK,EAAE,GAAG,CAAC,EAAE;aACd;YACD,mBAAmB,EAAE,OAAO;SAC7B,CAAC,CAAC;IACL,CAAC;;;YAjJF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,2pEAA8C;gBAE9C,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;;YAX4C,iBAAiB;YAE7C,cAAc;YAAtB,MAAM;;;yBAWZ,SAAS,SAAC,YAAY,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;sBACzC,SAAS,SAAC,SAAS,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;6BAEtC,KAAK;6BACL,KAAK;2BACL,KAAK;iCACL,MAAM;2BAuCN,YAAY,SAAC,eAAe;;;;IA7C7B,4CAAmE;;IACnE,yCAA6D;;IAE7D,gDAA+B;;IAC/B,gDAA+B;;IAC/B,8CAA6B;;IAC7B,oDAAyE;;IAEzE,sCAAmC;;IACnC,4CAAe;;IACf,sDAA0B;;IAC1B,+CAAsB;;IACtB,gDAAuB;;;;;IAEX,gDAAyC;;;;;IAAE,uCAA6B;;;;;IAAE,wCAAsB","sourcesContent":["import { Component, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef,\n         ViewChild, AfterViewInit, HostListener, Input, Output, EventEmitter } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\n\nimport { ScrollingTabDirective } from './scrolling-tab.directive';\n\n@Component({\n  selector: 'ngc-scrolling-tabs',\n  templateUrl: './scrolling-tabs.component.html',\n  styleUrls: ['./scrolling-tabs.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollingTabsComponent implements AfterViewInit {\n  @ViewChild('navWrapper', { static: false }) navWrapper: ElementRef;\n  @ViewChild('tabList', { static: false }) tabList: ElementRef;\n\n  @Input() firstTabActive = true;\n  @Input() scrollToActive = true;\n  @Input() trackOpenTab = true;\n  @Output() selectedTabChanged = new EventEmitter<ScrollingTabDirective>();\n\n  tabs: ScrollingTabDirective[] = [];\n  leftOffset = 0;\n  firstVisibleTabIndex = -1;\n  showLeftArrow = false;\n  showRightArrow = false;\n\n  constructor(private changeDetector: ChangeDetectorRef, private route: ActivatedRoute, private router: Router) { }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      // if there is a param of tabId and we want to track open tabs mark the open tab as active\n      if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {\n        this.markTabAsActive(this.route.snapshot.queryParams.tabId);\n      } else if (this.firstTabActive) { // if we should mark the first tab as active if a active tab is not specified\n        this.markFirstTabActive();\n      }\n\n      // scroll to the active tab if setting is true and the tabs are larger than the window\n      if (this.scrollToActive && this.hasHiddenTabs()) {\n        this.scrollToActiveTab();\n      }\n      this.redrawTabs();\n      this.changeDetector.detectChanges();\n    }, 0);\n  }\n\n  addTab(tab: ScrollingTabDirective) {\n    this.tabs.push(tab);\n  }\n\n  removeTab(tab: ScrollingTabDirective) {\n    const index = this.tabs.indexOf(tab);\n    if (index !== -1) {\n      this.tabs.splice(index, 1);\n    }\n  }\n\n  @HostListener('window:resize')\n  windowResize() {\n    this.redrawTabs();\n  }\n\n  redrawTabs() {\n    // Take the total width of the list. Subtract how far right we are and see if that is greater than the\n    // width of the current display\n    if (this.widthOfList() + this.leftOffset > this.navWrapper.nativeElement.offsetWidth) {\n      this.showRightArrow = true;\n    } else {\n      this.showRightArrow = false;\n    }\n\n    // see if we have scrolled right and we are not at the left most position\n    if (this.leftOffset < 0) {\n      this.showLeftArrow = true;\n    } else {\n      this.showLeftArrow = false;\n    }\n  }\n\n  widthOfList() {\n    let totalWidth = 0;\n    for (const li of this.tabList.nativeElement.children) {\n      totalWidth += li.offsetWidth;\n    }\n    return totalWidth;\n  }\n\n  onScrollerLeftClick() {\n    // we need to go left for the width of the previous tab\n    this.firstVisibleTabIndex--;\n    // when moving left the left offset increases\n    this.leftOffset += this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    this.redrawTabs();\n  }\n\n  onScrollerRightClick() {\n    // when moving right you descrease the left offset. We want to go right the length of the current tab\n    this.leftOffset -= this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    // change the index of the visible tab now that we have moved\n    this.firstVisibleTabIndex++;\n    this.redrawTabs();\n  }\n\n  onSelectedTabChanged(tab: ScrollingTabDirective) {\n    this.markTabAsActive(tab.id);\n    if (this.trackOpenTab) {\n      this.pushCurrentTabToParam(tab);\n    }\n    this.selectedTabChanged.emit(tab);\n  }\n\n  markFirstTabActive() {\n    const activeTab = this.tabs.find(t => t.active);\n    //  if there is no active tab and we have tabs set first one to active\n    if (!activeTab && this.tabs.length > 0) {\n      this.tabs[0].active = true;\n    }\n  }\n\n  scrollToActiveTab() {\n    const activeTab = this.tabs.findIndex(t => t.active);\n    this.firstVisibleTabIndex = activeTab;\n    for (let i = 0; i < activeTab; i++) {\n      if (this.tabList.nativeElement.children[i]) {\n        this.leftOffset -= this.tabList.nativeElement.children[i].offsetWidth;\n      }\n    }\n  }\n\n  hasHiddenTabs() {\n    return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;\n  }\n\n  markTabAsActive(tabId: any) {\n    for (const t of this.tabs) {\n      t.active = false;\n      if (t.id === tabId) {\n        t.active = true;\n      }\n    }\n  }\n\n  pushCurrentTabToParam(tab: ScrollingTabDirective) {\n    this.router.navigate([], {\n      relativeTo: this.route,\n      queryParams: {\n        tabId: tab.id\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n}\n"]}

@@ -17,3 +17,2 @@ /**

this.trackOpenTab = true;
this.scrollBarWidths = 52;
this.selectedTabChanged = new EventEmitter();

@@ -38,3 +37,3 @@ this.tabs = [];

function () {
// if there is a param of tabId and we want to track open tabs, mark the open tab as active
// if there is a param of tabId and we want to track open tabs mark the open tab as active
if (_this.route.snapshot.queryParams.tabId && _this.trackOpenTab) {

@@ -46,3 +45,4 @@ _this.markTabAsActive(_this.route.snapshot.queryParams.tabId);

}
if (_this.scrollToActive) {
// scroll to the active tab if setting is true and the tabs are larger than the window
if (_this.scrollToActive && _this.hasHiddenTabs()) {
_this.scrollToActiveTab();

@@ -210,3 +210,2 @@ }

this.firstVisibleTabIndex = activeTab;
// change the view to set the active tab as first tab on the left
for (var i = 0; i < activeTab; i++) {

@@ -219,2 +218,11 @@ if (this.tabList.nativeElement.children[i]) {

/**
* @return {?}
*/
ScrollingTabsComponent.prototype.hasHiddenTabs = /**
* @return {?}
*/
function () {
return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;
};
/**
* @param {?} tabId

@@ -268,3 +276,3 @@ * @return {?}

changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
}] }

@@ -284,3 +292,2 @@ ];

trackOpenTab: [{ type: Input }],
scrollBarWidths: [{ type: Input }],
selectedTabChanged: [{ type: Output }],

@@ -304,4 +311,2 @@ windowResize: [{ type: HostListener, args: ['window:resize',] }]

/** @type {?} */
ScrollingTabsComponent.prototype.scrollBarWidths;
/** @type {?} */
ScrollingTabsComponent.prototype.selectedTabChanged;

@@ -334,2 +339,2 @@ /** @type {?} */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolling-tabs.component.js","sourceRoot":"ng://ngc-scrolling-tabs/","sources":["lib/scrolling-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef,\n         ViewChild, AfterViewInit, HostListener, Input, Output, EventEmitter } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\n\nimport { ScrollingTabDirective } from './scrolling-tab.directive';\n\n@Component({\n  selector: 'ngc-scrolling-tabs',\n  templateUrl: './scrolling-tabs.component.html',\n  styleUrls: ['./scrolling-tabs.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollingTabsComponent implements AfterViewInit {\n  @ViewChild('navWrapper', { static: false }) navWrapper: ElementRef;\n  @ViewChild('tabList', { static: false }) tabList: ElementRef;\n\n  @Input() firstTabActive = true;\n  @Input() scrollToActive = true;\n  @Input() trackOpenTab = true;\n  @Input() scrollBarWidths = 52;\n  @Output() selectedTabChanged = new EventEmitter<ScrollingTabDirective>();\n\n  tabs: ScrollingTabDirective[] = [];\n  leftOffset = 0;\n  firstVisibleTabIndex = -1;\n  showLeftArrow = false;\n  showRightArrow = false;\n\n  constructor(private changeDetector: ChangeDetectorRef, private route: ActivatedRoute, private router: Router) { }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      // if there is a param of tabId and we want to track open tabs, mark the open tab as active\n      if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {\n        this.markTabAsActive(this.route.snapshot.queryParams.tabId);\n      } else if (this.firstTabActive) { // if we should mark the first tab as active if a active tab is not specified\n        this.markFirstTabActive();\n      }\n\n      if (this.scrollToActive) {\n        this.scrollToActiveTab();\n      }\n      this.redrawTabs();\n      this.changeDetector.detectChanges();\n    }, 0);\n  }\n\n  addTab(tab: ScrollingTabDirective) {\n    this.tabs.push(tab);\n  }\n\n  removeTab(tab: ScrollingTabDirective) {\n    const index = this.tabs.indexOf(tab);\n    if (index !== -1) {\n      this.tabs.splice(index, 1);\n    }\n  }\n\n  @HostListener('window:resize')\n  windowResize() {\n    this.redrawTabs();\n  }\n\n  redrawTabs() {\n    // Take the total width of the list. Subtract how far right we are and see if that is greater than the\n    // width of the current display\n    if (this.widthOfList() + this.leftOffset > this.navWrapper.nativeElement.offsetWidth) {\n      this.showRightArrow = true;\n    } else {\n      this.showRightArrow = false;\n    }\n\n    // see if we have scrolled right and we are not at the left most position\n    if (this.leftOffset < 0) {\n      this.showLeftArrow = true;\n    } else {\n      this.showLeftArrow = false;\n    }\n  }\n\n  widthOfList() {\n    let totalWidth = 0;\n    for (const li of this.tabList.nativeElement.children) {\n      totalWidth += li.offsetWidth;\n    }\n    return totalWidth;\n  }\n\n  onScrollerLeftClick() {\n    // we need to go left for the width of the previous tab\n    this.firstVisibleTabIndex--;\n    // when moving left the left offset increases\n    this.leftOffset += this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    this.redrawTabs();\n  }\n\n  onScrollerRightClick() {\n    // when moving right you descrease the left offset. We want to go right the length of the current tab\n    this.leftOffset -= this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    // change the index of the visible tab now that we have moved\n    this.firstVisibleTabIndex++;\n    this.redrawTabs();\n  }\n\n  onSelectedTabChanged(tab: ScrollingTabDirective) {\n    this.markTabAsActive(tab.id);\n    if (this.trackOpenTab) {\n      this.pushCurrentTabToParam(tab);\n    }\n    this.selectedTabChanged.emit(tab);\n  }\n\n  markFirstTabActive() {\n    const activeTab = this.tabs.find(t => t.active);\n    //  if there is no active tab and we have tabs set first one to active\n    if (!activeTab && this.tabs.length > 0) {\n      this.tabs[0].active = true;\n    }\n  }\n\n  scrollToActiveTab() {\n    const activeTab = this.tabs.findIndex(t => t.active);\n    this.firstVisibleTabIndex = activeTab;\n\n    // change the view to set the active tab as first tab on the left\n    for (let i = 0; i < activeTab; i++) {\n      if (this.tabList.nativeElement.children[i]) {\n        this.leftOffset -= this.tabList.nativeElement.children[i].offsetWidth;\n      }\n    }\n  }\n\n  markTabAsActive(tabId: any) {\n    for (const t of this.tabs) {\n      t.active = false;\n      if (t.id === tabId) {\n        t.active = true;\n      }\n    }\n  }\n\n  pushCurrentTabToParam(tab: ScrollingTabDirective) {\n    this.router.navigate([], {\n      relativeTo: this.route,\n      queryParams: {\n        tabId: tab.id\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrolling-tabs.component.js","sourceRoot":"ng://ngc-scrolling-tabs/","sources":["lib/scrolling-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef,\n         ViewChild, AfterViewInit, HostListener, Input, Output, EventEmitter } from '@angular/core';\nimport { Router, ActivatedRoute } from '@angular/router';\n\nimport { ScrollingTabDirective } from './scrolling-tab.directive';\n\n@Component({\n  selector: 'ngc-scrolling-tabs',\n  templateUrl: './scrolling-tabs.component.html',\n  styleUrls: ['./scrolling-tabs.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollingTabsComponent implements AfterViewInit {\n  @ViewChild('navWrapper', { static: false }) navWrapper: ElementRef;\n  @ViewChild('tabList', { static: false }) tabList: ElementRef;\n\n  @Input() firstTabActive = true;\n  @Input() scrollToActive = true;\n  @Input() trackOpenTab = true;\n  @Output() selectedTabChanged = new EventEmitter<ScrollingTabDirective>();\n\n  tabs: ScrollingTabDirective[] = [];\n  leftOffset = 0;\n  firstVisibleTabIndex = -1;\n  showLeftArrow = false;\n  showRightArrow = false;\n\n  constructor(private changeDetector: ChangeDetectorRef, private route: ActivatedRoute, private router: Router) { }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      // if there is a param of tabId and we want to track open tabs mark the open tab as active\n      if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {\n        this.markTabAsActive(this.route.snapshot.queryParams.tabId);\n      } else if (this.firstTabActive) { // if we should mark the first tab as active if a active tab is not specified\n        this.markFirstTabActive();\n      }\n\n      // scroll to the active tab if setting is true and the tabs are larger than the window\n      if (this.scrollToActive && this.hasHiddenTabs()) {\n        this.scrollToActiveTab();\n      }\n      this.redrawTabs();\n      this.changeDetector.detectChanges();\n    }, 0);\n  }\n\n  addTab(tab: ScrollingTabDirective) {\n    this.tabs.push(tab);\n  }\n\n  removeTab(tab: ScrollingTabDirective) {\n    const index = this.tabs.indexOf(tab);\n    if (index !== -1) {\n      this.tabs.splice(index, 1);\n    }\n  }\n\n  @HostListener('window:resize')\n  windowResize() {\n    this.redrawTabs();\n  }\n\n  redrawTabs() {\n    // Take the total width of the list. Subtract how far right we are and see if that is greater than the\n    // width of the current display\n    if (this.widthOfList() + this.leftOffset > this.navWrapper.nativeElement.offsetWidth) {\n      this.showRightArrow = true;\n    } else {\n      this.showRightArrow = false;\n    }\n\n    // see if we have scrolled right and we are not at the left most position\n    if (this.leftOffset < 0) {\n      this.showLeftArrow = true;\n    } else {\n      this.showLeftArrow = false;\n    }\n  }\n\n  widthOfList() {\n    let totalWidth = 0;\n    for (const li of this.tabList.nativeElement.children) {\n      totalWidth += li.offsetWidth;\n    }\n    return totalWidth;\n  }\n\n  onScrollerLeftClick() {\n    // we need to go left for the width of the previous tab\n    this.firstVisibleTabIndex--;\n    // when moving left the left offset increases\n    this.leftOffset += this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    this.redrawTabs();\n  }\n\n  onScrollerRightClick() {\n    // when moving right you descrease the left offset. We want to go right the length of the current tab\n    this.leftOffset -= this.tabList.nativeElement.children[this.firstVisibleTabIndex].offsetWidth;\n    // change the index of the visible tab now that we have moved\n    this.firstVisibleTabIndex++;\n    this.redrawTabs();\n  }\n\n  onSelectedTabChanged(tab: ScrollingTabDirective) {\n    this.markTabAsActive(tab.id);\n    if (this.trackOpenTab) {\n      this.pushCurrentTabToParam(tab);\n    }\n    this.selectedTabChanged.emit(tab);\n  }\n\n  markFirstTabActive() {\n    const activeTab = this.tabs.find(t => t.active);\n    //  if there is no active tab and we have tabs set first one to active\n    if (!activeTab && this.tabs.length > 0) {\n      this.tabs[0].active = true;\n    }\n  }\n\n  scrollToActiveTab() {\n    const activeTab = this.tabs.findIndex(t => t.active);\n    this.firstVisibleTabIndex = activeTab;\n    for (let i = 0; i < activeTab; i++) {\n      if (this.tabList.nativeElement.children[i]) {\n        this.leftOffset -= this.tabList.nativeElement.children[i].offsetWidth;\n      }\n    }\n  }\n\n  hasHiddenTabs() {\n    return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;\n  }\n\n  markTabAsActive(tabId: any) {\n    for (const t of this.tabs) {\n      t.active = false;\n      if (t.id === tabId) {\n        t.active = true;\n      }\n    }\n  }\n\n  pushCurrentTabToParam(tab: ScrollingTabDirective) {\n    this.router.navigate([], {\n      relativeTo: this.route,\n      queryParams: {\n        tabId: tab.id\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n}\n"]}

@@ -23,3 +23,2 @@ import { EventEmitter, Component, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild, Input, Output, HostListener, Directive, ElementRef, Renderer2, HostBinding, NgModule } from '@angular/core';

this.trackOpenTab = true;
this.scrollBarWidths = 52;
this.selectedTabChanged = new EventEmitter();

@@ -40,3 +39,3 @@ this.tabs = [];

() => {
// if there is a param of tabId and we want to track open tabs, mark the open tab as active
// if there is a param of tabId and we want to track open tabs mark the open tab as active
if (this.route.snapshot.queryParams.tabId && this.trackOpenTab) {

@@ -48,3 +47,4 @@ this.markTabAsActive(this.route.snapshot.queryParams.tabId);

}
if (this.scrollToActive) {
// scroll to the active tab if setting is true and the tabs are larger than the window
if (this.scrollToActive && this.hasHiddenTabs()) {
this.scrollToActiveTab();

@@ -168,3 +168,2 @@ }

this.firstVisibleTabIndex = activeTab;
// change the view to set the active tab as first tab on the left
for (let i = 0; i < activeTab; i++) {

@@ -177,2 +176,8 @@ if (this.tabList.nativeElement.children[i]) {

/**
* @return {?}
*/
hasHiddenTabs() {
return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;
}
/**
* @param {?} tabId

@@ -208,3 +213,3 @@ * @return {?}

changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
}] }

@@ -224,3 +229,2 @@ ];

trackOpenTab: [{ type: Input }],
scrollBarWidths: [{ type: Input }],
selectedTabChanged: [{ type: Output }],

@@ -241,4 +245,2 @@ windowResize: [{ type: HostListener, args: ['window:resize',] }]

/** @type {?} */
ScrollingTabsComponent.prototype.scrollBarWidths;
/** @type {?} */
ScrollingTabsComponent.prototype.selectedTabChanged;

@@ -245,0 +247,0 @@ /** @type {?} */

@@ -19,3 +19,2 @@ import { __values } from 'tslib';

this.trackOpenTab = true;
this.scrollBarWidths = 52;
this.selectedTabChanged = new EventEmitter();

@@ -40,3 +39,3 @@ this.tabs = [];

function () {
// if there is a param of tabId and we want to track open tabs, mark the open tab as active
// if there is a param of tabId and we want to track open tabs mark the open tab as active
if (_this.route.snapshot.queryParams.tabId && _this.trackOpenTab) {

@@ -48,3 +47,4 @@ _this.markTabAsActive(_this.route.snapshot.queryParams.tabId);

}
if (_this.scrollToActive) {
// scroll to the active tab if setting is true and the tabs are larger than the window
if (_this.scrollToActive && _this.hasHiddenTabs()) {
_this.scrollToActiveTab();

@@ -212,3 +212,2 @@ }

this.firstVisibleTabIndex = activeTab;
// change the view to set the active tab as first tab on the left
for (var i = 0; i < activeTab; i++) {

@@ -221,2 +220,11 @@ if (this.tabList.nativeElement.children[i]) {

/**
* @return {?}
*/
ScrollingTabsComponent.prototype.hasHiddenTabs = /**
* @return {?}
*/
function () {
return this.widthOfList() > this.navWrapper.nativeElement.offsetWidth;
};
/**
* @param {?} tabId

@@ -270,3 +278,3 @@ * @return {?}

changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
styles: [".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]
}] }

@@ -286,3 +294,2 @@ ];

trackOpenTab: [{ type: Input }],
scrollBarWidths: [{ type: Input }],
selectedTabChanged: [{ type: Output }],

@@ -305,4 +312,2 @@ windowResize: [{ type: HostListener, args: ['window:resize',] }]

/** @type {?} */
ScrollingTabsComponent.prototype.scrollBarWidths;
/** @type {?} */
ScrollingTabsComponent.prototype.selectedTabChanged;

@@ -309,0 +314,0 @@ /** @type {?} */

@@ -13,3 +13,2 @@ import { ChangeDetectorRef, ElementRef, AfterViewInit, EventEmitter } from '@angular/core';

trackOpenTab: boolean;
scrollBarWidths: number;
selectedTabChanged: EventEmitter<ScrollingTabDirective>;

@@ -33,4 +32,5 @@ tabs: ScrollingTabDirective[];

scrollToActiveTab(): void;
hasHiddenTabs(): boolean;
markTabAsActive(tabId: any): void;
pushCurrentTabToParam(tab: ScrollingTabDirective): void;
}

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"ScrollingTabsComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"ngc-scrolling-tabs","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":10,"character":19},"member":"OnPush"},"template":"<div class=\"wrap-selector\">\n <div class=\"nav-tabs-boxed\">\n <div class=\"scroller scroller-left\" (click)=\"onScrollerLeftClick()\" *ngIf=\"showLeftArrow\">\n <svg class=\"arrow-img\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.0\" width=\"157.000000pt\" height=\"263.000000pt\"\n viewBox=\"0 0 157.000000 263.000000\" preserveAspectRatio=\"xMidYMid meet\">\n <g transform=\"translate(0.000000,263.000000) scale(0.100000,-0.100000)\" fill=\"currentColor\" stroke=\"none\">\n <path d=\"M653 1967 l-603 -602 0 -45 0 -45 603 -602 c710 -711 628 -655 764 -520 79 79 83 85 83 127 l0 45 -497 497 -498 498 498 498 497 497 0 45 c0 42 -4 48 -83 127 -136 135 -54 191 -764 -520z\" />\n </g>\n </svg>\n </div>\n <div class=\"scroller scroller-right\" (click)=\"onScrollerRightClick()\" *ngIf=\"showRightArrow\">\n <svg class=\"arrow-img\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.0\" width=\"157.000000pt\" height=\"263.000000pt\"\n viewBox=\"0 0 157.000000 263.000000\" preserveAspectRatio=\"xMidYMid meet\">\n <g transform=\"translate(0.000000,263.000000) scale(0.100000,-0.100000)\" fill=\"currentColor\" stroke=\"none\">\n <path d=\"M153 2477 c-79 -79 -83 -85 -83 -127 l0 -45 497 -497 498 -498 -498 -498 -497 -497 0 -45 c0 -42 4 -48 83 -127 136 -135 54 -191 764 520 l603 602 0 45 0 45 -603 602 c-710 711 -628 655 -764 520z\" />\n </g>\n </svg>\n </div>\n <div class=\"nav-wrapper\" #navWrapper>\n <ul class=\"nav nav-tabs list\" role=\"tablist\" #tabList [style.left.px]=\"leftOffset\">\n <li *ngFor=\"let tab of tabs\" class=\"nav-item\">\n <a [ngClass]=\"tab.getTabClasses()\" data-toggle=\"tab\" href=\"javascript:void(0)\" role=\"tab\"\n attr.aria-controls=\"{{tab.title}}\" (click)=\"onSelectedTabChanged(tab)\">{{tab.title}}</a>\n </li>\n </ul>\n </div>\n <div class=\"tab-content\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>","styles":[".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px}.nav-link{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]}]}],"members":{"navWrapper":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":13,"character":3},"arguments":["navWrapper",{"static":false}]}]}],"tabList":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":14,"character":3},"arguments":["tabList",{"static":false}]}]}],"firstTabActive":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"scrollToActive":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"trackOpenTab":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"scrollBarWidths":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"selectedTabChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":20,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":28,"character":38},{"__symbolic":"reference","module":"@angular/router","name":"ActivatedRoute","line":28,"character":72},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":28,"character":104}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"addTab":[{"__symbolic":"method"}],"removeTab":[{"__symbolic":"method"}],"windowResize":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":58,"character":3},"arguments":["window:resize"]}]}],"redrawTabs":[{"__symbolic":"method"}],"widthOfList":[{"__symbolic":"method"}],"onScrollerLeftClick":[{"__symbolic":"method"}],"onScrollerRightClick":[{"__symbolic":"method"}],"onSelectedTabChanged":[{"__symbolic":"method"}],"markFirstTabActive":[{"__symbolic":"method"}],"scrollToActiveTab":[{"__symbolic":"method"}],"markTabAsActive":[{"__symbolic":"method"}],"pushCurrentTabToParam":[{"__symbolic":"method"}]}},"ScrollingTabsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":14}],"declarations":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[ngcScrollingTab], ngcScrollingTab"}]}],"members":{"id":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"title":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}],"active":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":12,"character":5},"arguments":["class.active"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":5}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":15,"character":74},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":15,"character":104}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getTabClasses":[{"__symbolic":"method"}]}}},"origins":{"ScrollingTabsComponent":"./lib/scrolling-tabs.component","ScrollingTabsModule":"./lib/scrolling-tabs.module","ɵa":"./lib/scrolling-tab.directive"},"importAs":"ngc-scrolling-tabs"}
{"__symbolic":"module","version":4,"metadata":{"ScrollingTabsComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"ngc-scrolling-tabs","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":10,"character":19},"member":"OnPush"},"template":"<div class=\"wrap-selector\">\n <div class=\"nav-tabs-boxed\">\n <div class=\"scroller scroller-left\" (click)=\"onScrollerLeftClick()\" *ngIf=\"showLeftArrow\">\n <svg class=\"arrow-img\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.0\" width=\"157.000000pt\" height=\"263.000000pt\"\n viewBox=\"0 0 157.000000 263.000000\" preserveAspectRatio=\"xMidYMid meet\">\n <g transform=\"translate(0.000000,263.000000) scale(0.100000,-0.100000)\" fill=\"currentColor\" stroke=\"none\">\n <path d=\"M653 1967 l-603 -602 0 -45 0 -45 603 -602 c710 -711 628 -655 764 -520 79 79 83 85 83 127 l0 45 -497 497 -498 498 498 498 497 497 0 45 c0 42 -4 48 -83 127 -136 135 -54 191 -764 -520z\" />\n </g>\n </svg>\n </div>\n <div class=\"scroller scroller-right\" (click)=\"onScrollerRightClick()\" *ngIf=\"showRightArrow\">\n <svg class=\"arrow-img\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.0\" width=\"157.000000pt\" height=\"263.000000pt\"\n viewBox=\"0 0 157.000000 263.000000\" preserveAspectRatio=\"xMidYMid meet\">\n <g transform=\"translate(0.000000,263.000000) scale(0.100000,-0.100000)\" fill=\"currentColor\" stroke=\"none\">\n <path d=\"M153 2477 c-79 -79 -83 -85 -83 -127 l0 -45 497 -497 498 -498 -498 -498 -497 -497 0 -45 c0 -42 4 -48 83 -127 136 -135 54 -191 764 520 l603 602 0 45 0 45 -603 602 c-710 711 -628 655 -764 520z\" />\n </g>\n </svg>\n </div>\n <div class=\"nav-wrapper\" #navWrapper>\n <ul class=\"nav nav-tabs list\" role=\"tablist\" #tabList [style.left.px]=\"leftOffset\">\n <li *ngFor=\"let tab of tabs\" class=\"nav-item\">\n <a [ngClass]=\"tab.getTabClasses()\" data-toggle=\"tab\" href=\"javascript:void(0)\" role=\"tab\"\n attr.aria-controls=\"{{tab.title}}\" (click)=\"onSelectedTabChanged(tab)\">{{tab.title}}</a>\n </li>\n </ul>\n </div>\n <div class=\"tab-content\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>","styles":[".nav-wrapper{position:relative;margin:0 auto;overflow:hidden;padding:5px;height:38px}.nav-tabs{height:38px;margin-left:1px}.tab-content{margin-left:1px}.list{position:absolute;left:0;top:0;min-width:3000px;margin-top:0}.list li{display:table-cell;position:relative;text-align:center;cursor:grab;cursor:-webkit-grab;color:#efefef;vertical-align:middle}.scroller{text-align:center;cursor:pointer;padding:7px;white-space:no-wrap;vertical-align:middle}.scroller-right{float:right}.scroller-left{float:left}.arrow-img{height:20px;width:15px}.arrow-img:hover{opacity:.5}"]}]}],"members":{"navWrapper":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":13,"character":3},"arguments":["navWrapper",{"static":false}]}]}],"tabList":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":14,"character":3},"arguments":["tabList",{"static":false}]}]}],"firstTabActive":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"scrollToActive":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"trackOpenTab":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"selectedTabChanged":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":19,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":27,"character":38},{"__symbolic":"reference","module":"@angular/router","name":"ActivatedRoute","line":27,"character":72},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":27,"character":104}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"addTab":[{"__symbolic":"method"}],"removeTab":[{"__symbolic":"method"}],"windowResize":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":58,"character":3},"arguments":["window:resize"]}]}],"redrawTabs":[{"__symbolic":"method"}],"widthOfList":[{"__symbolic":"method"}],"onScrollerLeftClick":[{"__symbolic":"method"}],"onScrollerRightClick":[{"__symbolic":"method"}],"onSelectedTabChanged":[{"__symbolic":"method"}],"markFirstTabActive":[{"__symbolic":"method"}],"scrollToActiveTab":[{"__symbolic":"method"}],"hasHiddenTabs":[{"__symbolic":"method"}],"markTabAsActive":[{"__symbolic":"method"}],"pushCurrentTabToParam":[{"__symbolic":"method"}]}},"ScrollingTabsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":14}],"declarations":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[ngcScrollingTab], ngcScrollingTab"}]}],"members":{"id":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"title":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}],"active":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":12,"character":5},"arguments":["class.active"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":5}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ScrollingTabsComponent"},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":15,"character":74},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":15,"character":104}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getTabClasses":[{"__symbolic":"method"}]}}},"origins":{"ScrollingTabsComponent":"./lib/scrolling-tabs.component","ScrollingTabsModule":"./lib/scrolling-tabs.module","ɵa":"./lib/scrolling-tab.directive"},"importAs":"ngc-scrolling-tabs"}
{
"name": "ngc-scrolling-tabs",
"version": "1.0.6",
"version": "1.0.7",
"peerDependencies": {

@@ -14,3 +14,3 @@ "@angular/common": "^8.2.14",

"type": "git",
"url": "https://github.com/jeff-nelson-78954/advanced-angular-bootstrap-components.git"
"url": "git+https://github.com/jeff-nelson-78954/advanced-angular-bootstrap-components.git"
},

@@ -17,0 +17,0 @@ "keywords": [

@@ -17,9 +17,9 @@ # ScrollingTabs

```
## Input options
- [firstTabActive] -> Used on page load, if the active tab is not specified the first tab will be marked as active.
- [scrollToActive] -> Used on page load, the active tab that is marked active will be scrolled to.
- [trackOpenTab] -> Used to track what tab is open as a url parameter. If the page is refreshed it will default to that tab.
- [scrollBarWidths] -> If your styles affect the scroll bar widths you will need to adjust this setting so tab scrolling continues to work properly.
## Output
## Inputs
- [firstTabActive] -> Used on page load, if the active tab is not specified the first tab will be marked as active. Default: true
- [scrollToActive] -> Used on page load, the active tab that is marked active will be scrolled to if there are hidden tabs. Default: true
- [trackOpenTab] -> Used to track what tab is open as a url parameter. If the page is refreshed it will default to that tab. Default: true
## Outputs
(selectedTabChanged) -> Fired when a user changes tabs.

@@ -29,3 +29,3 @@

```shell
<ngc-scrolling-tabs [firstTabActive]="true" [scrollToActive]="true" [trackOpenTab]="false">
<ngc-scrolling-tabs [firstTabActive]="true" [scrollToActive]="true" [trackOpenTab]="false" (selectedTabChanged)="onSelectedTabChanged($event)">
<ngcScrollingTab id="home" title="Home">

@@ -32,0 +32,0 @@ Tab 1 content

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc