fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
226 lines • 17.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Type, TemplateRef, ViewContainerRef, ViewChild, ComponentFactoryResolver, ChangeDetectorRef, HostListener, Optional } 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\" 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',
'[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
],
styles: [":host{max-width:none;z-index:1000}:host:focus{outline:0}:host .fd-modal__content{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    Component,\n    ElementRef,\n    OnInit,\n    AfterViewInit,\n    Type,\n    TemplateRef,\n    ViewContainerRef,\n    ViewChild,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    ChangeDetectorRef, HostListener, OnDestroy, Optional\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        '[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})\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"]}