UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

228 lines 17.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var ModalComponent = /** @class */ (function (_super) { tslib_1.__extends(ModalComponent, _super); function ModalComponent(elRef, componentFactoryResolver, cdRef, modalRef) { var _this = _super.call(this, elRef) || this; _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 _this; } /** * @return {?} */ ModalComponent.prototype.ngOnInit = /** * @return {?} */ function () { this._setProperties(); }; /** * @return {?} */ ModalComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.focusTrap) { this.focusTrap.deactivate(); } }; /** * @return {?} */ ModalComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { 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 {?} */ ModalComponent.prototype.closeModalEsc = /** * @param {?} event * @return {?} */ function (event) { if (this.escKeyCloseable && event.key === 'Escape') { this.modalRef.dismiss('escape'); } }; /** * @private * @param {?} content * @return {?} */ ModalComponent.prototype.loadFromComponent = /** * @private * @param {?} content * @return {?} */ function (content) { this.containerRef.clear(); /** @type {?} */ var componentFactory = this.componentFactoryResolver.resolveComponentFactory(content); this.componentRef = this.containerRef.createComponent(componentFactory); }; /** * @private * @param {?} content * @return {?} */ ModalComponent.prototype.loadFromTemplate = /** * @private * @param {?} content * @return {?} */ function (content) { this.containerRef.clear(); /** @type {?} */ var context = { $implicit: this.modalRef }; this.componentRef = this.containerRef.createEmbeddedView(content, context); }; /** * @return {?} */ ModalComponent.prototype._setProperties = /** * @return {?} */ function () { 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 = function () { return [ { 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'],] }] }; return ModalComponent; }(AbstractFdNgxClass)); export { ModalComponent }; 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"]}