ng2-bs3-modal
Version:
Angular Boostrap 3 Modal Component
417 lines (416 loc) • 37.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ElementRef, HostBinding, NgZone } from '@angular/core';
import { Observable, Subject, of as observableOf, fromEvent, merge, zip } from 'rxjs';
import { take, filter, tap, share, map } from 'rxjs/operators';
import { BsModalHideType, BsModalSize } from './models';
import { BsModalService } from './modal.service';
/** @type {?} */
const EVENT_SUFFIX = 'ng2-bs3-modal';
/** @type {?} */
const SHOW_EVENT_NAME = `show.bs.modal.${EVENT_SUFFIX}`;
/** @type {?} */
const SHOWN_EVENT_NAME = `shown.bs.modal.${EVENT_SUFFIX}`;
/** @type {?} */
const HIDE_EVENT_NAME = `hide.bs.modal.${EVENT_SUFFIX}`;
/** @type {?} */
const HIDDEN_EVENT_NAME = `hidden.bs.modal.${EVENT_SUFFIX}`;
/** @type {?} */
const LOADED_EVENT_NAME = `loaded.bs.modal.${EVENT_SUFFIX}`;
/** @type {?} */
const DATA_KEY = 'bs.modal';
export class BsModalComponent {
/**
* @param {?} element
* @param {?} service
* @param {?} zone
*/
constructor(element, service, zone) {
this.element = element;
this.service = service;
this.zone = zone;
this.overrideSize = null;
this.onInternalClose$ = new Subject();
this.subscriptions = [];
this.visible = false;
this.showing = false;
this.hiding = false;
this.animation = true;
this.backdrop = true;
this.keyboard = true;
this.onShow = new EventEmitter();
this.onOpen = new EventEmitter();
this.onHide = new EventEmitter();
this.onClose = new EventEmitter();
this.onDismiss = new EventEmitter();
this.onLoaded = new EventEmitter();
this.setVisible = (isVisible) => {
return () => {
this.visible = isVisible;
this.showing = false;
this.hiding = false;
};
};
this.setOptions = (options) => {
/** @type {?} */
let backdrop = options.backdrop;
if (typeof backdrop === 'string' && backdrop !== 'static') {
backdrop = true;
}
if (options.backdrop !== undefined) {
this.options.backdrop = backdrop;
}
if (options.keyboard !== undefined) {
this.options.keyboard = options.keyboard;
}
};
this.service.add(this);
this.init();
}
/**
* @return {?}
*/
get options() {
if (!this.$modal) {
this.init();
}
return this.$modal.data(DATA_KEY).options;
}
/**
* @return {?}
*/
get fadeClass() { return this.animation; }
/**
* @return {?}
*/
get modalClass() { return true; }
/**
* @return {?}
*/
get roleAttr() { return 'dialog'; }
/**
* @return {?}
*/
get tabindexAttr() { return '-1'; }
/**
* @return {?}
*/
ngOnInit() {
this.wireUpEventEmitters();
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.$dialog = this.$modal.find('.modal-dialog');
}
/**
* @return {?}
*/
ngOnChanges() {
this.setOptions({
backdrop: this.backdrop,
keyboard: this.keyboard
});
}
/**
* @return {?}
*/
ngOnDestroy() {
this.onInternalClose$.next(BsModalHideType.Destroy);
return this.destroy();
}
/**
* @return {?}
*/
focus() {
this.$modal.trigger('focus');
}
/**
* @return {?}
*/
routerCanDeactivate() {
this.onInternalClose$.next(BsModalHideType.RouteChange);
return this.destroy();
}
/**
* @param {?=} size
* @return {?}
*/
open(size) {
this.overrideSize = null;
if (BsModalSize.isValidSize(size)) {
this.overrideSize = size;
}
return this.show().toPromise();
}
/**
* @param {?=} value
* @return {?}
*/
close(value) {
this.onInternalClose$.next(BsModalHideType.Close);
return this.hide().pipe(tap(() => this.onClose.emit(value))).toPromise().then(() => value);
}
/**
* @return {?}
*/
dismiss() {
this.onInternalClose$.next(BsModalHideType.Dismiss);
return this.hide().toPromise();
}
/**
* @return {?}
*/
getCssClasses() {
/** @type {?} */
const classes = [];
if (this.isSmall()) {
classes.push('modal-sm');
}
if (this.isLarge()) {
classes.push('modal-lg');
}
if (this.cssClass) {
classes.push(this.cssClass);
}
return classes.join(' ');
}
/**
* @return {?}
*/
isSmall() {
return this.overrideSize !== BsModalSize.Large
&& this.size === BsModalSize.Small
|| this.overrideSize === BsModalSize.Small;
}
/**
* @return {?}
*/
isLarge() {
return this.overrideSize !== BsModalSize.Small
&& this.size === BsModalSize.Large
|| this.overrideSize === BsModalSize.Large;
}
/**
* @return {?}
*/
show() {
if (this.visible && !this.hiding) {
return observableOf(null);
}
this.showing = true;
return Observable.create((o) => {
this.onShown$.pipe(take(1)).subscribe(next => {
o.next(next);
o.complete();
});
this.transitionFix();
this.$modal.modal('show');
});
}
/**
* @return {?}
*/
transitionFix() {
// Fix for shown.bs.modal not firing when .fade is present
// https://github.com/twbs/bootstrap/issues/11793
if (this.animation) {
setTimeout(() => {
this.$modal.trigger('focus').trigger(SHOWN_EVENT_NAME);
}, jQuery.fn.modal['Constructor'].TRANSITION_DURATION);
}
}
/**
* @return {?}
*/
hide() {
if (!this.visible && !this.showing) {
return observableOf(null);
}
this.hiding = true;
return Observable.create((o) => {
this.onHidden$.pipe(take(1)).subscribe(next => {
o.next(next);
o.complete();
});
this.$modal.modal('hide');
});
}
/**
* @return {?}
*/
init() {
this.$modal = jQuery(this.element.nativeElement);
this.$modal.appendTo(document.body);
this.$modal.modal({
show: false
});
this.onShowEvent$ = fromEvent(this.$modal, SHOW_EVENT_NAME);
this.onShownEvent$ = fromEvent(this.$modal, SHOWN_EVENT_NAME);
this.onHideEvent$ = fromEvent(this.$modal, HIDE_EVENT_NAME);
this.onHiddenEvent$ = fromEvent(this.$modal, HIDDEN_EVENT_NAME);
this.onLoadedEvent$ = fromEvent(this.$modal, LOADED_EVENT_NAME);
/** @type {?} */
const onClose$ = merge(this.onInternalClose$, this.service.onBackdropClose$, this.service.onKeyboardClose$);
this.onHide$ = zip(this.onHideEvent$, onClose$).pipe(map(x => /** @type {?} */ ({ event: x[0], type: x[1] })));
this.onHidden$ = zip(this.onHiddenEvent$, onClose$).pipe(map(x => x[1]), tap(this.setVisible(false)), tap(() => this.service.focusNext()), share());
this.onShown$ = this.onShownEvent$.pipe(tap(this.setVisible(true)), share());
this.onDismiss$ = this.onHidden$.pipe(filter((x) => x !== BsModalHideType.Close));
// Start watching for events
this.subscriptions.push(...[
this.onShown$.subscribe(() => { }),
this.onHidden$.subscribe(() => { }),
this.service.onModalStack$.subscribe(() => { })
]);
}
/**
* @return {?}
*/
wireUpEventEmitters() {
this.wireUpEventEmitter(this.onShow, this.onShowEvent$);
this.wireUpEventEmitter(this.onOpen, this.onShown$);
this.wireUpEventEmitter(this.onHide, this.onHide$);
this.wireUpEventEmitter(this.onDismiss, this.onDismiss$);
this.wireUpEventEmitter(this.onLoaded, this.onLoadedEvent$);
}
/**
* @template T
* @param {?} emitter
* @param {?} stream$
* @return {?}
*/
wireUpEventEmitter(emitter, stream$) {
if (emitter.observers.length === 0) {
return;
}
/** @type {?} */
const sub = stream$.subscribe((next) => {
this.zone.run(() => {
emitter.next(next);
});
});
this.subscriptions.push(sub);
}
/**
* @return {?}
*/
destroy() {
return this.hide().pipe(tap(() => {
this.service.remove(this);
this.subscriptions.forEach(s => s.unsubscribe());
this.subscriptions = [];
if (this.$modal) {
this.$modal.data(DATA_KEY, null);
this.$modal.remove();
this.$modal = null;
}
})).toPromise();
}
}
BsModalComponent.decorators = [
{ type: Component, args: [{
selector: 'bs-modal',
template: `
<div class="modal-dialog" [ngClass]="getCssClasses()">
<div class="modal-content">
<ng-content></ng-content>
</div>
</div>
`
},] },
];
/** @nocollapse */
BsModalComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: BsModalService },
{ type: NgZone }
];
BsModalComponent.propDecorators = {
animation: [{ type: Input }],
backdrop: [{ type: Input }],
keyboard: [{ type: Input }],
size: [{ type: Input }],
cssClass: [{ type: Input }],
onShow: [{ type: Output }],
onOpen: [{ type: Output }],
onHide: [{ type: Output }],
onClose: [{ type: Output }],
onDismiss: [{ type: Output }],
onLoaded: [{ type: Output }],
fadeClass: [{ type: HostBinding, args: ['class.fade',] }],
modalClass: [{ type: HostBinding, args: ['class.modal',] }],
roleAttr: [{ type: HostBinding, args: ['attr.role',] }],
tabindexAttr: [{ type: HostBinding, args: ['attr.tabindex',] }]
};
if (false) {
/** @type {?} */
BsModalComponent.prototype.overrideSize;
/** @type {?} */
BsModalComponent.prototype.$modal;
/** @type {?} */
BsModalComponent.prototype.$dialog;
/** @type {?} */
BsModalComponent.prototype.onShowEvent$;
/** @type {?} */
BsModalComponent.prototype.onShownEvent$;
/** @type {?} */
BsModalComponent.prototype.onHideEvent$;
/** @type {?} */
BsModalComponent.prototype.onHiddenEvent$;
/** @type {?} */
BsModalComponent.prototype.onLoadedEvent$;
/** @type {?} */
BsModalComponent.prototype.onShown$;
/** @type {?} */
BsModalComponent.prototype.onInternalClose$;
/** @type {?} */
BsModalComponent.prototype.onDismiss$;
/** @type {?} */
BsModalComponent.prototype.onHide$;
/** @type {?} */
BsModalComponent.prototype.onHidden$;
/** @type {?} */
BsModalComponent.prototype.subscriptions;
/** @type {?} */
BsModalComponent.prototype.visible;
/** @type {?} */
BsModalComponent.prototype.showing;
/** @type {?} */
BsModalComponent.prototype.hiding;
/** @type {?} */
BsModalComponent.prototype.animation;
/** @type {?} */
BsModalComponent.prototype.backdrop;
/** @type {?} */
BsModalComponent.prototype.keyboard;
/** @type {?} */
BsModalComponent.prototype.size;
/** @type {?} */
BsModalComponent.prototype.cssClass;
/** @type {?} */
BsModalComponent.prototype.onShow;
/** @type {?} */
BsModalComponent.prototype.onOpen;
/** @type {?} */
BsModalComponent.prototype.onHide;
/** @type {?} */
BsModalComponent.prototype.onClose;
/** @type {?} */
BsModalComponent.prototype.onDismiss;
/** @type {?} */
BsModalComponent.prototype.onLoaded;
/** @type {?} */
BsModalComponent.prototype.setVisible;
/** @type {?} */
BsModalComponent.prototype.setOptions;
/** @type {?} */
BsModalComponent.prototype.element;
/** @type {?} */
BsModalComponent.prototype.service;
/** @type {?} */
BsModalComponent.prototype.zone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"ng://ng2-bs3-modal/","sources":["modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:no-output-on-prefix\nimport {\n    Component,\n    OnInit,\n    AfterViewInit,\n    OnChanges,\n    OnDestroy,\n    Input,\n    Output,\n    EventEmitter,\n    ElementRef,\n    HostBinding,\n    NgZone\n} from '@angular/core';\nimport { Observable, Observer, Subject, Subscription, of as observableOf, fromEvent, merge, zip } from 'rxjs';\nimport { take, filter, tap, share, map } from 'rxjs/operators';\n\nimport { BsModalHideEvent, BsModalHideType, BsModalOptions, BsModalSize } from './models';\nimport { BsModalService } from './modal.service';\n\nconst EVENT_SUFFIX = 'ng2-bs3-modal';\nconst SHOW_EVENT_NAME = `show.bs.modal.${EVENT_SUFFIX}`;\nconst SHOWN_EVENT_NAME = `shown.bs.modal.${EVENT_SUFFIX}`;\nconst HIDE_EVENT_NAME = `hide.bs.modal.${EVENT_SUFFIX}`;\nconst HIDDEN_EVENT_NAME = `hidden.bs.modal.${EVENT_SUFFIX}`;\nconst LOADED_EVENT_NAME = `loaded.bs.modal.${EVENT_SUFFIX}`;\nconst DATA_KEY = 'bs.modal';\n\n@Component({\n    selector: 'bs-modal',\n    template: `\n        <div class=\"modal-dialog\" [ngClass]=\"getCssClasses()\">\n            <div class=\"modal-content\">\n                <ng-content></ng-content>\n            </div>\n        </div>\n    `\n})\nexport class BsModalComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\n\n    private overrideSize: string = null;\n    private $modal: JQuery;\n    private $dialog: JQuery;\n    private onShowEvent$: Observable<Event>;\n    private onShownEvent$: Observable<Event>;\n    private onHideEvent$: Observable<Event>;\n    private onHiddenEvent$: Observable<Event>;\n    private onLoadedEvent$: Observable<Event>;\n    private onShown$: Observable<{}>;\n    private onInternalClose$: Subject<BsModalHideType> = new Subject<BsModalHideType>();\n    private onDismiss$: Observable<BsModalHideType>;\n    private onHide$: Observable<BsModalHideEvent>;\n    private onHidden$: Observable<BsModalHideType>;\n    private subscriptions: Subscription[] = [];\n    private get options() {\n        if (!this.$modal) {\n            this.init();\n        }\n        return this.$modal.data(DATA_KEY).options;\n    }\n\n    visible = false;\n    showing = false;\n    hiding = false;\n\n    @Input() animation = true;\n    @Input() backdrop: string | boolean = true;\n    @Input() keyboard = true;\n    @Input() size: string;\n    @Input() cssClass: string;\n\n    @Output() onShow = new EventEmitter<Event>();\n    @Output() onOpen = new EventEmitter<any>();\n    @Output() onHide = new EventEmitter<any>();\n    @Output() onClose = new EventEmitter<any>();\n    @Output() onDismiss = new EventEmitter<BsModalHideType>();\n    @Output() onLoaded = new EventEmitter<any>();\n\n    @HostBinding('class.fade')\n    get fadeClass() { return this.animation; }\n\n    @HostBinding('class.modal')\n    get modalClass() { return true; }\n\n    @HostBinding('attr.role')\n    get roleAttr() { return 'dialog'; }\n\n    @HostBinding('attr.tabindex')\n    get tabindexAttr() { return '-1'; }\n\n    constructor(private element: ElementRef, private service: BsModalService, private zone: NgZone) {\n        this.service.add(this);\n        this.init();\n    }\n\n    ngOnInit() {\n        this.wireUpEventEmitters();\n    }\n\n    ngAfterViewInit() {\n        this.$dialog = this.$modal.find('.modal-dialog');\n    }\n\n    ngOnChanges() {\n        this.setOptions({\n            backdrop: this.backdrop,\n            keyboard: this.keyboard\n        });\n    }\n\n    ngOnDestroy() {\n        this.onInternalClose$.next(BsModalHideType.Destroy);\n        return this.destroy();\n    }\n\n    focus() {\n        this.$modal.trigger('focus');\n    }\n\n    routerCanDeactivate(): any {\n        this.onInternalClose$.next(BsModalHideType.RouteChange);\n        return this.destroy();\n    }\n\n    open(size?: string) {\n        this.overrideSize = null;\n        if (BsModalSize.isValidSize(size)) {\n            this.overrideSize = size;\n        }\n        return this.show().toPromise();\n    }\n\n    close(value?: any): Promise<{}> {\n        this.onInternalClose$.next(BsModalHideType.Close);\n        return this.hide().pipe(\n            tap(() => this.onClose.emit(value)),\n        ).toPromise().then(() => value);\n    }\n\n    dismiss(): Promise<{}> {\n        this.onInternalClose$.next(BsModalHideType.Dismiss);\n        return this.hide().toPromise();\n    }\n\n    getCssClasses(): string {\n        const classes: string[] = [];\n\n        if (this.isSmall()) {\n            classes.push('modal-sm');\n        }\n\n        if (this.isLarge()) {\n            classes.push('modal-lg');\n        }\n\n        if (this.cssClass) {\n            classes.push(this.cssClass);\n        }\n\n        return classes.join(' ');\n    }\n\n    private isSmall() {\n        return this.overrideSize !== BsModalSize.Large\n            && this.size === BsModalSize.Small\n            || this.overrideSize === BsModalSize.Small;\n    }\n\n    private isLarge() {\n        return this.overrideSize !== BsModalSize.Small\n            && this.size === BsModalSize.Large\n            || this.overrideSize === BsModalSize.Large;\n    }\n\n    private show(): Observable<any> {\n        if (this.visible && !this.hiding) {\n            return observableOf(null);\n        }\n        this.showing = true;\n\n        return Observable.create((o: Observer<any>) => {\n            this.onShown$.pipe(\n                take(1),\n            ).subscribe(next => {\n                o.next(next);\n                o.complete();\n            });\n\n            this.transitionFix();\n            this.$modal.modal('show');\n        });\n    }\n\n    private transitionFix() {\n        // Fix for shown.bs.modal not firing when .fade is present\n        // https://github.com/twbs/bootstrap/issues/11793\n        if (this.animation) {\n            setTimeout(() => {\n                this.$modal.trigger('focus').trigger(SHOWN_EVENT_NAME);\n            }, jQuery.fn.modal['Constructor'].TRANSITION_DURATION);\n        }\n    }\n\n    private hide(): Observable<BsModalHideType> {\n        if (!this.visible && !this.showing) {\n            return observableOf<BsModalHideType>(null);\n        }\n        this.hiding = true;\n\n        return Observable.create((o: Observer<any>) => {\n            this.onHidden$.pipe(\n                take(1)\n            ).subscribe(next => {\n                o.next(next);\n                o.complete();\n            });\n\n            this.$modal.modal('hide');\n        });\n    }\n\n    private init() {\n        this.$modal = jQuery(this.element.nativeElement);\n        this.$modal.appendTo(document.body);\n        this.$modal.modal({\n            show: false\n        });\n\n        this.onShowEvent$ = fromEvent(this.$modal, SHOW_EVENT_NAME);\n        this.onShownEvent$ = fromEvent(this.$modal, SHOWN_EVENT_NAME);\n        this.onHideEvent$ = fromEvent(this.$modal, HIDE_EVENT_NAME);\n        this.onHiddenEvent$ = fromEvent(this.$modal, HIDDEN_EVENT_NAME);\n        this.onLoadedEvent$ = fromEvent(this.$modal, LOADED_EVENT_NAME);\n\n        const onClose$ = merge(this.onInternalClose$, this.service.onBackdropClose$, this.service.onKeyboardClose$);\n\n        this.onHide$ = zip(this.onHideEvent$, onClose$).pipe(\n            map(x => <BsModalHideEvent>{ event: x[0], type: x[1] }),\n        );\n\n        this.onHidden$ = zip<BsModalHideType>(this.onHiddenEvent$, onClose$).pipe(\n            map(x => x[1]),\n            tap(this.setVisible(false)),\n            tap(() => this.service.focusNext()),\n            share(),\n        );\n\n        this.onShown$ = this.onShownEvent$.pipe(\n            tap(this.setVisible(true)),\n            share()\n        );\n\n        this.onDismiss$ = this.onHidden$.pipe(\n            filter((x) => x !== BsModalHideType.Close)\n        );\n\n        // Start watching for events\n        this.subscriptions.push(...[\n            this.onShown$.subscribe(() => { }),\n            this.onHidden$.subscribe(() => { }),\n            this.service.onModalStack$.subscribe(() => { })\n        ]);\n    }\n\n    private wireUpEventEmitters() {\n\n        this.wireUpEventEmitter(this.onShow, this.onShowEvent$);\n        this.wireUpEventEmitter(this.onOpen, this.onShown$);\n        this.wireUpEventEmitter(this.onHide, this.onHide$);\n        this.wireUpEventEmitter(this.onDismiss, this.onDismiss$);\n        this.wireUpEventEmitter(this.onLoaded, this.onLoadedEvent$);\n    }\n\n    private wireUpEventEmitter<T>(emitter: EventEmitter<T>, stream$: Observable<T>) {\n        if (emitter.observers.length === 0) {\n            return;\n        }\n\n        const sub = stream$.subscribe((next) => {\n            this.zone.run(() => {\n                emitter.next(next);\n            });\n        });\n\n        this.subscriptions.push(sub);\n    }\n\n    private setVisible = (isVisible) => {\n        return () => {\n            this.visible = isVisible;\n            this.showing = false;\n            this.hiding = false;\n        };\n    }\n\n    private setOptions = (options: BsModalOptions) => {\n        let backdrop = options.backdrop;\n        if (typeof backdrop === 'string' && backdrop !== 'static') {\n            backdrop = true;\n\n        }\n\n        if (options.backdrop !== undefined) {\n            this.options.backdrop = backdrop;\n        }\n        if (options.keyboard !== undefined) {\n            this.options.keyboard = options.keyboard;\n        }\n    }\n\n    private destroy() {\n        return this.hide().pipe(\n            tap(() => {\n                this.service.remove(this);\n                this.subscriptions.forEach(s => s.unsubscribe());\n                this.subscriptions = [];\n                if (this.$modal) {\n                    this.$modal.data(DATA_KEY, null);\n                    this.$modal.remove();\n                    this.$modal = null;\n                }\n            })\n        ).toPromise();\n    }\n}\n"]}