/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ContentChildren, Directive, EventEmitter, Input, Output, QueryList, TemplateRef, ViewEncapsulation } from '@angular/core';
import { NgbTabsetConfig } from './tabset-config';
/** @type {?} */
let nextId = 0;
/**
* A directive to wrap tab titles that need to contain HTML markup or other directives.
*
* Alternatively you could use the `NgbTab.title` input for string titles.
*/
export class NgbTabTitle {
/**
* @param {?} templateRef
*/
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbTabTitle.decorators = [
{ type: Directive, args: [{ selector: 'ng-template[ngbTabTitle]' },] }
];
/** @nocollapse */
NgbTabTitle.ctorParameters = () => [
{ type: TemplateRef }
];
if (false) {
/** @type {?} */
NgbTabTitle.prototype.templateRef;
}
/**
* A directive to wrap content to be displayed in a tab.
*/
export class NgbTabContent {
/**
* @param {?} templateRef
*/
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbTabContent.decorators = [
{ type: Directive, args: [{ selector: 'ng-template[ngbTabContent]' },] }
];
/** @nocollapse */
NgbTabContent.ctorParameters = () => [
{ type: TemplateRef }
];
if (false) {
/** @type {?} */
NgbTabContent.prototype.templateRef;
}
/**
* A directive representing an individual tab.
*/
export class NgbTab {
constructor() {
/**
* The tab identifier.
*
* Must be unique for the entire document for proper accessibility support.
*/
this.id = `ngb-tab-${nextId++}`;
/**
* If `true`, the current tab is disabled and can't be toggled.
*/
this.disabled = false;
}
/**
* @return {?}
*/
ngAfterContentChecked() {
// We are using @ContentChildren instead of @ContentChild as in the Angular version being used
// only @ContentChildren allows us to specify the {descendants: false} option.
// Without {descendants: false} we are hitting bugs described in:
// https://github.com/ng-bootstrap/ng-bootstrap/issues/2240
this.titleTpl = this.titleTpls.first;
this.contentTpl = this.contentTpls.first;
}
}
NgbTab.decorators = [
{ type: Directive, args: [{ selector: 'ngb-tab' },] }
];
NgbTab.propDecorators = {
id: [{ type: Input }],
title: [{ type: Input }],
disabled: [{ type: Input }],
titleTpls: [{ type: ContentChildren, args: [NgbTabTitle, { descendants: false },] }],
contentTpls: [{ type: ContentChildren, args: [NgbTabContent, { descendants: false },] }]
};
if (false) {
/**
* The tab identifier.
*
* Must be unique for the entire document for proper accessibility support.
* @type {?}
*/
NgbTab.prototype.id;
/**
* The tab title.
*
* Use the [`NgbTabTitle`](#/components/tabset/api#NgbTabTitle) directive for non-string titles.
* @type {?}
*/
NgbTab.prototype.title;
/**
* If `true`, the current tab is disabled and can't be toggled.
* @type {?}
*/
NgbTab.prototype.disabled;
/** @type {?} */
NgbTab.prototype.titleTpl;
/** @type {?} */
NgbTab.prototype.contentTpl;
/** @type {?} */
NgbTab.prototype.titleTpls;
/** @type {?} */
NgbTab.prototype.contentTpls;
}
/**
* The payload of the change event fired right before the tab change.
* @record
*/
export function NgbTabChangeEvent() { }
if (false) {
/**
* The id of the currently active tab.
* @type {?}
*/
NgbTabChangeEvent.prototype.activeId;
/**
* The id of the newly selected tab.
* @type {?}
*/
NgbTabChangeEvent.prototype.nextId;
/**
* Calling this function will prevent tab switching.
* @type {?}
*/
NgbTabChangeEvent.prototype.preventDefault;
}
/**
* A component that makes it easy to create tabbed interface.
*/
export class NgbTabset {
/**
* @param {?} config
*/
constructor(config) {
/**
* If `true`, non-visible tabs content will be removed from DOM. Otherwise it will just be hidden.
*/
this.destroyOnHide = true;
/**
* A tab change event emitted right before the tab change happens.
*
* See [`NgbTabChangeEvent`](#/components/tabset/api#NgbTabChangeEvent) for payload details.
*/
this.tabChange = new EventEmitter();
this.type = config.type;
this.justify = config.justify;
this.orientation = config.orientation;
}
/**
* The horizontal alignment of the tabs with flexbox utilities.
* @param {?} className
* @return {?}
*/
set justify(className) {
if (className === 'fill' || className === 'justified') {
this.justifyClass = `nav-${className}`;
}
else {
this.justifyClass = `justify-content-${className}`;
}
}
/**
* Selects the tab with the given id and shows its associated content panel.
*
* Any other tab that was previously selected becomes unselected and its associated pane is removed from DOM or
* hidden depending on the `destroyOnHide` value.
* @param {?} tabId
* @return {?}
*/
select(tabId) {
/** @type {?} */
let selectedTab = this._getTabById(tabId);
if (selectedTab && !selectedTab.disabled && this.activeId !== selectedTab.id) {
/** @type {?} */
let defaultPrevented = false;
this.tabChange.emit({ activeId: this.activeId, nextId: selectedTab.id, preventDefault: (/**
* @return {?}
*/
() => { defaultPrevented = true; }) });
if (!defaultPrevented) {
this.activeId = selectedTab.id;
}
}
}
/**
* @return {?}
*/
ngAfterContentChecked() {
// auto-correct activeId that might have been set incorrectly as input
/** @type {?} */
let activeTab = this._getTabById(this.activeId);
this.activeId = activeTab ? activeTab.id : (this.tabs.length ? this.tabs.first.id : null);
}
/**
* @private
* @param {?} id
* @return {?}
*/
_getTabById(id) {
/** @type {?} */
let tabsWithId = this.tabs.filter((/**
* @param {?} tab
* @return {?}
*/
tab => tab.id === id));
return tabsWithId.length ? tabsWithId[0] : null;
}
}
NgbTabset.decorators = [
{ type: Component, args: [{
selector: 'ngb-tabset',
exportAs: 'ngbTabset',
encapsulation: ViewEncapsulation.None,
template: `
`
}] }
];
/** @nocollapse */
NgbTabset.ctorParameters = () => [
{ type: NgbTabsetConfig }
];
NgbTabset.propDecorators = {
tabs: [{ type: ContentChildren, args: [NgbTab,] }],
activeId: [{ type: Input }],
destroyOnHide: [{ type: Input }],
justify: [{ type: Input }],
orientation: [{ type: Input }],
type: [{ type: Input }],
tabChange: [{ type: Output }]
};
if (false) {
/** @type {?} */
NgbTabset.prototype.justifyClass;
/** @type {?} */
NgbTabset.prototype.tabs;
/**
* The identifier of the tab that should be opened **initially**.
*
* For subsequent tab switches use the `.select()` method and the `(tabChange)` event.
* @type {?}
*/
NgbTabset.prototype.activeId;
/**
* If `true`, non-visible tabs content will be removed from DOM. Otherwise it will just be hidden.
* @type {?}
*/
NgbTabset.prototype.destroyOnHide;
/**
* The orientation of the tabset.
* @type {?}
*/
NgbTabset.prototype.orientation;
/**
* Type of navigation to be used for tabs.
*
* Currently Bootstrap supports only `"tabs"` and `"pills"`.
*
* Since `3.0.0` can also be an arbitrary string (ex. for custom themes).
* @type {?}
*/
NgbTabset.prototype.type;
/**
* A tab change event emitted right before the tab change happens.
*
* See [`NgbTabChangeEvent`](#/components/tabset/api#NgbTabChangeEvent) for payload details.
* @type {?}
*/
NgbTabset.prototype.tabChange;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabset.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["tabset/tabset.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  Component,\n  ContentChildren,\n  Directive,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport {NgbTabsetConfig} from './tabset-config';\n\nlet nextId = 0;\n\n/**\n * A directive to wrap tab titles that need to contain HTML markup or other directives.\n *\n * Alternatively you could use the `NgbTab.title` input for string titles.\n */\n@Directive({selector: 'ng-template[ngbTabTitle]'})\nexport class NgbTabTitle {\n  constructor(public templateRef: TemplateRef<any>) {}\n}\n\n/**\n * A directive to wrap content to be displayed in a tab.\n */\n@Directive({selector: 'ng-template[ngbTabContent]'})\nexport class NgbTabContent {\n  constructor(public templateRef: TemplateRef<any>) {}\n}\n\n/**\n * A directive representing an individual tab.\n */\n@Directive({selector: 'ngb-tab'})\nexport class NgbTab implements AfterContentChecked {\n  /**\n   * The tab identifier.\n   *\n   * Must be unique for the entire document for proper accessibility support.\n   */\n  @Input() id = `ngb-tab-${nextId++}`;\n\n  /**\n   * The tab title.\n   *\n   * Use the [`NgbTabTitle`](#/components/tabset/api#NgbTabTitle) directive for non-string titles.\n   */\n  @Input() title: string;\n\n  /**\n   * If `true`, the current tab is disabled and can't be toggled.\n   */\n  @Input() disabled = false;\n\n  titleTpl: NgbTabTitle | null;\n  contentTpl: NgbTabContent | null;\n\n  @ContentChildren(NgbTabTitle, {descendants: false}) titleTpls: QueryList<NgbTabTitle>;\n  @ContentChildren(NgbTabContent, {descendants: false}) contentTpls: QueryList<NgbTabContent>;\n\n  ngAfterContentChecked() {\n    // We are using @ContentChildren instead of @ContentChild as in the Angular version being used\n    // only @ContentChildren allows us to specify the {descendants: false} option.\n    // Without {descendants: false} we are hitting bugs described in:\n    // https://github.com/ng-bootstrap/ng-bootstrap/issues/2240\n    this.titleTpl = this.titleTpls.first;\n    this.contentTpl = this.contentTpls.first;\n  }\n}\n\n/**\n * The payload of the change event fired right before the tab change.\n */\nexport interface NgbTabChangeEvent {\n  /**\n   * The id of the currently active tab.\n   */\n  activeId: string;\n\n  /**\n   * The id of the newly selected tab.\n   */\n  nextId: string;\n\n  /**\n   * Calling this function will prevent tab switching.\n   */\n  preventDefault: () => void;\n}\n\n/**\n * A component that makes it easy to create tabbed interface.\n */\n@Component({\n  selector: 'ngb-tabset',\n  exportAs: 'ngbTabset',\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <ul [class]=\"'nav nav-' + type + (orientation == 'horizontal'?  ' ' + justifyClass : ' flex-column')\" role=\"tablist\">\n      <li class=\"nav-item\" *ngFor=\"let tab of tabs\">\n        <a [id]=\"tab.id\" class=\"nav-link\" [class.active]=\"tab.id === activeId\" [class.disabled]=\"tab.disabled\"\n          href (click)=\"select(tab.id); $event.preventDefault()\" role=\"tab\" [attr.tabindex]=\"(tab.disabled ? '-1': undefined)\"\n          [attr.aria-controls]=\"(!destroyOnHide || tab.id === activeId ? tab.id + '-panel' : null)\"\n          [attr.aria-selected]=\"tab.id === activeId\" [attr.aria-disabled]=\"tab.disabled\">\n          {{tab.title}}<ng-template [ngTemplateOutlet]=\"tab.titleTpl?.templateRef\"></ng-template>\n        </a>\n      </li>\n    </ul>\n    <div class=\"tab-content\">\n      <ng-template ngFor let-tab [ngForOf]=\"tabs\">\n        <div\n          class=\"tab-pane {{tab.id === activeId ? 'active' : null}}\"\n          *ngIf=\"!destroyOnHide || tab.id === activeId\"\n          role=\"tabpanel\"\n          [attr.aria-labelledby]=\"tab.id\" id=\"{{tab.id}}-panel\">\n          <ng-template [ngTemplateOutlet]=\"tab.contentTpl?.templateRef\"></ng-template>\n        </div>\n      </ng-template>\n    </div>\n  `\n})\nexport class NgbTabset implements AfterContentChecked {\n  justifyClass: string;\n\n  @ContentChildren(NgbTab) tabs: QueryList<NgbTab>;\n\n  /**\n   * The identifier of the tab that should be opened **initially**.\n   *\n   * For subsequent tab switches use the `.select()` method and the `(tabChange)` event.\n   */\n  @Input() activeId: string;\n\n  /**\n   * If `true`, non-visible tabs content will be removed from DOM. Otherwise it will just be hidden.\n   */\n  @Input() destroyOnHide = true;\n\n  /**\n   * The horizontal alignment of the tabs with flexbox utilities.\n   */\n  @Input()\n  set justify(className: 'start' | 'center' | 'end' | 'fill' | 'justified') {\n    if (className === 'fill' || className === 'justified') {\n      this.justifyClass = `nav-${className}`;\n    } else {\n      this.justifyClass = `justify-content-${className}`;\n    }\n  }\n\n  /**\n   * The orientation of the tabset.\n   */\n  @Input() orientation: 'horizontal' | 'vertical';\n\n  /**\n   * Type of navigation to be used for tabs.\n   *\n   * Currently Bootstrap supports only `\"tabs\"` and `\"pills\"`.\n   *\n   * Since `3.0.0` can also be an arbitrary string (ex. for custom themes).\n   */\n  @Input() type: 'tabs' | 'pills' | string;\n\n  /**\n   * A tab change event emitted right before the tab change happens.\n   *\n   * See [`NgbTabChangeEvent`](#/components/tabset/api#NgbTabChangeEvent) for payload details.\n   */\n  @Output() tabChange = new EventEmitter<NgbTabChangeEvent>();\n\n  constructor(config: NgbTabsetConfig) {\n    this.type = config.type;\n    this.justify = config.justify;\n    this.orientation = config.orientation;\n  }\n\n  /**\n   * Selects the tab with the given id and shows its associated content panel.\n   *\n   * Any other tab that was previously selected becomes unselected and its associated pane is removed from DOM or\n   * hidden depending on the `destroyOnHide` value.\n   */\n  select(tabId: string) {\n    let selectedTab = this._getTabById(tabId);\n    if (selectedTab && !selectedTab.disabled && this.activeId !== selectedTab.id) {\n      let defaultPrevented = false;\n\n      this.tabChange.emit(\n          {activeId: this.activeId, nextId: selectedTab.id, preventDefault: () => { defaultPrevented = true; }});\n\n      if (!defaultPrevented) {\n        this.activeId = selectedTab.id;\n      }\n    }\n  }\n\n  ngAfterContentChecked() {\n    // auto-correct activeId that might have been set incorrectly as input\n    let activeTab = this._getTabById(this.activeId);\n    this.activeId = activeTab ? activeTab.id : (this.tabs.length ? this.tabs.first.id : null);\n  }\n\n  private _getTabById(id: string): NgbTab {\n    let tabsWithId: NgbTab[] = this.tabs.filter(tab => tab.id === id);\n    return tabsWithId.length ? tabsWithId[0] : null;\n  }\n}\n"]}