import { ChangeDetectionStrategy, Component, ContentChildren, Directive, EventEmitter, Inject, Input, Output, PLATFORM_ID, ViewEncapsulation, } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { BehaviorSubject, combineLatest, NEVER, Subject, timer, zip } from 'rxjs';
import { distinctUntilChanged, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';
import { ngbCompleteTransition, ngbRunTransition } from '../util/transition/ngbTransition';
import { ngbCarouselTransitionIn, ngbCarouselTransitionOut, NgbSlideEventDirection, } from './carousel-transition';
import * as i0 from "@angular/core";
import * as i1 from "./carousel-config";
import * as i2 from "@angular/common";
let nextId = 0;
/**
* A directive that wraps the individual carousel slide.
*/
export class NgbSlide {
constructor(tplRef) {
this.tplRef = tplRef;
/**
* Slide id that must be unique for the entire document.
*
* If not provided, will be generated in the `ngb-slide-xx` format.
*/
this.id = `ngb-slide-${nextId++}`;
/**
* An event emitted when the slide transition is finished
*
* @since 8.0.0
*/
this.slid = new EventEmitter();
}
}
NgbSlide.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbSlide, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbSlide.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbSlide, selector: "ng-template[ngbSlide]", inputs: { id: "id" }, outputs: { slid: "slid" }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbSlide, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbSlide]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; }, propDecorators: { id: [{
type: Input
}], slid: [{
type: Output
}] } });
/**
* Carousel is a component to easily create and control slideshows.
*
* Allows to set intervals, change the way user interacts with the slides and provides a programmatic API.
*/
export class NgbCarousel {
constructor(config, _platformId, _ngZone, _cd, _container) {
this._platformId = _platformId;
this._ngZone = _ngZone;
this._cd = _cd;
this._container = _container;
this.NgbSlideEventSource = NgbSlideEventSource;
this._destroy$ = new Subject();
this._interval$ = new BehaviorSubject(0);
this._mouseHover$ = new BehaviorSubject(false);
this._focused$ = new BehaviorSubject(false);
this._pauseOnHover$ = new BehaviorSubject(false);
this._pauseOnFocus$ = new BehaviorSubject(false);
this._pause$ = new BehaviorSubject(false);
this._wrap$ = new BehaviorSubject(false);
/**
* An event emitted just before the slide transition starts.
*
* See [`NgbSlideEvent`](#/components/carousel/api#NgbSlideEvent) for payload details.
*/
this.slide = new EventEmitter();
/**
* An event emitted right after the slide transition is completed.
*
* See [`NgbSlideEvent`](#/components/carousel/api#NgbSlideEvent) for payload details.
*
* @since 8.0.0
*/
this.slid = new EventEmitter();
/*
* Keep the ids of the panels currently transitionning
* in order to allow only the transition revertion
*/
this._transitionIds = null;
this.animation = config.animation;
this.interval = config.interval;
this.wrap = config.wrap;
this.keyboard = config.keyboard;
this.pauseOnHover = config.pauseOnHover;
this.pauseOnFocus = config.pauseOnFocus;
this.showNavigationArrows = config.showNavigationArrows;
this.showNavigationIndicators = config.showNavigationIndicators;
}
/**
* Time in milliseconds before the next slide is shown.
*/
set interval(value) {
this._interval$.next(value);
}
get interval() {
return this._interval$.value;
}
/**
* If `true`, will 'wrap' the carousel by switching from the last slide back to the first.
*/
set wrap(value) {
this._wrap$.next(value);
}
get wrap() {
return this._wrap$.value;
}
/**
* If `true`, will pause slide switching when mouse cursor hovers the slide.
*
* @since 2.2.0
*/
set pauseOnHover(value) {
this._pauseOnHover$.next(value);
}
get pauseOnHover() {
return this._pauseOnHover$.value;
}
/**
* If `true`, will pause slide switching when the focus is inside the carousel.
*/
set pauseOnFocus(value) {
this._pauseOnFocus$.next(value);
}
get pauseOnFocus() {
return this._pauseOnFocus$.value;
}
set mouseHover(value) {
this._mouseHover$.next(value);
}
get mouseHover() {
return this._mouseHover$.value;
}
set focused(value) {
this._focused$.next(value);
}
get focused() {
return this._focused$.value;
}
arrowLeft() {
this.focus();
this.prev(NgbSlideEventSource.ARROW_LEFT);
}
arrowRight() {
this.focus();
this.next(NgbSlideEventSource.ARROW_RIGHT);
}
ngAfterContentInit() {
// setInterval() doesn't play well with SSR and protractor,
// so we should run it in the browser and outside Angular
if (isPlatformBrowser(this._platformId)) {
this._ngZone.runOutsideAngular(() => {
const hasNextSlide$ = combineLatest([
this.slide.pipe(map((slideEvent) => slideEvent.current), startWith(this.activeId)),
this._wrap$,
this.slides.changes.pipe(startWith(null)),
]).pipe(map(([currentSlideId, wrap]) => {
const slideArr = this.slides.toArray();
const currentSlideIdx = this._getSlideIdxById(currentSlideId);
return wrap ? slideArr.length > 1 : currentSlideIdx < slideArr.length - 1;
}), distinctUntilChanged());
combineLatest([
this._pause$,
this._pauseOnHover$,
this._mouseHover$,
this._pauseOnFocus$,
this._focused$,
this._interval$,
hasNextSlide$,
])
.pipe(map(([pause, pauseOnHover, mouseHover, pauseOnFocus, focused, interval, hasNextSlide]) => pause || (pauseOnHover && mouseHover) || (pauseOnFocus && focused) || !hasNextSlide ? 0 : interval), distinctUntilChanged(), switchMap((interval) => (interval > 0 ? timer(interval, interval) : NEVER)), takeUntil(this._destroy$))
.subscribe(() => this._ngZone.run(() => this.next(NgbSlideEventSource.TIMER)));
});
}
this.slides.changes.pipe(takeUntil(this._destroy$)).subscribe(() => {
this._transitionIds?.forEach((id) => ngbCompleteTransition(this._getSlideElement(id)));
this._transitionIds = null;
this._cd.markForCheck();
// The following code need to be done asynchronously, after the dom becomes stable,
// otherwise all changes will be undone.
this._ngZone.onStable.pipe(take(1)).subscribe(() => {
for (const { id } of this.slides) {
const element = this._getSlideElement(id);
if (id === this.activeId) {
element.classList.add('active');
}
else {
element.classList.remove('active');
}
}
});
});
}
ngAfterContentChecked() {
let activeSlide = this._getSlideById(this.activeId);
this.activeId = activeSlide ? activeSlide.id : this.slides.length ? this.slides.first.id : '';
}
ngAfterViewInit() {
// Initialize the 'active' class (not managed by the template)
if (this.activeId) {
const element = this._getSlideElement(this.activeId);
if (element) {
element.classList.add('active');
}
}
}
ngOnDestroy() {
this._destroy$.next();
}
/**
* Navigates to a slide with the specified identifier.
*/
select(slideId, source) {
this._cycleToSelected(slideId, this._getSlideEventDirection(this.activeId, slideId), source);
}
/**
* Navigates to the previous slide.
*/
prev(source) {
this._cycleToSelected(this._getPrevSlide(this.activeId), NgbSlideEventDirection.END, source);
}
/**
* Navigates to the next slide.
*/
next(source) {
this._cycleToSelected(this._getNextSlide(this.activeId), NgbSlideEventDirection.START, source);
}
/**
* Pauses cycling through the slides.
*/
pause() {
this._pause$.next(true);
}
/**
* Restarts cycling through the slides from start to end.
*/
cycle() {
this._pause$.next(false);
}
/**
* Set the focus on the carousel.
*/
focus() {
this._container.nativeElement.focus();
}
_cycleToSelected(slideIdx, direction, source) {
const transitionIds = this._transitionIds;
if (transitionIds && (transitionIds[0] !== slideIdx || transitionIds[1] !== this.activeId)) {
// Revert prevented
return;
}
let selectedSlide = this._getSlideById(slideIdx);
if (selectedSlide && selectedSlide.id !== this.activeId) {
this._transitionIds = [this.activeId, slideIdx];
this.slide.emit({
prev: this.activeId,
current: selectedSlide.id,
direction: direction,
paused: this._pause$.value,
source,
});
const options = {
animation: this.animation,
runningTransition: 'stop',
context: { direction },
};
const transitions = [];
const activeSlide = this._getSlideById(this.activeId);
if (activeSlide) {
const activeSlideTransition = ngbRunTransition(this._ngZone, this._getSlideElement(activeSlide.id), ngbCarouselTransitionOut, options);
activeSlideTransition.subscribe(() => {
activeSlide.slid.emit({ isShown: false, direction, source });
});
transitions.push(activeSlideTransition);
}
const previousId = this.activeId;
this.activeId = selectedSlide.id;
const nextSlide = this._getSlideById(this.activeId);
const transition = ngbRunTransition(this._ngZone, this._getSlideElement(selectedSlide.id), ngbCarouselTransitionIn, options);
transition.subscribe(() => {
nextSlide?.slid.emit({ isShown: true, direction, source });
});
transitions.push(transition);
zip(...transitions)
.pipe(take(1))
.subscribe(() => {
this._transitionIds = null;
this.slid.emit({
prev: previousId,
current: selectedSlide.id,
direction: direction,
paused: this._pause$.value,
source,
});
});
}
// we get here after the interval fires or any external API call like next(), prev() or select()
this._cd.markForCheck();
}
_getSlideEventDirection(currentActiveSlideId, nextActiveSlideId) {
const currentActiveSlideIdx = this._getSlideIdxById(currentActiveSlideId);
const nextActiveSlideIdx = this._getSlideIdxById(nextActiveSlideId);
return currentActiveSlideIdx > nextActiveSlideIdx ? NgbSlideEventDirection.END : NgbSlideEventDirection.START;
}
_getSlideById(slideId) {
return this.slides.find((slide) => slide.id === slideId) || null;
}
_getSlideIdxById(slideId) {
const slide = this._getSlideById(slideId);
return slide != null ? this.slides.toArray().indexOf(slide) : -1;
}
_getNextSlide(currentSlideId) {
const slideArr = this.slides.toArray();
const currentSlideIdx = this._getSlideIdxById(currentSlideId);
const isLastSlide = currentSlideIdx === slideArr.length - 1;
return isLastSlide
? this.wrap
? slideArr[0].id
: slideArr[slideArr.length - 1].id
: slideArr[currentSlideIdx + 1].id;
}
_getPrevSlide(currentSlideId) {
const slideArr = this.slides.toArray();
const currentSlideIdx = this._getSlideIdxById(currentSlideId);
const isFirstSlide = currentSlideIdx === 0;
return isFirstSlide
? this.wrap
? slideArr[slideArr.length - 1].id
: slideArr[0].id
: slideArr[currentSlideIdx - 1].id;
}
_getSlideElement(slideId) {
return this._container.nativeElement.querySelector(`#slide-${slideId}`);
}
}
NgbCarousel.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbCarousel, deps: [{ token: i1.NgbCarouselConfig }, { token: PLATFORM_ID }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
NgbCarousel.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.6", type: NgbCarousel, selector: "ngb-carousel", inputs: { animation: "animation", activeId: "activeId", interval: "interval", wrap: "wrap", keyboard: "keyboard", pauseOnHover: "pauseOnHover", pauseOnFocus: "pauseOnFocus", showNavigationArrows: "showNavigationArrows", showNavigationIndicators: "showNavigationIndicators" }, outputs: { slide: "slide", slid: "slid" }, host: { attributes: { "tabIndex": "0" }, listeners: { "keydown.arrowLeft": "keyboard && arrowLeft()", "keydown.arrowRight": "keyboard && arrowRight()", "mouseenter": "mouseHover = true", "mouseleave": "mouseHover = false", "focusin": "focused = true", "focusout": "focused = false" }, properties: { "style.display": "\"block\"", "attr.aria-activedescendant": "'slide-' + activeId" }, classAttribute: "carousel slide" }, queries: [{ propertyName: "slides", predicate: NgbSlide }], exportAs: ["ngbCarousel"], ngImport: i0, template: `
Slide {{ i + 1 }} of {{ c }}
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbCarousel, decorators: [{
type: Component,
args: [{
selector: 'ngb-carousel',
exportAs: 'ngbCarousel',
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
host: {
class: 'carousel slide',
'[style.display]': '"block"',
tabIndex: '0',
'(keydown.arrowLeft)': 'keyboard && arrowLeft()',
'(keydown.arrowRight)': 'keyboard && arrowRight()',
'(mouseenter)': 'mouseHover = true',
'(mouseleave)': 'mouseHover = false',
'(focusin)': 'focused = true',
'(focusout)': 'focused = false',
'[attr.aria-activedescendant]': `'slide-' + activeId`,
},
template: `
Slide {{ i + 1 }} of {{ c }}
`,
}]
}], ctorParameters: function () { return [{ type: i1.NgbCarouselConfig }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { slides: [{
type: ContentChildren,
args: [NgbSlide]
}], animation: [{
type: Input
}], activeId: [{
type: Input
}], interval: [{
type: Input
}], wrap: [{
type: Input
}], keyboard: [{
type: Input
}], pauseOnHover: [{
type: Input
}], pauseOnFocus: [{
type: Input
}], showNavigationArrows: [{
type: Input
}], showNavigationIndicators: [{
type: Input
}], slide: [{
type: Output
}], slid: [{
type: Output
}] } });
export var NgbSlideEventSource;
(function (NgbSlideEventSource) {
NgbSlideEventSource["TIMER"] = "timer";
NgbSlideEventSource["ARROW_LEFT"] = "arrowLeft";
NgbSlideEventSource["ARROW_RIGHT"] = "arrowRight";
NgbSlideEventSource["INDICATOR"] = "indicator";
})(NgbSlideEventSource || (NgbSlideEventSource = {}));
export const NGB_CAROUSEL_DIRECTIVES = [NgbCarousel, NgbSlide];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.js","sourceRoot":"","sources":["../../../../src/carousel/carousel.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterContentChecked,\n\tAfterContentInit,\n\tChangeDetectionStrategy,\n\tChangeDetectorRef,\n\tComponent,\n\tContentChildren,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tInject,\n\tInput,\n\tNgZone,\n\tOnDestroy,\n\tOutput,\n\tPLATFORM_ID,\n\tQueryList,\n\tTemplateRef,\n\tViewEncapsulation,\n\tAfterViewInit,\n} from '@angular/core';\nimport { isPlatformBrowser } from '@angular/common';\n\nimport { NgbCarouselConfig } from './carousel-config';\n\nimport { BehaviorSubject, combineLatest, NEVER, Observable, Subject, timer, zip } from 'rxjs';\nimport { distinctUntilChanged, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { ngbCompleteTransition, ngbRunTransition, NgbTransitionOptions } from '../util/transition/ngbTransition';\nimport {\n\tngbCarouselTransitionIn,\n\tngbCarouselTransitionOut,\n\tNgbSlideEventDirection,\n\tNgbCarouselCtx,\n} from './carousel-transition';\n\nlet nextId = 0;\n\n/**\n * A directive that wraps the individual carousel slide.\n */\n@Directive({ selector: 'ng-template[ngbSlide]' })\nexport class NgbSlide {\n\t/**\n\t * Slide id that must be unique for the entire document.\n\t *\n\t * If not provided, will be generated in the `ngb-slide-xx` format.\n\t */\n\t@Input() id = `ngb-slide-${nextId++}`;\n\n\t/**\n\t * An event emitted when the slide transition is finished\n\t *\n\t * @since 8.0.0\n\t */\n\t@Output() slid = new EventEmitter<NgbSingleSlideEvent>();\n\n\tconstructor(public tplRef: TemplateRef<any>) {}\n}\n\n/**\n * Carousel is a component to easily create and control slideshows.\n *\n * Allows to set intervals, change the way user interacts with the slides and provides a programmatic API.\n */\n@Component({\n\tselector: 'ngb-carousel',\n\texportAs: 'ngbCarousel',\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\tclass: 'carousel slide',\n\t\t'[style.display]': '\"block\"',\n\t\ttabIndex: '0',\n\t\t'(keydown.arrowLeft)': 'keyboard && arrowLeft()',\n\t\t'(keydown.arrowRight)': 'keyboard && arrowRight()',\n\t\t'(mouseenter)': 'mouseHover = true',\n\t\t'(mouseleave)': 'mouseHover = false',\n\t\t'(focusin)': 'focused = true',\n\t\t'(focusout)': 'focused = false',\n\t\t'[attr.aria-activedescendant]': `'slide-' + activeId`,\n\t},\n\ttemplate: `\n\t\t<div class=\"carousel-indicators\" [class.visually-hidden]=\"!showNavigationIndicators\" role=\"tablist\">\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tdata-bs-target\n\t\t\t\t*ngFor=\"let slide of slides\"\n\t\t\t\t[class.active]=\"slide.id === activeId\"\n\t\t\t\trole=\"tab\"\n\t\t\t\t[attr.aria-labelledby]=\"'slide-' + slide.id\"\n\t\t\t\t[attr.aria-controls]=\"'slide-' + slide.id\"\n\t\t\t\t[attr.aria-selected]=\"slide.id === activeId\"\n\t\t\t\t(click)=\"focus(); select(slide.id, NgbSlideEventSource.INDICATOR)\"\n\t\t\t></button>\n\t\t</div>\n\t\t<div class=\"carousel-inner\">\n\t\t\t<div\n\t\t\t\t*ngFor=\"let slide of slides; index as i; count as c\"\n\t\t\t\tclass=\"carousel-item\"\n\t\t\t\t[id]=\"'slide-' + slide.id\"\n\t\t\t\trole=\"tabpanel\"\n\t\t\t>\n\t\t\t\t<span\n\t\t\t\t\tclass=\"visually-hidden\"\n\t\t\t\t\ti18n=\"Currently selected slide number read by screen reader@@ngb.carousel.slide-number\"\n\t\t\t\t>\n\t\t\t\t\tSlide {{ i + 1 }} of {{ c }}\n\t\t\t\t</span>\n\t\t\t\t<ng-template [ngTemplateOutlet]=\"slide.tplRef\"></ng-template>\n\t\t\t</div>\n\t\t</div>\n\t\t<button class=\"carousel-control-prev\" type=\"button\" (click)=\"arrowLeft()\" *ngIf=\"showNavigationArrows\">\n\t\t\t<span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.carousel.previous\">Previous</span>\n\t\t</button>\n\t\t<button class=\"carousel-control-next\" type=\"button\" (click)=\"arrowRight()\" *ngIf=\"showNavigationArrows\">\n\t\t\t<span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.carousel.next\">Next</span>\n\t\t</button>\n\t`,\n})\nexport class NgbCarousel implements AfterContentChecked, AfterContentInit, AfterViewInit, OnDestroy {\n\t@ContentChildren(NgbSlide) slides: QueryList<NgbSlide>;\n\n\tpublic NgbSlideEventSource = NgbSlideEventSource;\n\n\tprivate _destroy$ = new Subject<void>();\n\tprivate _interval$ = new BehaviorSubject(0);\n\tprivate _mouseHover$ = new BehaviorSubject(false);\n\tprivate _focused$ = new BehaviorSubject(false);\n\tprivate _pauseOnHover$ = new BehaviorSubject(false);\n\tprivate _pauseOnFocus$ = new BehaviorSubject(false);\n\tprivate _pause$ = new BehaviorSubject(false);\n\tprivate _wrap$ = new BehaviorSubject(false);\n\n\t/**\n\t * A flag to enable/disable the animations.\n\t *\n\t * @since 8.0.0\n\t */\n\t@Input() animation: boolean;\n\n\t/**\n\t * The slide id that should be displayed **initially**.\n\t *\n\t * For subsequent interactions use methods `select()`, `next()`, etc. and the `(slide)` output.\n\t */\n\t@Input() activeId: string;\n\n\t/**\n\t * Time in milliseconds before the next slide is shown.\n\t */\n\t@Input()\n\tset interval(value: number) {\n\t\tthis._interval$.next(value);\n\t}\n\n\tget interval() {\n\t\treturn this._interval$.value;\n\t}\n\n\t/**\n\t * If `true`, will 'wrap' the carousel by switching from the last slide back to the first.\n\t */\n\t@Input()\n\tset wrap(value: boolean) {\n\t\tthis._wrap$.next(value);\n\t}\n\n\tget wrap() {\n\t\treturn this._wrap$.value;\n\t}\n\n\t/**\n\t * If `true`, allows to interact with carousel using keyboard 'arrow left' and 'arrow right'.\n\t */\n\t@Input() keyboard: boolean;\n\n\t/**\n\t * If `true`, will pause slide switching when mouse cursor hovers the slide.\n\t *\n\t * @since 2.2.0\n\t */\n\t@Input()\n\tset pauseOnHover(value: boolean) {\n\t\tthis._pauseOnHover$.next(value);\n\t}\n\n\tget pauseOnHover() {\n\t\treturn this._pauseOnHover$.value;\n\t}\n\n\t/**\n\t * If `true`, will pause slide switching when the focus is inside the carousel.\n\t */\n\t@Input()\n\tset pauseOnFocus(value: boolean) {\n\t\tthis._pauseOnFocus$.next(value);\n\t}\n\n\tget pauseOnFocus() {\n\t\treturn this._pauseOnFocus$.value;\n\t}\n\n\t/**\n\t * If `true`, 'previous' and 'next' navigation arrows will be visible on the slide.\n\t *\n\t * @since 2.2.0\n\t */\n\t@Input() showNavigationArrows: boolean;\n\n\t/**\n\t * If `true`, navigation indicators at the bottom of the slide will be visible.\n\t *\n\t * @since 2.2.0\n\t */\n\t@Input() showNavigationIndicators: boolean;\n\n\t/**\n\t * An event emitted just before the slide transition starts.\n\t *\n\t * See [`NgbSlideEvent`](#/components/carousel/api#NgbSlideEvent) for payload details.\n\t */\n\t@Output() slide = new EventEmitter<NgbSlideEvent>();\n\n\t/**\n\t * An event emitted right after the slide transition is completed.\n\t *\n\t * See [`NgbSlideEvent`](#/components/carousel/api#NgbSlideEvent) for payload details.\n\t *\n\t * @since 8.0.0\n\t */\n\t@Output() slid = new EventEmitter<NgbSlideEvent>();\n\n\t/*\n\t * Keep the ids of the panels currently transitionning\n\t * in order to allow only the transition revertion\n\t */\n\tprivate _transitionIds: [string, string] | null = null;\n\n\tset mouseHover(value: boolean) {\n\t\tthis._mouseHover$.next(value);\n\t}\n\n\tget mouseHover() {\n\t\treturn this._mouseHover$.value;\n\t}\n\n\tset focused(value: boolean) {\n\t\tthis._focused$.next(value);\n\t}\n\n\tget focused() {\n\t\treturn this._focused$.value;\n\t}\n\n\tconstructor(\n\t\tconfig: NgbCarouselConfig,\n\t\t@Inject(PLATFORM_ID) private _platformId,\n\t\tprivate _ngZone: NgZone,\n\t\tprivate _cd: ChangeDetectorRef,\n\t\tprivate _container: ElementRef,\n\t) {\n\t\tthis.animation = config.animation;\n\t\tthis.interval = config.interval;\n\t\tthis.wrap = config.wrap;\n\t\tthis.keyboard = config.keyboard;\n\t\tthis.pauseOnHover = config.pauseOnHover;\n\t\tthis.pauseOnFocus = config.pauseOnFocus;\n\t\tthis.showNavigationArrows = config.showNavigationArrows;\n\t\tthis.showNavigationIndicators = config.showNavigationIndicators;\n\t}\n\n\tarrowLeft() {\n\t\tthis.focus();\n\t\tthis.prev(NgbSlideEventSource.ARROW_LEFT);\n\t}\n\n\tarrowRight() {\n\t\tthis.focus();\n\t\tthis.next(NgbSlideEventSource.ARROW_RIGHT);\n\t}\n\n\tngAfterContentInit() {\n\t\t// setInterval() doesn't play well with SSR and protractor,\n\t\t// so we should run it in the browser and outside Angular\n\t\tif (isPlatformBrowser(this._platformId)) {\n\t\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\t\tconst hasNextSlide$ = combineLatest([\n\t\t\t\t\tthis.slide.pipe(\n\t\t\t\t\t\tmap((slideEvent) => slideEvent.current),\n\t\t\t\t\t\tstartWith(this.activeId),\n\t\t\t\t\t),\n\t\t\t\t\tthis._wrap$,\n\t\t\t\t\tthis.slides.changes.pipe(startWith(null)),\n\t\t\t\t]).pipe(\n\t\t\t\t\tmap(([currentSlideId, wrap]) => {\n\t\t\t\t\t\tconst slideArr = this.slides.toArray();\n\t\t\t\t\t\tconst currentSlideIdx = this._getSlideIdxById(currentSlideId);\n\t\t\t\t\t\treturn wrap ? slideArr.length > 1 : currentSlideIdx < slideArr.length - 1;\n\t\t\t\t\t}),\n\t\t\t\t\tdistinctUntilChanged(),\n\t\t\t\t);\n\t\t\t\tcombineLatest([\n\t\t\t\t\tthis._pause$,\n\t\t\t\t\tthis._pauseOnHover$,\n\t\t\t\t\tthis._mouseHover$,\n\t\t\t\t\tthis._pauseOnFocus$,\n\t\t\t\t\tthis._focused$,\n\t\t\t\t\tthis._interval$,\n\t\t\t\t\thasNextSlide$,\n\t\t\t\t])\n\t\t\t\t\t.pipe(\n\t\t\t\t\t\tmap(\n\t\t\t\t\t\t\t([pause, pauseOnHover, mouseHover, pauseOnFocus, focused, interval, hasNextSlide]: [\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t\tnumber,\n\t\t\t\t\t\t\t\tboolean,\n\t\t\t\t\t\t\t]) =>\n\t\t\t\t\t\t\t\tpause || (pauseOnHover && mouseHover) || (pauseOnFocus && focused) || !hasNextSlide ? 0 : interval,\n\t\t\t\t\t\t),\n\n\t\t\t\t\t\tdistinctUntilChanged(),\n\t\t\t\t\t\tswitchMap((interval) => (interval > 0 ? timer(interval, interval) : NEVER)),\n\t\t\t\t\t\ttakeUntil(this._destroy$),\n\t\t\t\t\t)\n\t\t\t\t\t.subscribe(() => this._ngZone.run(() => this.next(NgbSlideEventSource.TIMER)));\n\t\t\t});\n\t\t}\n\n\t\tthis.slides.changes.pipe(takeUntil(this._destroy$)).subscribe(() => {\n\t\t\tthis._transitionIds?.forEach((id) => ngbCompleteTransition(this._getSlideElement(id)));\n\t\t\tthis._transitionIds = null;\n\n\t\t\tthis._cd.markForCheck();\n\n\t\t\t// The following code need to be done asynchronously, after the dom becomes stable,\n\t\t\t// otherwise all changes will be undone.\n\t\t\tthis._ngZone.onStable.pipe(take(1)).subscribe(() => {\n\t\t\t\tfor (const { id } of this.slides) {\n\t\t\t\t\tconst element = this._getSlideElement(id);\n\t\t\t\t\tif (id === this.activeId) {\n\t\t\t\t\t\telement.classList.add('active');\n\t\t\t\t\t} else {\n\t\t\t\t\t\telement.classList.remove('active');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tngAfterContentChecked() {\n\t\tlet activeSlide = this._getSlideById(this.activeId);\n\t\tthis.activeId = activeSlide ? activeSlide.id : this.slides.length ? this.slides.first.id : '';\n\t}\n\n\tngAfterViewInit() {\n\t\t// Initialize the 'active' class (not managed by the template)\n\t\tif (this.activeId) {\n\t\t\tconst element = this._getSlideElement(this.activeId);\n\t\t\tif (element) {\n\t\t\t\telement.classList.add('active');\n\t\t\t}\n\t\t}\n\t}\n\n\tngOnDestroy() {\n\t\tthis._destroy$.next();\n\t}\n\n\t/**\n\t * Navigates to a slide with the specified identifier.\n\t */\n\tselect(slideId: string, source?: NgbSlideEventSource) {\n\t\tthis._cycleToSelected(slideId, this._getSlideEventDirection(this.activeId, slideId), source);\n\t}\n\n\t/**\n\t * Navigates to the previous slide.\n\t */\n\tprev(source?: NgbSlideEventSource) {\n\t\tthis._cycleToSelected(this._getPrevSlide(this.activeId), NgbSlideEventDirection.END, source);\n\t}\n\n\t/**\n\t * Navigates to the next slide.\n\t */\n\tnext(source?: NgbSlideEventSource) {\n\t\tthis._cycleToSelected(this._getNextSlide(this.activeId), NgbSlideEventDirection.START, source);\n\t}\n\n\t/**\n\t * Pauses cycling through the slides.\n\t */\n\tpause() {\n\t\tthis._pause$.next(true);\n\t}\n\n\t/**\n\t * Restarts cycling through the slides from start to end.\n\t */\n\tcycle() {\n\t\tthis._pause$.next(false);\n\t}\n\n\t/**\n\t * Set the focus on the carousel.\n\t */\n\tfocus() {\n\t\tthis._container.nativeElement.focus();\n\t}\n\n\tprivate _cycleToSelected(slideIdx: string, direction: NgbSlideEventDirection, source?: NgbSlideEventSource) {\n\t\tconst transitionIds = this._transitionIds;\n\t\tif (transitionIds && (transitionIds[0] !== slideIdx || transitionIds[1] !== this.activeId)) {\n\t\t\t// Revert prevented\n\t\t\treturn;\n\t\t}\n\n\t\tlet selectedSlide = this._getSlideById(slideIdx);\n\t\tif (selectedSlide && selectedSlide.id !== this.activeId) {\n\t\t\tthis._transitionIds = [this.activeId, slideIdx];\n\t\t\tthis.slide.emit({\n\t\t\t\tprev: this.activeId,\n\t\t\t\tcurrent: selectedSlide.id,\n\t\t\t\tdirection: direction,\n\t\t\t\tpaused: this._pause$.value,\n\t\t\t\tsource,\n\t\t\t});\n\n\t\t\tconst options: NgbTransitionOptions<NgbCarouselCtx> = {\n\t\t\t\tanimation: this.animation,\n\t\t\t\trunningTransition: 'stop',\n\t\t\t\tcontext: { direction },\n\t\t\t};\n\n\t\t\tconst transitions: Array<Observable<any>> = [];\n\t\t\tconst activeSlide = this._getSlideById(this.activeId);\n\t\t\tif (activeSlide) {\n\t\t\t\tconst activeSlideTransition = ngbRunTransition(\n\t\t\t\t\tthis._ngZone,\n\t\t\t\t\tthis._getSlideElement(activeSlide.id),\n\t\t\t\t\tngbCarouselTransitionOut,\n\t\t\t\t\toptions,\n\t\t\t\t);\n\t\t\t\tactiveSlideTransition.subscribe(() => {\n\t\t\t\t\tactiveSlide.slid.emit({ isShown: false, direction, source });\n\t\t\t\t});\n\t\t\t\ttransitions.push(activeSlideTransition);\n\t\t\t}\n\n\t\t\tconst previousId = this.activeId;\n\t\t\tthis.activeId = selectedSlide.id;\n\t\t\tconst nextSlide = this._getSlideById(this.activeId);\n\t\t\tconst transition = ngbRunTransition(\n\t\t\t\tthis._ngZone,\n\t\t\t\tthis._getSlideElement(selectedSlide.id),\n\t\t\t\tngbCarouselTransitionIn,\n\t\t\t\toptions,\n\t\t\t);\n\t\t\ttransition.subscribe(() => {\n\t\t\t\tnextSlide?.slid.emit({ isShown: true, direction, source });\n\t\t\t});\n\t\t\ttransitions.push(transition);\n\n\t\t\tzip(...transitions)\n\t\t\t\t.pipe(take(1))\n\t\t\t\t.subscribe(() => {\n\t\t\t\t\tthis._transitionIds = null;\n\t\t\t\t\tthis.slid.emit({\n\t\t\t\t\t\tprev: previousId,\n\t\t\t\t\t\tcurrent: selectedSlide!.id,\n\t\t\t\t\t\tdirection: direction,\n\t\t\t\t\t\tpaused: this._pause$.value,\n\t\t\t\t\t\tsource,\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t}\n\n\t\t// we get here after the interval fires or any external API call like next(), prev() or select()\n\t\tthis._cd.markForCheck();\n\t}\n\n\tprivate _getSlideEventDirection(currentActiveSlideId: string, nextActiveSlideId: string): NgbSlideEventDirection {\n\t\tconst currentActiveSlideIdx = this._getSlideIdxById(currentActiveSlideId);\n\t\tconst nextActiveSlideIdx = this._getSlideIdxById(nextActiveSlideId);\n\n\t\treturn currentActiveSlideIdx > nextActiveSlideIdx ? NgbSlideEventDirection.END : NgbSlideEventDirection.START;\n\t}\n\n\tprivate _getSlideById(slideId: string): NgbSlide | null {\n\t\treturn this.slides.find((slide) => slide.id === slideId) || null;\n\t}\n\n\tprivate _getSlideIdxById(slideId: string): number {\n\t\tconst slide = this._getSlideById(slideId);\n\t\treturn slide != null ? this.slides.toArray().indexOf(slide) : -1;\n\t}\n\n\tprivate _getNextSlide(currentSlideId: string): string {\n\t\tconst slideArr = this.slides.toArray();\n\t\tconst currentSlideIdx = this._getSlideIdxById(currentSlideId);\n\t\tconst isLastSlide = currentSlideIdx === slideArr.length - 1;\n\n\t\treturn isLastSlide\n\t\t\t? this.wrap\n\t\t\t\t? slideArr[0].id\n\t\t\t\t: slideArr[slideArr.length - 1].id\n\t\t\t: slideArr[currentSlideIdx + 1].id;\n\t}\n\n\tprivate _getPrevSlide(currentSlideId: string): string {\n\t\tconst slideArr = this.slides.toArray();\n\t\tconst currentSlideIdx = this._getSlideIdxById(currentSlideId);\n\t\tconst isFirstSlide = currentSlideIdx === 0;\n\n\t\treturn isFirstSlide\n\t\t\t? this.wrap\n\t\t\t\t? slideArr[slideArr.length - 1].id\n\t\t\t\t: slideArr[0].id\n\t\t\t: slideArr[currentSlideIdx - 1].id;\n\t}\n\n\tprivate _getSlideElement(slideId: string): HTMLElement {\n\t\treturn this._container.nativeElement.querySelector(`#slide-${slideId}`);\n\t}\n}\n\n/**\n * A slide change event emitted right after the slide transition is completed.\n */\nexport interface NgbSlideEvent {\n\t/**\n\t * The previous slide id.\n\t */\n\tprev: string;\n\n\t/**\n\t * The current slide id.\n\t */\n\tcurrent: string;\n\n\t/**\n\t * The slide event direction.\n\t *\n\t * <span class=\"badge bg-info text-dark\">since 12.0.0</span> Possible values are `'start' | 'end'`.\n\t *\n\t * <span class=\"badge bg-secondary\">before 12.0.0</span> Possible values were `'left' | 'right'`.\n\t */\n\tdirection: NgbSlideEventDirection;\n\n\t/**\n\t * Whether the pause() method was called (and no cycle() call was done afterwards).\n\t *\n\t * @since 5.1.0\n\t */\n\tpaused: boolean;\n\n\t/**\n\t * Source triggering the slide change event.\n\t *\n\t * Possible values are `'timer' | 'arrowLeft' | 'arrowRight' | 'indicator'`\n\t *\n\t * @since 5.1.0\n\t */\n\tsource?: NgbSlideEventSource;\n}\n\n/**\n * A slide change event emitted right after the slide transition is completed.\n *\n * @since 8.0.0\n */\nexport interface NgbSingleSlideEvent {\n\t/**\n\t * true if the slide is shown, false otherwise\n\t */\n\tisShown: boolean;\n\n\t/**\n\t * The slide event direction.\n\t *\n\t * <span class=\"badge bg-info text-dark\">since 12.0.0</span> Possible values are `'start' | 'end'`.\n\t *\n\t * <span class=\"badge bg-secondary\">before 12.0.0</span> Possible values were `'left' | 'right'`.\n\t */\n\tdirection: NgbSlideEventDirection;\n\n\t/**\n\t * Source triggering the slide change event.\n\t *\n\t * Possible values are `'timer' | 'arrowLeft' | 'arrowRight' | 'indicator'`\n\t *\n\t */\n\tsource?: NgbSlideEventSource;\n}\n\nexport enum NgbSlideEventSource {\n\tTIMER = 'timer',\n\tARROW_LEFT = 'arrowLeft',\n\tARROW_RIGHT = 'arrowRight',\n\tINDICATOR = 'indicator',\n}\n\nexport const NGB_CAROUSEL_DIRECTIVES = [NgbCarousel, NgbSlide];\n"]}