UNPKG

fundamental-ngx

Version:

SAP Fundamentals, implemented in Angular

203 lines 16.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, HostListener, Optional, TemplateRef, Type, ViewChild, ViewContainerRef, ViewEncapsulation } from '@angular/core'; import { ModalRef } from './modal-utils/modal-ref'; import { modalFadeNgIf } from './modal-utils/modal-animations'; import { AbstractFdNgxClass } from '../utils/abstract-fd-ngx-class'; import focusTrap from 'focus-trap'; export class ModalComponent extends AbstractFdNgxClass { /** * @param {?} elRef * @param {?} componentFactoryResolver * @param {?} cdRef * @param {?} modalRef */ constructor(elRef, componentFactoryResolver, cdRef, modalRef) { super(elRef); this.elRef = elRef; this.componentFactoryResolver = componentFactoryResolver; this.cdRef = cdRef; this.modalRef = modalRef; this.escKeyCloseable = true; this.focusTrapped = true; this.ariaLabelledBy = null; this.ariaLabel = null; this.ariaDescribedBy = null; this.backdropClickCloseable = true; this.hasBackdrop = true; this.modalPanelClass = ''; } /** * @return {?} */ ngOnInit() { this._setProperties(); } /** * @return {?} */ ngOnDestroy() { if (this.focusTrap) { this.focusTrap.deactivate(); } } /** * @return {?} */ ngAfterViewInit() { if (this.childComponentType) { if (this.childComponentType instanceof Type) { this.loadFromComponent(this.childComponentType); } else if (this.childComponentType instanceof TemplateRef) { this.loadFromTemplate(this.childComponentType); } } if (this.focusTrapped) { try { this.focusTrap = focusTrap(this.elRef.nativeElement, { clickOutsideDeactivates: this.backdropClickCloseable && this.hasBackdrop, escapeDeactivates: false, initialFocus: this.elRef.nativeElement }); this.focusTrap.activate(); } catch (e) { console.warn('Attempted to focus trap the modal, but no tabbable elements were found.'); } } this.cdRef.detectChanges(); } /** * @param {?} event * @return {?} */ closeModalEsc(event) { if (this.escKeyCloseable && event.key === 'Escape') { this.modalRef.dismiss('escape'); } } /** * @private * @param {?} content * @return {?} */ loadFromComponent(content) { this.containerRef.clear(); /** @type {?} */ const componentFactory = this.componentFactoryResolver.resolveComponentFactory(content); this.componentRef = this.containerRef.createComponent(componentFactory); } /** * @private * @param {?} content * @return {?} */ loadFromTemplate(content) { this.containerRef.clear(); /** @type {?} */ const context = { $implicit: this.modalRef }; this.componentRef = this.containerRef.createEmbeddedView(content, context); } /** * @return {?} */ _setProperties() { if (this.modalPanelClass) { this._addClassToElement(this.modalPanelClass); } } } ModalComponent.decorators = [ { type: Component, args: [{ selector: 'fd-modal', template: "<div class=\"fd-modal__content fd-modal__content--overrides\" role=\"document\">\n <ng-content select=\"fd-modal-header\"></ng-content>\n <ng-content select=\"fd-modal-body\"></ng-content>\n <ng-content select=\"fd-modal-footer\"></ng-content>\n <ng-container #vc></ng-container>\n <ng-content></ng-content>\n</div>\n", host: { 'role': 'dialog', '[class.fd-modal]': 'true', '[class.fd-modal-custom]': 'true', '[attr.aria-labelledby]': 'ariaLabelledBy', '[attr.aria-label]': 'ariaLabel', '[attr.aria-describedby]': 'ariaDescribedBy', '[attr.aria-modal]': 'true', '[attr.id]': 'id', 'tabindex': '-1', '[@modal-fade]': '' }, animations: [ modalFadeNgIf ], encapsulation: ViewEncapsulation.None, styles: [".fd-modal-custom{max-width:none;z-index:1000;position:absolute}.fd-modal-custom:focus{outline:0}.fd-modal__content--overrides{height:100%;width:100%;min-height:inherit;min-width:inherit;max-height:inherit;max-width:inherit;display:flex;flex-direction:column}"] }] } ]; /** @nocollapse */ ModalComponent.ctorParameters = () => [ { type: ElementRef }, { type: ComponentFactoryResolver }, { type: ChangeDetectorRef }, { type: ModalRef, decorators: [{ type: Optional }] } ]; ModalComponent.propDecorators = { containerRef: [{ type: ViewChild, args: ['vc', { read: ViewContainerRef },] }], closeModalEsc: [{ type: HostListener, args: ['keyup', ['$event'],] }] }; if (false) { /** @type {?} */ ModalComponent.prototype.containerRef; /** @type {?} */ ModalComponent.prototype.id; /** @type {?} */ ModalComponent.prototype.escKeyCloseable; /** @type {?} */ ModalComponent.prototype.focusTrapped; /** @type {?} */ ModalComponent.prototype.ariaLabelledBy; /** @type {?} */ ModalComponent.prototype.ariaLabel; /** @type {?} */ ModalComponent.prototype.ariaDescribedBy; /** @type {?} */ ModalComponent.prototype.childComponentType; /** @type {?} */ ModalComponent.prototype.backdropClickCloseable; /** @type {?} */ ModalComponent.prototype.hasBackdrop; /** @type {?} */ ModalComponent.prototype.modalPanelClass; /** * @type {?} * @private */ ModalComponent.prototype.componentRef; /** * @type {?} * @private */ ModalComponent.prototype.focusTrap; /** * @type {?} * @private */ ModalComponent.prototype.elRef; /** * @type {?} * @private */ ModalComponent.prototype.componentFactoryResolver; /** * @type {?} * @private */ ModalComponent.prototype.cdRef; /** * @type {?} * @private */ ModalComponent.prototype.modalRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ElementRef,\n    EmbeddedViewRef,\n    HostListener,\n    OnDestroy,\n    OnInit,\n    Optional,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ModalRef } from './modal-utils/modal-ref';\nimport { modalFadeNgIf } from './modal-utils/modal-animations';\nimport { AbstractFdNgxClass } from '../utils/abstract-fd-ngx-class';\nimport focusTrap from 'focus-trap';\n\n@Component({\n    selector: 'fd-modal',\n    styleUrls: ['modal.component.scss'],\n    templateUrl: './modal.component.html',\n    host: {\n        'role': 'dialog',\n        '[class.fd-modal]': 'true',\n        '[class.fd-modal-custom]': 'true',\n        '[attr.aria-labelledby]': 'ariaLabelledBy',\n        '[attr.aria-label]': 'ariaLabel',\n        '[attr.aria-describedby]': 'ariaDescribedBy',\n        '[attr.aria-modal]': 'true',\n        '[attr.id]': 'id',\n        'tabindex': '-1',\n        '[@modal-fade]': ''\n    },\n    animations: [\n        modalFadeNgIf\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class ModalComponent extends AbstractFdNgxClass implements OnInit, AfterViewInit, OnDestroy {\n\n    @ViewChild('vc', {read: ViewContainerRef})\n    containerRef: ViewContainerRef;\n\n    id: string;\n\n    escKeyCloseable: boolean = true;\n\n    focusTrapped: boolean = true;\n\n    ariaLabelledBy: string = null;\n\n    ariaLabel: string = null;\n\n    ariaDescribedBy: string = null;\n\n    childComponentType: TemplateRef<any> | Type<any>;\n\n    backdropClickCloseable: boolean = true;\n\n    hasBackdrop: boolean  = true;\n\n    modalPanelClass: string = '';\n\n    private componentRef: ComponentRef<any> | EmbeddedViewRef<any>;\n\n    private focusTrap: any;\n\n    constructor(private elRef: ElementRef,\n                private componentFactoryResolver: ComponentFactoryResolver,\n                private cdRef: ChangeDetectorRef,\n                @Optional() private modalRef: ModalRef) {\n        super(elRef);\n    }\n\n    ngOnInit(): void {\n        this._setProperties();\n    }\n\n    ngOnDestroy(): void {\n        if (this.focusTrap) {\n            this.focusTrap.deactivate();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        if (this.childComponentType) {\n            if (this.childComponentType instanceof Type) {\n                this.loadFromComponent(this.childComponentType);\n            } else if (this.childComponentType instanceof TemplateRef) {\n                this.loadFromTemplate(this.childComponentType);\n            }\n        }\n        if (this.focusTrapped) {\n            try {\n                this.focusTrap = focusTrap(this.elRef.nativeElement, {\n                    clickOutsideDeactivates: this.backdropClickCloseable && this.hasBackdrop,\n                    escapeDeactivates: false,\n                    initialFocus: this.elRef.nativeElement\n                });\n                this.focusTrap.activate();\n            } catch (e) {\n                console.warn('Attempted to focus trap the modal, but no tabbable elements were found.');\n            }\n        }\n        this.cdRef.detectChanges();\n    }\n\n    @HostListener('keyup', ['$event'])\n    closeModalEsc(event: KeyboardEvent): void {\n        if (this.escKeyCloseable && event.key === 'Escape') {\n            this.modalRef.dismiss('escape');\n        }\n    }\n\n    private loadFromComponent(content: Type<any>): void {\n        this.containerRef.clear();\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(content);\n        this.componentRef = this.containerRef.createComponent(componentFactory);\n    }\n\n    private loadFromTemplate(content: TemplateRef<any>): void {\n        this.containerRef.clear();\n        const context = {\n            $implicit: this.modalRef\n        };\n        this.componentRef = this.containerRef.createEmbeddedView(content, context);\n    }\n\n    _setProperties(): void {\n        if (this.modalPanelClass) {\n            this._addClassToElement(this.modalPanelClass);\n        }\n    }\n}\n"]}