fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
625 lines • 42.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ApplicationRef, ChangeDetectorRef, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, HostListener, Injector, Input, Output, Renderer2 } from '@angular/core';
import { PopoverContainer } from './popover-container';
import Popper from 'popper.js';
/**
* Directive which manages the popper and popover components of the library.
* It can be attached to any element. To bind it to a body, use the following syntax.
* ```html
* <div [fdPopover]="template">Control Element</div>
* <ng-template #template>
* Popover Body
* </ng-template>
* ```
*/
var PopoverDirective = /** @class */ (function () {
/** @hidden */
function PopoverDirective(elRef, cdRef, resolver, injector, appRef, renderer) {
this.elRef = elRef;
this.cdRef = cdRef;
this.resolver = resolver;
this.injector = injector;
this.appRef = appRef;
this.renderer = renderer;
/**
* \@Input Whether the popover is open. Can be used through two-way binding.
*/
this.isOpen = false;
/**
* \@Input The trigger events that will open/close the popover.
* Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp).
*/
this.triggers = ['click'];
/**
* \@Input Whether the popover should display the default arrow.
*/
this.defaultArrow = false;
/**
* \@Input Whether the popover should be focusTrapped.
*/
this.focusTrapped = false;
/**
* \@Input Whether the popover should close when the escape key is pressed.
*/
this.closeOnEscapeKey = true;
/**
* \@Input Whether the popover is disabled.
*/
this.disabled = false;
/**
* \@Input Whether the popover should close when a click is made outside its boundaries.
*/
this.closeOnOutsideClick = true;
/**
* \@Input The element to which the popover should be appended.
*/
this.appendTo = 'body';
/**
* \@Input The Popper.js options to attach to this popover.
* See the [Popper.js Documentation](https://popper.js.org/popper-documentation.html) for details.
*/
this.options = {
placement: 'bottom-start',
modifiers: {
preventOverflow: {
enabled: true,
escapeWithReference: true,
boundariesElement: 'scrollParent'
}
}
};
/**
* \@Input Whether the Popover Body should try to have the same width as the Popover Control.
*/
this.fillControl = false;
/**
* \@Output Event emitted when the state of the isOpen property changes.
*/
this.isOpenChange = new EventEmitter();
this.eventRef = [];
this.isSetup = false;
}
/** @hidden */
/**
* @hidden
* @return {?}
*/
PopoverDirective.prototype.ngOnInit = /**
* @hidden
* @return {?}
*/
function () {
if (this.isOpen) {
this.open();
}
this.initFillControl();
this.initPlacement();
this.addTriggerListeners();
this.isSetup = true;
};
/** @hidden */
/**
* @hidden
* @return {?}
*/
PopoverDirective.prototype.ngOnDestroy = /**
* @hidden
* @return {?}
*/
function () {
if (this.popper) {
this.popper.destroy();
}
if (this.containerRef) {
this.destroyContainer();
}
this.destroyTriggerListeners();
};
/** @hidden */
/**
* @hidden
* @param {?} changes
* @return {?}
*/
PopoverDirective.prototype.ngOnChanges = /**
* @hidden
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
if (!this.isSetup) {
return;
}
if (changes.triggers) {
setTimeout((/**
* @return {?}
*/
function () {
_this.destroyTriggerListeners();
_this.addTriggerListeners();
}));
}
if (changes.isOpen) {
if (changes.isOpen.currentValue) {
setTimeout((/**
* @return {?}
*/
function () {
_this.isOpen = false;
_this.open(false);
}));
}
else {
setTimeout((/**
* @return {?}
*/
function () {
_this.isOpen = true;
_this.close(false);
}));
}
}
if (changes.placement) {
setTimeout((/**
* @return {?}
*/
function () {
_this.initPlacement();
}));
}
if (changes.fillControl) {
setTimeout((/**
* @return {?}
*/
function () {
_this.initFillControl();
}));
}
};
/**
* Toggles the popover open state.
*/
/**
* Toggles the popover open state.
* @param {?=} fireEvent
* @return {?}
*/
PopoverDirective.prototype.toggle = /**
* Toggles the popover open state.
* @param {?=} fireEvent
* @return {?}
*/
function (fireEvent) {
if (fireEvent === void 0) { fireEvent = true; }
if (this.isOpen) {
this.close(fireEvent);
}
else {
this.open(fireEvent);
}
};
/**
* Opens the popover.
*/
/**
* Opens the popover.
* @param {?=} fireEvent
* @return {?}
*/
PopoverDirective.prototype.open = /**
* Opens the popover.
* @param {?=} fireEvent
* @return {?}
*/
function (fireEvent) {
if (fireEvent === void 0) { fireEvent = true; }
if (!this.isOpen && !this.disabled) {
this.createContainer();
this.isOpen = true;
if (fireEvent) {
this.isOpenChange.emit(this.isOpen);
}
}
};
/**
* Closes the popover.
*/
/**
* Closes the popover.
* @param {?=} fireEvent
* @return {?}
*/
PopoverDirective.prototype.close = /**
* Closes the popover.
* @param {?=} fireEvent
* @return {?}
*/
function (fireEvent) {
if (fireEvent === void 0) { fireEvent = true; }
if (this.isOpen) {
this.destroyContainer();
this.isOpen = false;
if (fireEvent) {
this.isOpenChange.emit(this.isOpen);
}
}
};
/**
* Forces an update of the popover's positioning calculation.
*/
/**
* Forces an update of the popover's positioning calculation.
* @return {?}
*/
PopoverDirective.prototype.updatePopper = /**
* Forces an update of the popover's positioning calculation.
* @return {?}
*/
function () {
if (this.popper) {
this.popper.scheduleUpdate();
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.createContainer = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this.containerRef) {
return;
}
/** @type {?} */
var factory = this.resolver.resolveComponentFactory(PopoverContainer);
this.containerRef = factory.create(this.injector);
// Set instance properties
this.containerRef.instance.context = this;
this.containerRef.instance.content = this.content;
this.containerRef.instance.focusTrapped = this.focusTrapped;
this.containerRef.instance.defaultArrow = this.defaultArrow;
this.containerRef.instance.closeOnEscapeKey = this.closeOnEscapeKey;
if (!this.defaultArrow) {
this.containerRef.location.nativeElement.style.margin = 0;
}
this.appRef.attachView(this.containerRef.hostView);
/** @type {?} */
var setupRef = this.containerRef.instance.isSetup.subscribe((/**
* @return {?}
*/
function () {
_this.createPopper();
setupRef.unsubscribe();
}));
/** @type {?} */
var containerEl = (/** @type {?} */ (((/** @type {?} */ (this.containerRef.hostView))).rootNodes[0]));
if (this.appendTo === 'body') {
document.body.appendChild(containerEl);
}
else {
this.appendTo.appendChild(containerEl);
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.destroyTriggerListeners = /**
* @private
* @return {?}
*/
function () {
if (this.eventRef && this.eventRef.length > 0) {
this.eventRef.forEach((/**
* @param {?} event
* @return {?}
*/
function (event) {
event();
}));
this.eventRef = [];
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.addTriggerListeners = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this.triggers && this.triggers.length > 0) {
this.triggers.forEach((/**
* @param {?} trigger
* @return {?}
*/
function (trigger) {
_this.eventRef.push(_this.renderer.listen(_this.elRef.nativeElement, trigger, (/**
* @return {?}
*/
function () {
_this.toggle();
})));
}));
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.destroyContainer = /**
* @private
* @return {?}
*/
function () {
if (this.containerRef) {
this.appRef.detachView(this.containerRef.hostView);
this.containerRef.destroy();
this.containerRef = null;
}
if (this.popper) {
this.popper.destroy();
this.popper = null;
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.createPopper = /**
* @private
* @return {?}
*/
function () {
this.popper = new Popper((/** @type {?} */ (this.elRef.nativeElement)), (/** @type {?} */ (this.containerRef.location.nativeElement)), this.options);
};
/**
* @private
* @param {?} data
* @return {?}
*/
PopoverDirective.prototype.fillReference = /**
* @private
* @param {?} data
* @return {?}
*/
function (data) {
data.offsets.popper.left = data.offsets.reference.left;
data.offsets.popper.right = data.offsets.reference.right;
data.offsets.popper.width = data.styles.width = data.offsets.reference.width;
return data;
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.initPlacement = /**
* @private
* @return {?}
*/
function () {
if (this.placement) {
if (this.options) {
this.options.placement = this.placement;
}
else {
this.options = { placement: this.placement };
}
}
};
/**
* @private
* @return {?}
*/
PopoverDirective.prototype.initFillControl = /**
* @private
* @return {?}
*/
function () {
if (this.fillControl) {
if (this.options && this.options.modifiers) {
this.options.modifiers.fillReference = {
enabled: true,
fn: this.fillReference,
order: 840
};
}
else {
this.options = {
modifiers: {
fillReference: {
enabled: true,
fn: this.fillReference,
order: 840
}
}
};
}
}
};
/** @hidden */
/**
* @hidden
* @param {?} event
* @return {?}
*/
PopoverDirective.prototype.clickHandler = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
if (this.containerRef &&
this.isOpen &&
this.closeOnOutsideClick &&
event.target !== this.elRef.nativeElement &&
!this.elRef.nativeElement.contains(event.target) &&
!this.containerRef.location.nativeElement.contains(event.target)) {
event.preventDefault();
event.stopPropagation();
this.close();
}
};
PopoverDirective.decorators = [
{ type: Directive, args: [{
selector: '[fdPopover]'
},] }
];
/** @nocollapse */
PopoverDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: ChangeDetectorRef },
{ type: ComponentFactoryResolver },
{ type: Injector },
{ type: ApplicationRef },
{ type: Renderer2 }
]; };
PopoverDirective.propDecorators = {
content: [{ type: Input, args: ['fdPopover',] }],
isOpen: [{ type: Input }],
triggers: [{ type: Input }],
defaultArrow: [{ type: Input }],
placement: [{ type: Input }],
focusTrapped: [{ type: Input }],
closeOnEscapeKey: [{ type: Input }],
disabled: [{ type: Input }],
closeOnOutsideClick: [{ type: Input }],
appendTo: [{ type: Input }],
options: [{ type: Input }],
fillControl: [{ type: Input }],
isOpenChange: [{ type: Output }],
clickHandler: [{ type: HostListener, args: ['document:click', ['$event'],] }]
};
return PopoverDirective;
}());
export { PopoverDirective };
if (false) {
/**
* \@Input Content of the popover. Used through the actual directive tag. Accepts strings or TemplateRefs.
* @type {?}
*/
PopoverDirective.prototype.content;
/**
* \@Input Whether the popover is open. Can be used through two-way binding.
* @type {?}
*/
PopoverDirective.prototype.isOpen;
/**
* \@Input The trigger events that will open/close the popover.
* Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp).
* @type {?}
*/
PopoverDirective.prototype.triggers;
/**
* \@Input Whether the popover should display the default arrow.
* @type {?}
*/
PopoverDirective.prototype.defaultArrow;
/**
* \@Input The placement of the popover. It can be one of: top, top-start, top-end, bottom,
* bottom-start, bottom-end, right, right-start, right-end, left, left-start, left-end.
* @type {?}
*/
PopoverDirective.prototype.placement;
/**
* \@Input Whether the popover should be focusTrapped.
* @type {?}
*/
PopoverDirective.prototype.focusTrapped;
/**
* \@Input Whether the popover should close when the escape key is pressed.
* @type {?}
*/
PopoverDirective.prototype.closeOnEscapeKey;
/**
* \@Input Whether the popover is disabled.
* @type {?}
*/
PopoverDirective.prototype.disabled;
/**
* \@Input Whether the popover should close when a click is made outside its boundaries.
* @type {?}
*/
PopoverDirective.prototype.closeOnOutsideClick;
/**
* \@Input The element to which the popover should be appended.
* @type {?}
*/
PopoverDirective.prototype.appendTo;
/**
* \@Input The Popper.js options to attach to this popover.
* See the [Popper.js Documentation](https://popper.js.org/popper-documentation.html) for details.
* @type {?}
*/
PopoverDirective.prototype.options;
/**
* \@Input Whether the Popover Body should try to have the same width as the Popover Control.
* @type {?}
*/
PopoverDirective.prototype.fillControl;
/**
* \@Output Event emitted when the state of the isOpen property changes.
* @type {?}
*/
PopoverDirective.prototype.isOpenChange;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.containerRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.popper;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.eventRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.isSetup;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.elRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.cdRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.resolver;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.injector;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.appRef;
/**
* @type {?}
* @private
*/
PopoverDirective.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/popover/popover-directive/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    ComponentFactoryResolver,\n    ComponentRef,\n    Directive,\n    ElementRef, EmbeddedViewRef, EventEmitter, HostListener,\n    Injector, Input, OnChanges, OnDestroy, OnInit, Output, Renderer2, SimpleChanges,\n    TemplateRef\n} from '@angular/core';\nimport { PopoverContainer } from './popover-container';\nimport Popper, { Placement, PopperOptions } from 'popper.js';\n\n/**\n * Directive which manages the popper and popover components of the library.\n * It can be attached to any element. To bind it to a body, use the following syntax.\n * ```html\n * <div [fdPopover]=\"template\">Control Element</div>\n * <ng-template #template>\n *     Popover Body\n * </ng-template>\n * ```\n */\n@Directive({\n    selector: '[fdPopover]'\n})\nexport class PopoverDirective implements OnInit, OnDestroy, OnChanges {\n\n    /** @Input Content of the popover. Used through the actual directive tag. Accepts strings or TemplateRefs. */\n    @Input('fdPopover')\n    content: TemplateRef<any> | string;\n\n    /** @Input Whether the popover is open. Can be used through two-way binding. */\n    @Input()\n    isOpen: boolean = false;\n\n    /** @Input The trigger events that will open/close the popover.\n     *  Accepts any [HTML DOM Events](https://www.w3schools.com/jsref/dom_obj_event.asp). */\n    @Input()\n    triggers: string[] = ['click'];\n\n    /** @Input Whether the popover should display the default arrow. */\n    @Input()\n    defaultArrow: boolean = false;\n\n    /** @Input The placement of the popover. It can be one of: top, top-start, top-end, bottom,\n     *  bottom-start, bottom-end, right, right-start, right-end, left, left-start, left-end. */\n    @Input()\n    placement: Placement;\n\n    /** @Input Whether the popover should be focusTrapped. */\n    @Input()\n    focusTrapped: boolean = false;\n\n    /** @Input Whether the popover should close when the escape key is pressed. */\n    @Input()\n    closeOnEscapeKey: boolean = true;\n\n    /** @Input Whether the popover is disabled. */\n    @Input()\n    disabled: boolean = false;\n\n    /** @Input Whether the popover should close when a click is made outside its boundaries. */\n    @Input()\n    closeOnOutsideClick: boolean = true;\n\n    /** @Input The element to which the popover should be appended. */\n    @Input()\n    appendTo: HTMLElement | 'body' = 'body';\n\n    /** @Input The Popper.js options to attach to this popover.\n     * See the [Popper.js Documentation](https://popper.js.org/popper-documentation.html) for details. */\n    @Input()\n    options: PopperOptions = {\n        placement: 'bottom-start',\n        modifiers: {\n            preventOverflow: {\n                enabled: true,\n                escapeWithReference: true,\n                boundariesElement: 'scrollParent'\n            }\n        }\n    };\n\n    /** @Input Whether the Popover Body should try to have the same width as the Popover Control. */\n    @Input()\n    fillControl: boolean = false;\n\n    /** @Output Event emitted when the state of the isOpen property changes. */\n    @Output()\n    isOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    private containerRef: ComponentRef<PopoverContainer>;\n    private popper: Popper;\n    private eventRef: Function[] = [];\n    private isSetup: boolean = false;\n\n    /** @hidden */\n    constructor(private elRef: ElementRef,\n                private cdRef: ChangeDetectorRef,\n                private resolver: ComponentFactoryResolver,\n                private injector: Injector,\n                private appRef: ApplicationRef,\n                private renderer: Renderer2) {\n    }\n\n    /** @hidden */\n    ngOnInit(): void {\n        if (this.isOpen) {\n            this.open();\n        }\n\n        this.initFillControl();\n        this.initPlacement();\n\n        this.addTriggerListeners();\n        this.isSetup = true;\n    }\n\n    /** @hidden */\n    ngOnDestroy(): void {\n        if (this.popper) {\n            this.popper.destroy();\n        }\n\n        if (this.containerRef) {\n            this.destroyContainer();\n        }\n\n        this.destroyTriggerListeners();\n    }\n\n    /** @hidden */\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!this.isSetup) {\n            return;\n        }\n\n        if (changes.triggers) {\n            setTimeout(() => {\n                this.destroyTriggerListeners();\n                this.addTriggerListeners();\n            });\n        }\n\n        if (changes.isOpen) {\n            if (changes.isOpen.currentValue) {\n                setTimeout(() => {\n                    this.isOpen = false;\n                    this.open(false);\n                });\n            } else {\n                setTimeout(() => {\n                    this.isOpen = true;\n                    this.close(false);\n                });\n            }\n        }\n\n        if (changes.placement) {\n            setTimeout(() => {\n                this.initPlacement();\n            });\n        }\n\n        if (changes.fillControl) {\n            setTimeout(() => {\n                this.initFillControl();\n            });\n        }\n    }\n\n    /**\n     * Toggles the popover open state.\n     */\n    public toggle(fireEvent: boolean = true): void {\n        if (this.isOpen) {\n            this.close(fireEvent);\n        } else {\n            this.open(fireEvent);\n        }\n    }\n\n    /**\n     * Opens the popover.\n     */\n    public open(fireEvent: boolean = true): void {\n        if (!this.isOpen && !this.disabled) {\n            this.createContainer();\n            this.isOpen = true;\n\n            if (fireEvent) {\n                this.isOpenChange.emit(this.isOpen);\n            }\n        }\n    }\n\n    /**\n     * Closes the popover.\n     */\n    public close(fireEvent: boolean = true): void {\n        if (this.isOpen) {\n            this.destroyContainer();\n            this.isOpen = false;\n\n            if (fireEvent) {\n                this.isOpenChange.emit(this.isOpen);\n            }\n        }\n    }\n\n    /**\n     * Forces an update of the popover's positioning calculation.\n     */\n    public updatePopper(): void {\n        if (this.popper) {\n            this.popper.scheduleUpdate();\n        }\n    }\n\n    private createContainer(): void {\n        if (this.containerRef) {\n            return;\n        }\n        \n        const factory = this.resolver.resolveComponentFactory(PopoverContainer);\n        this.containerRef = factory.create(this.injector);\n\n        // Set instance properties\n        this.containerRef.instance.context = this;\n        this.containerRef.instance.content = this.content;\n        this.containerRef.instance.focusTrapped = this.focusTrapped;\n        this.containerRef.instance.defaultArrow = this.defaultArrow;\n        this.containerRef.instance.closeOnEscapeKey = this.closeOnEscapeKey;\n\n        if (!this.defaultArrow) {\n            this.containerRef.location.nativeElement.style.margin = 0;\n        }\n\n        this.appRef.attachView(this.containerRef.hostView);\n        const setupRef = this.containerRef.instance.isSetup.subscribe(() => {\n            this.createPopper();\n            setupRef.unsubscribe();\n        });\n\n        const containerEl = (this.containerRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n        if (this.appendTo === 'body') {\n            document.body.appendChild(containerEl);\n        } else {\n            this.appendTo.appendChild(containerEl);\n        }\n\n    }\n\n    private destroyTriggerListeners(): void {\n        if (this.eventRef && this.eventRef.length > 0) {\n            this.eventRef.forEach(event => {\n                event();\n            });\n            this.eventRef = [];\n        }\n    }\n\n    private addTriggerListeners(): void {\n        if (this.triggers && this.triggers.length > 0) {\n            this.triggers.forEach(trigger => {\n                this.eventRef.push(this.renderer.listen(this.elRef.nativeElement, trigger, () => {\n                    this.toggle();\n                }));\n            });\n        }\n    }\n\n    private destroyContainer(): void {\n        if (this.containerRef) {\n            this.appRef.detachView(this.containerRef.hostView);\n            this.containerRef.destroy();\n            this.containerRef = null;\n        }\n\n        if (this.popper) {\n            this.popper.destroy();\n            this.popper = null;\n        }\n    }\n\n    private createPopper(): void {\n        this.popper = new Popper(\n            this.elRef.nativeElement as HTMLElement,\n            this.containerRef.location.nativeElement as HTMLElement,\n            this.options\n        );\n    }\n\n    private fillReference(data): any {\n        data.offsets.popper.left = data.offsets.reference.left;\n        data.offsets.popper.right = data.offsets.reference.right;\n        data.offsets.popper.width = data.styles.width = data.offsets.reference.width;\n        return data;\n    }\n\n    private initPlacement(): void {\n        if (this.placement) {\n            if (this.options) {\n                this.options.placement = this.placement;\n            } else {\n                this.options = {placement: this.placement}\n            }\n        }\n    }\n\n    private initFillControl(): void {\n        if (this.fillControl) {\n            if (this.options && this.options.modifiers) {\n                this.options.modifiers.fillReference = {\n                    enabled: true,\n                    fn: this.fillReference,\n                    order: 840\n                }\n            } else {\n                this.options = {\n                    modifiers: {\n                        fillReference: {\n                            enabled: true,\n                            fn: this.fillReference,\n                            order: 840\n                        }\n                    }\n                };\n            }\n        }\n    }\n\n    /** @hidden */\n    @HostListener('document:click', ['$event'])\n    clickHandler(event: MouseEvent): void {\n        if (this.containerRef &&\n            this.isOpen &&\n            this.closeOnOutsideClick &&\n            event.target !== this.elRef.nativeElement &&\n            !this.elRef.nativeElement.contains(event.target) &&\n            !this.containerRef.location.nativeElement.contains(event.target)) {\n            event.preventDefault();\n            event.stopPropagation();\n            this.close();\n        }\n    }\n}\n"]}