UNPKG

ng2-bs3-modal

Version:

Angular Boostrap 3 Modal Component

417 lines (416 loc) 37.3 kB
/** * @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"]}