Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@ngneat/helipopper

Package Overview
Dependencies
Maintainers
3
Versions
81
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ngneat/helipopper - npm Package Compare versions

Comparing version 1.0.0 to 1.1.0

schematics/collection.json

78

bundles/ngneat-helipopper.umd.js

@@ -342,7 +342,10 @@ (function (global, factory) {

var icon = "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ";
var HelipopperDirective = /** @class */ (function () {
function HelipopperDirective(host, appRef, zone, config) {
function HelipopperDirective(host, appRef, zone, resolver, hostInjector, config) {
this.host = host;
this.appRef = appRef;
this.zone = zone;
this.resolver = resolver;
this.hostInjector = hostInjector;
this.config = config;

@@ -352,2 +355,3 @@ this.helipopperOptions = {};

this.helipopperAppendTo = document.body;
this.helipopperClose = new rxjs.Subject();
this._destroy = new rxjs.Subject();

@@ -403,11 +407,4 @@ this._placement = 'top';

var _this = this;
var _content;
if (content instanceof core.TemplateRef) {
_content = this.resolveTemplate(content);
}
else {
_content = this.mergedConfig.beforeRender(content);
}
this._content = content;
if (this.instance) {
this.instance.setContent(_content);
this.checkOverflow();

@@ -418,3 +415,3 @@ }

.pipe(operators.takeUntil(this._destroy))
.subscribe(function () { return _this.create(_content); });
.subscribe(function () { return _this.create(); });
}

@@ -463,3 +460,3 @@ },

HelipopperDirective.prototype.ngOnDestroy = function () {
this.tplPortal && this.destroyTemplate();
this.destroyView();
this.instance && this.instance.destroy();

@@ -469,7 +466,11 @@ this.instance = null;

};
HelipopperDirective.prototype.create = function (content) {
HelipopperDirective.prototype.destroyView = function () {
this.tplPortal && this.destroyTemplate();
this.innerComponentRef && this.destroyComponent();
};
HelipopperDirective.prototype.create = function () {
var _this = this;
this.zone.runOutsideAngular(function () { return _this.createInstance(content); });
this.zone.runOutsideAngular(function () { return _this.createInstance(); });
};
HelipopperDirective.prototype.createInstance = function (content) {
HelipopperDirective.prototype.createInstance = function () {
var _this = this;

@@ -484,3 +485,3 @@ if (this.showOnlyOnTextOverflow) {

this.helipopperTrigger = this.resolveTrigger();
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: content, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: undefined, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
// TODO: Merge the following methods with the passed config

@@ -490,5 +491,8 @@ onCreate: function (instance) {

}, onShow: function (instance) {
_this.zone.run(function () { return _this.instance.setContent(_this.resolveContent()); });
_this.isPopper && _this.addCloseButton(instance);
}, onHidden: function (instance) {
_this.isPopper && _this.removeCloseButton(instance);
_this.destroyView();
_this.helipopperClose.next();
} }, this.resolveTheme()), this.helipopperOptions));

@@ -547,6 +551,6 @@ this.markDisabled(this._disabled);

closeButtonElement.innerHTML = closeIcon;
var closeButtonSubcription = rxjs.fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
var closeButtonSubscription = rxjs.fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
popper.appendChild(closeButtonElement);
instance.closeButtonElement = closeButtonElement;
instance.closeButtonSubscription = closeButtonSubcription;
instance.closeButtonSubscription = closeButtonSubscription;
};

@@ -568,6 +572,7 @@ HelipopperDirective.prototype.removeCloseButton = function (instance) {

this.tplPortal.destroy();
this.tplPortal = null;
};
HelipopperDirective.prototype.createConfig = function (config) {
var defaults = {
closeIcon: "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ",
closeIcon: icon,
beforeRender: function (content) {

@@ -579,2 +584,29 @@ return content;

};
HelipopperDirective.prototype.resolveComponent = function (content) {
var factory = this.resolver.resolveComponentFactory(content);
var injector = this.injector || this.hostInjector;
this.innerComponentRef = factory.create(injector);
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef.hostView.detectChanges();
return this.innerComponentRef.location.nativeElement;
};
HelipopperDirective.prototype.destroyComponent = function () {
this.innerComponentRef.destroy();
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef = null;
};
HelipopperDirective.prototype.resolveContent = function () {
var content = this._content;
var finalContent;
if (content instanceof core.TemplateRef) {
finalContent = this.resolveTemplate(content);
}
else if (typeof content === 'string') {
finalContent = this.mergedConfig.beforeRender(content);
}
else {
finalContent = this.resolveComponent(content);
}
return finalContent;
};
HelipopperDirective.ctorParameters = function () { return [

@@ -584,2 +616,4 @@ { type: core.ElementRef },

{ type: core.NgZone },
{ type: core.ComponentFactoryResolver },
{ type: core.Injector },
{ type: undefined, decorators: [{ type: core.Inject, args: [HELIPOPPER_CONFIG,] }] }

@@ -612,2 +646,5 @@ ]; };

__decorate([
core.Input('helipopperInjector')
], HelipopperDirective.prototype, "injector", void 0);
__decorate([
core.Input('helipopperPlacement')

@@ -627,5 +664,8 @@ ], HelipopperDirective.prototype, "placement", null);

], HelipopperDirective.prototype, "helipopper", null);
__decorate([
core.Output()
], HelipopperDirective.prototype, "helipopperClose", void 0);
HelipopperDirective = __decorate([
core.Directive({ selector: "[helipopper]", exportAs: 'helipopper' }),
__param(3, core.Inject(HELIPOPPER_CONFIG))
__param(5, core.Inject(HELIPOPPER_CONFIG))
], HelipopperDirective);

@@ -632,0 +672,0 @@ return HelipopperDirective;

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("tippy.js"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("@ngneat/helipopper",["exports","@angular/core","tippy.js","rxjs","rxjs/operators"],t):t(((e=e||self).ngneat=e.ngneat||{},e.ngneat.helipopper={}),e.ng.core,e.tippy,e.rxjs,e.rxjs.operators)}(this,(function(e,t,o,i,n){"use strict";o=o&&Object.prototype.hasOwnProperty.call(o,"default")?o.default:o;var r=function(){return(r=Object.assign||function(e){for(var t,o=1,i=arguments.length;o<i;o++)for(var n in t=arguments[o])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)};function p(e,t,o,i){var n,r=arguments.length,p=r<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,o):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)p=Reflect.decorate(e,t,o,i);else for(var s=e.length-1;s>=0;s--)(n=e[s])&&(p=(r<3?n(p):r>3?n(t,o,p):n(t,o))||p);return r>3&&p&&Object.defineProperty(t,o,p),p}function s(e,t){var o="function"==typeof Symbol&&e[Symbol.iterator];if(!o)return e;var i,n,r=o.call(e),p=[];try{for(;(void 0===t||t-- >0)&&!(i=r.next()).done;)p.push(i.value)}catch(e){n={error:e}}finally{try{i&&!i.done&&(o=r.return)&&o.call(r)}finally{if(n)throw n.error}}return p}var l="IntersectionObserver"in window;var c="ResizeObserver"in window;function a(e,t){return c?function(e,t){void 0===t&&(t={box:"border-box"});return new i.Observable((function(o){var i=new ResizeObserver((function(e){var t=s(e,1)[0];t.borderBoxSize?o.next({width:t.borderBoxSize.inlineSize,height:t.borderBoxSize.blockSize}):o.next({width:t.target.offsetWidth,height:t.target.offsetHeight})}));return i.observe(e,t),function(){return i.disconnect()}}))}(e,t).pipe(n.auditTime(150)):function(e){return i.fromEvent(window,"resize").pipe(n.auditTime(150),n.map((function(){return{width:e.offsetWidth,height:e.offsetHeight}})),n.distinctUntilChanged((function(e,t){return e.width===t.width&&e.height===t.height})))}(e)}function h(e){return e instanceof t.ElementRef?e.nativeElement:e}function u(e){return e.onStable.pipe(n.take(1))}function f(e,t){Array.isArray(t)?t.forEach((function(t){return e.classList.add(t)})):e.classList.add(t)}var d=function(){function e(e){this.viewRef=e.createEmbeddedView({}),this.viewRef.detectChanges()}return Object.defineProperty(e.prototype,"elementRef",{get:function(){return this.viewRef.rootNodes[0]},enumerable:!0,configurable:!0}),e.prototype.destroy=function(){this.viewRef.destroy()},e}(),y=new t.InjectionToken("HELIPOPPER_CONFIG"),v=function(){function e(e,t,o,n){this.host=e,this.appRef=t,this.zone=o,this.config=n,this.helipopperOptions={},this.showOnlyOnTextOverflow=!1,this.helipopperAppendTo=document.body,this._destroy=new i.Subject,this._placement="top",this._disabled=!1,this._variation="tooltip",this.mergedConfig=this.createConfig(n)}var c,v;return Object.defineProperty(e.prototype,"placement",{set:function(e){this._placement=e,this.setProps({placement:e})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"variation",{set:function(e){this._variation=e,this.setProps(this.resolveTheme())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"disabled",{set:function(e){this._disabled=e,this.markDisabled(this._disabled)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"sticky",{set:function(e){this.instance&&(e?(this.setProps({trigger:"manual",hideOnClick:!1}),this.show()):(this.hide(),this.setProps({trigger:this.helipopperTrigger})))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"helipopper",{set:function(e){var o,r,p,c=this;o=e instanceof t.TemplateRef?this.resolveTemplate(e):this.mergedConfig.beforeRender(e),this.instance?(this.instance.setContent(o),this.checkOverflow()):i.forkJoin([(r=this.host.nativeElement,void 0===p&&(p={root:null,threshold:.3}),new i.Observable((function(e){l||(e.next(),e.complete());var t=new IntersectionObserver((function(t){s(t,1)[0].isIntersecting&&(e.next(),e.complete())}),p);return t.observe(r),function(){return t.disconnect()}}))),u(this.zone)]).pipe(n.takeUntil(this._destroy)).subscribe((function(){return c.create(o)}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_tooltipTarget",{get:function(){return h(this.triggerTarget)||this.host.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_tooltipHost",{get:function(){return h(this.helipopperHost)||this.host.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isTooltip",{get:function(){return"tooltip"===this._variation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isPopper",{get:function(){return"popper"===this._variation},enumerable:!0,configurable:!0}),e.prototype.setProps=function(e){this.instance&&this.instance.setProps(e)},e.prototype.hide=function(){this.instance.hide()},e.prototype.show=function(){this.instance.show()},e.prototype.ngOnDestroy=function(){this.tplPortal&&this.destroyTemplate(),this.instance&&this.instance.destroy(),this.instance=null,this._destroy.next()},e.prototype.create=function(e){var t=this;this.zone.runOutsideAngular((function(){return t.createInstance(e)}))},e.prototype.createInstance=function(e){var t=this;this.showOnlyOnTextOverflow&&a(this._tooltipHost).pipe(n.takeUntil(this._destroy)).subscribe((function(){t.markDisabled(!1===t.isElementOverflow())})),this.helipopperTrigger=this.resolveTrigger(),this.instance=o(this._tooltipHost,r(r({content:e,appendTo:this.getParent(),arrow:!this.isTooltip,allowHTML:!0,zIndex:1e6,trigger:this.helipopperTrigger,placement:this._placement,triggerTarget:this._tooltipTarget,onCreate:function(e){t.helipopperClass&&f(e.popper,t.helipopperClass)},onShow:function(e){t.isPopper&&t.addCloseButton(e)},onHidden:function(e){t.isPopper&&t.removeCloseButton(e)}},this.resolveTheme()),this.helipopperOptions)),this.markDisabled(this._disabled)},e.prototype.resolveTrigger=function(){return this.helipopperTrigger||(this.isTooltip?"mouseenter":"click")},e.prototype.resolveTemplate=function(e){return this.tplPortal&&this.destroyTemplate(),this.tplPortal=new d(e),this.appRef.attachView(this.tplPortal.viewRef),this.tplPortal.elementRef},e.prototype.isElementOverflow=function(){var e=this._tooltipTarget,t=e.parentElement,o=e.offsetWidth>t.offsetWidth,i=e.offsetWidth<e.scrollWidth;return o||i},e.prototype.getParent=function(){var e,t,o;return"string"==typeof this.helipopperAppendTo?(t=this.host.nativeElement,o=this.helipopperAppendTo,window.Element&&!Element.prototype.closest&&(Element.prototype.closest=function(e){var t,o=(this.document||this.ownerDocument).querySelectorAll(e),i=this;do{for(t=o.length;--t>=0&&o.item(t)!==i;);}while(t<0&&(i=i.parentElement));return i}),e=t.closest(o)):e=this.helipopperAppendTo,e||document.body},e.prototype.markDisabled=function(e){void 0===e&&(e=!0),this.instance&&(e?this.instance.disable():this.instance.enable())},e.prototype.resolveTheme=function(){return{offset:this.helipopperOffset||[0,this.isTooltip?5:10],theme:this.isTooltip?null:"light",arrow:!1===this.isTooltip,animation:this.isTooltip?"scale":null,interactive:!this.isTooltip}},e.prototype.addCloseButton=function(e){var t,o=this,n=e.popper,r=this.mergedConfig.closeIcon,p=(t="div",document.createElement(t));f(p,"tippy-close"),p.innerHTML=r;var s=i.fromEvent(p,"click").subscribe((function(){return o.hide()}));n.appendChild(p),e.closeButtonElement=p,e.closeButtonSubscription=s},e.prototype.removeCloseButton=function(e){e.popper.removeChild(e.closeButtonElement),e.closeButtonSubscription.unsubscribe(),e.closeButtonElement=null,e.closeButtonSubscription=null},e.prototype.checkOverflow=function(){var e=this;this.showOnlyOnTextOverflow&&u(this.zone).subscribe((function(){return e.markDisabled(!1===e.isElementOverflow())}))},e.prototype.destroyTemplate=function(){this.appRef.detachView(this.tplPortal.viewRef),this.tplPortal.destroy()},e.prototype.createConfig=function(e){return r(r({},{closeIcon:'\n <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">\n<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>\n</svg>\n ',beforeRender:function(e){return e}}),e)},e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.ApplicationRef},{type:t.NgZone},{type:void 0,decorators:[{type:t.Inject,args:[y]}]}]},p([t.Input()],e.prototype,"helipopperOptions",void 0),p([t.Input("helipopperTextOverflow")],e.prototype,"showOnlyOnTextOverflow",void 0),p([t.Input()],e.prototype,"triggerTarget",void 0),p([t.Input()],e.prototype,"helipopperHost",void 0),p([t.Input()],e.prototype,"helipopperAppendTo",void 0),p([t.Input()],e.prototype,"helipopperTrigger",void 0),p([t.Input()],e.prototype,"helipopperClass",void 0),p([t.Input()],e.prototype,"helipopperOffset",void 0),p([t.Input("helipopperPlacement")],e.prototype,"placement",null),p([t.Input("helipopperVariation")],e.prototype,"variation",null),p([t.Input("helipopperDisabled")],e.prototype,"disabled",null),p([t.Input("helipopperSticky")],e.prototype,"sticky",null),p([t.Input()],e.prototype,"helipopper",null),e=p([t.Directive({selector:"[helipopper]",exportAs:"helipopper"}),(c=3,v=t.Inject(y),function(e,t){v(e,t,c)})],e)}(),g=function(){function e(){}var o;return o=e,e.forRoot=function(e){return void 0===e&&(e={}),{ngModule:o,providers:[{provide:y,useValue:e}]}},e=o=p([t.NgModule({declarations:[v],exports:[v]})],e)}();e.HelipopperDirective=v,e.HelipopperModule=g,e.ɵb=y,Object.defineProperty(e,"__esModule",{value:!0})}));
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("tippy.js"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("@ngneat/helipopper",["exports","@angular/core","tippy.js","rxjs","rxjs/operators"],t):t(((e=e||self).ngneat=e.ngneat||{},e.ngneat.helipopper={}),e.ng.core,e.tippy,e.rxjs,e.rxjs.operators)}(this,(function(e,t,o,n,i){"use strict";o=o&&Object.prototype.hasOwnProperty.call(o,"default")?o.default:o;var r=function(){return(r=Object.assign||function(e){for(var t,o=1,n=arguments.length;o<n;o++)for(var i in t=arguments[o])Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i]);return e}).apply(this,arguments)};function p(e,t,o,n){var i,r=arguments.length,p=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)p=Reflect.decorate(e,t,o,n);else for(var s=e.length-1;s>=0;s--)(i=e[s])&&(p=(r<3?i(p):r>3?i(t,o,p):i(t,o))||p);return r>3&&p&&Object.defineProperty(t,o,p),p}function s(e,t){var o="function"==typeof Symbol&&e[Symbol.iterator];if(!o)return e;var n,i,r=o.call(e),p=[];try{for(;(void 0===t||t-- >0)&&!(n=r.next()).done;)p.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(o=r.return)&&o.call(r)}finally{if(i)throw i.error}}return p}var l="IntersectionObserver"in window;var c="ResizeObserver"in window;function h(e,t){return c?function(e,t){void 0===t&&(t={box:"border-box"});return new n.Observable((function(o){var n=new ResizeObserver((function(e){var t=s(e,1)[0];t.borderBoxSize?o.next({width:t.borderBoxSize.inlineSize,height:t.borderBoxSize.blockSize}):o.next({width:t.target.offsetWidth,height:t.target.offsetHeight})}));return n.observe(e,t),function(){return n.disconnect()}}))}(e,t).pipe(i.auditTime(150)):function(e){return n.fromEvent(window,"resize").pipe(i.auditTime(150),i.map((function(){return{width:e.offsetWidth,height:e.offsetHeight}})),i.distinctUntilChanged((function(e,t){return e.width===t.width&&e.height===t.height})))}(e)}function a(e){return e instanceof t.ElementRef?e.nativeElement:e}function u(e){return e.onStable.pipe(i.take(1))}function f(e,t){Array.isArray(t)?t.forEach((function(t){return e.classList.add(t)})):e.classList.add(t)}var d=function(){function e(e){this.viewRef=e.createEmbeddedView({}),this.viewRef.detectChanges()}return Object.defineProperty(e.prototype,"elementRef",{get:function(){return this.viewRef.rootNodes[0]},enumerable:!0,configurable:!0}),e.prototype.destroy=function(){this.viewRef.destroy()},e}(),y=new t.InjectionToken("HELIPOPPER_CONFIG"),v=function(){function e(e,t,o,i,r,p){this.host=e,this.appRef=t,this.zone=o,this.resolver=i,this.hostInjector=r,this.config=p,this.helipopperOptions={},this.showOnlyOnTextOverflow=!1,this.helipopperAppendTo=document.body,this.helipopperClose=new n.Subject,this._destroy=new n.Subject,this._placement="top",this._disabled=!1,this._variation="tooltip",this.mergedConfig=this.createConfig(p)}var c,v;return Object.defineProperty(e.prototype,"placement",{set:function(e){this._placement=e,this.setProps({placement:e})},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"variation",{set:function(e){this._variation=e,this.setProps(this.resolveTheme())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"disabled",{set:function(e){this._disabled=e,this.markDisabled(this._disabled)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"sticky",{set:function(e){this.instance&&(e?(this.setProps({trigger:"manual",hideOnClick:!1}),this.show()):(this.hide(),this.setProps({trigger:this.helipopperTrigger})))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"helipopper",{set:function(e){var t,o,r=this;this._content=e,this.instance?this.checkOverflow():n.forkJoin([(t=this.host.nativeElement,void 0===o&&(o={root:null,threshold:.3}),new n.Observable((function(e){l||(e.next(),e.complete());var n=new IntersectionObserver((function(t){s(t,1)[0].isIntersecting&&(e.next(),e.complete())}),o);return n.observe(t),function(){return n.disconnect()}}))),u(this.zone)]).pipe(i.takeUntil(this._destroy)).subscribe((function(){return r.create()}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_tooltipTarget",{get:function(){return a(this.triggerTarget)||this.host.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"_tooltipHost",{get:function(){return a(this.helipopperHost)||this.host.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isTooltip",{get:function(){return"tooltip"===this._variation},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isPopper",{get:function(){return"popper"===this._variation},enumerable:!0,configurable:!0}),e.prototype.setProps=function(e){this.instance&&this.instance.setProps(e)},e.prototype.hide=function(){this.instance.hide()},e.prototype.show=function(){this.instance.show()},e.prototype.ngOnDestroy=function(){this.destroyView(),this.instance&&this.instance.destroy(),this.instance=null,this._destroy.next()},e.prototype.destroyView=function(){this.tplPortal&&this.destroyTemplate(),this.innerComponentRef&&this.destroyComponent()},e.prototype.create=function(){var e=this;this.zone.runOutsideAngular((function(){return e.createInstance()}))},e.prototype.createInstance=function(){var e=this;this.showOnlyOnTextOverflow&&h(this._tooltipHost).pipe(i.takeUntil(this._destroy)).subscribe((function(){e.markDisabled(!1===e.isElementOverflow())})),this.helipopperTrigger=this.resolveTrigger(),this.instance=o(this._tooltipHost,r(r({content:void 0,appendTo:this.getParent(),arrow:!this.isTooltip,allowHTML:!0,zIndex:1e6,trigger:this.helipopperTrigger,placement:this._placement,triggerTarget:this._tooltipTarget,onCreate:function(t){e.helipopperClass&&f(t.popper,e.helipopperClass)},onShow:function(t){e.zone.run((function(){return e.instance.setContent(e.resolveContent())})),e.isPopper&&e.addCloseButton(t)},onHidden:function(t){e.isPopper&&e.removeCloseButton(t),e.destroyView(),e.helipopperClose.next()}},this.resolveTheme()),this.helipopperOptions)),this.markDisabled(this._disabled)},e.prototype.resolveTrigger=function(){return this.helipopperTrigger||(this.isTooltip?"mouseenter":"click")},e.prototype.resolveTemplate=function(e){return this.tplPortal&&this.destroyTemplate(),this.tplPortal=new d(e),this.appRef.attachView(this.tplPortal.viewRef),this.tplPortal.elementRef},e.prototype.isElementOverflow=function(){var e=this._tooltipTarget,t=e.parentElement,o=e.offsetWidth>t.offsetWidth,n=e.offsetWidth<e.scrollWidth;return o||n},e.prototype.getParent=function(){var e,t,o;return"string"==typeof this.helipopperAppendTo?(t=this.host.nativeElement,o=this.helipopperAppendTo,window.Element&&!Element.prototype.closest&&(Element.prototype.closest=function(e){var t,o=(this.document||this.ownerDocument).querySelectorAll(e),n=this;do{for(t=o.length;--t>=0&&o.item(t)!==n;);}while(t<0&&(n=n.parentElement));return n}),e=t.closest(o)):e=this.helipopperAppendTo,e||document.body},e.prototype.markDisabled=function(e){void 0===e&&(e=!0),this.instance&&(e?this.instance.disable():this.instance.enable())},e.prototype.resolveTheme=function(){return{offset:this.helipopperOffset||[0,this.isTooltip?5:10],theme:this.isTooltip?null:"light",arrow:!1===this.isTooltip,animation:this.isTooltip?"scale":null,interactive:!this.isTooltip}},e.prototype.addCloseButton=function(e){var t,o=this,i=e.popper,r=this.mergedConfig.closeIcon,p=(t="div",document.createElement(t));f(p,"tippy-close"),p.innerHTML=r;var s=n.fromEvent(p,"click").subscribe((function(){return o.hide()}));i.appendChild(p),e.closeButtonElement=p,e.closeButtonSubscription=s},e.prototype.removeCloseButton=function(e){e.popper.removeChild(e.closeButtonElement),e.closeButtonSubscription.unsubscribe(),e.closeButtonElement=null,e.closeButtonSubscription=null},e.prototype.checkOverflow=function(){var e=this;this.showOnlyOnTextOverflow&&u(this.zone).subscribe((function(){return e.markDisabled(!1===e.isElementOverflow())}))},e.prototype.destroyTemplate=function(){this.appRef.detachView(this.tplPortal.viewRef),this.tplPortal.destroy(),this.tplPortal=null},e.prototype.createConfig=function(e){return r(r({},{closeIcon:'\n <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">\n<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>\n</svg>\n ',beforeRender:function(e){return e}}),e)},e.prototype.resolveComponent=function(e){var t=this.resolver.resolveComponentFactory(e),o=this.injector||this.hostInjector;return this.innerComponentRef=t.create(o),this.appRef.attachView(this.innerComponentRef.hostView),this.innerComponentRef.hostView.detectChanges(),this.innerComponentRef.location.nativeElement},e.prototype.destroyComponent=function(){this.innerComponentRef.destroy(),this.appRef.attachView(this.innerComponentRef.hostView),this.innerComponentRef=null},e.prototype.resolveContent=function(){var e=this._content;return e instanceof t.TemplateRef?this.resolveTemplate(e):"string"==typeof e?this.mergedConfig.beforeRender(e):this.resolveComponent(e)},e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.ApplicationRef},{type:t.NgZone},{type:t.ComponentFactoryResolver},{type:t.Injector},{type:void 0,decorators:[{type:t.Inject,args:[y]}]}]},p([t.Input()],e.prototype,"helipopperOptions",void 0),p([t.Input("helipopperTextOverflow")],e.prototype,"showOnlyOnTextOverflow",void 0),p([t.Input()],e.prototype,"triggerTarget",void 0),p([t.Input()],e.prototype,"helipopperHost",void 0),p([t.Input()],e.prototype,"helipopperAppendTo",void 0),p([t.Input()],e.prototype,"helipopperTrigger",void 0),p([t.Input()],e.prototype,"helipopperClass",void 0),p([t.Input()],e.prototype,"helipopperOffset",void 0),p([t.Input("helipopperInjector")],e.prototype,"injector",void 0),p([t.Input("helipopperPlacement")],e.prototype,"placement",null),p([t.Input("helipopperVariation")],e.prototype,"variation",null),p([t.Input("helipopperDisabled")],e.prototype,"disabled",null),p([t.Input("helipopperSticky")],e.prototype,"sticky",null),p([t.Input()],e.prototype,"helipopper",null),p([t.Output()],e.prototype,"helipopperClose",void 0),e=p([t.Directive({selector:"[helipopper]",exportAs:"helipopper"}),(c=5,v=t.Inject(y),function(e,t){v(e,t,c)})],e)}(),m=function(){function e(){}var o;return o=e,e.forRoot=function(e){return void 0===e&&(e={}),{ngModule:o,providers:[{provide:y,useValue:e}]}},e=o=p([t.NgModule({declarations:[v],exports:[v]})],e)}();e.HelipopperDirective=v,e.HelipopperModule=m,e.ɵb=y,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=ngneat-helipopper.umd.min.js.map
import { __decorate, __param } from "tslib";
import { ApplicationRef, Directive, ElementRef, Inject, Input, NgZone, OnDestroy, TemplateRef } from '@angular/core';
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Inject, Injector, Input, NgZone, OnDestroy, Output, TemplateRef, Type } from '@angular/core';
import tippy from 'tippy.js';

@@ -8,7 +8,14 @@ import { forkJoin, fromEvent, Subject } from 'rxjs';

import { HELIPOPPER_CONFIG } from './helipopper.types';
const icon = `
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">
<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>
</svg>
`;
let HelipopperDirective = class HelipopperDirective {
constructor(host, appRef, zone, config) {
constructor(host, appRef, zone, resolver, hostInjector, config) {
this.host = host;
this.appRef = appRef;
this.zone = zone;
this.resolver = resolver;
this.hostInjector = hostInjector;
this.config = config;

@@ -18,2 +25,3 @@ this.helipopperOptions = {};

this.helipopperAppendTo = document.body;
this.helipopperClose = new Subject();
this._destroy = new Subject();

@@ -51,11 +59,4 @@ this._placement = 'top';

set helipopper(content) {
let _content;
if (content instanceof TemplateRef) {
_content = this.resolveTemplate(content);
}
else {
_content = this.mergedConfig.beforeRender(content);
}
this._content = content;
if (this.instance) {
this.instance.setContent(_content);
this.checkOverflow();

@@ -66,3 +67,3 @@ }

.pipe(takeUntil(this._destroy))
.subscribe(() => this.create(_content));
.subscribe(() => this.create());
}

@@ -92,3 +93,3 @@ }

ngOnDestroy() {
this.tplPortal && this.destroyTemplate();
this.destroyView();
this.instance && this.instance.destroy();

@@ -98,6 +99,10 @@ this.instance = null;

}
create(content) {
this.zone.runOutsideAngular(() => this.createInstance(content));
destroyView() {
this.tplPortal && this.destroyTemplate();
this.innerComponentRef && this.destroyComponent();
}
createInstance(content) {
create() {
this.zone.runOutsideAngular(() => this.createInstance());
}
createInstance() {
if (this.showOnlyOnTextOverflow) {

@@ -111,3 +116,3 @@ dimensionsChanges(this._tooltipHost)

this.helipopperTrigger = this.resolveTrigger();
this.instance = tippy(this._tooltipHost, Object.assign(Object.assign({ content, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
this.instance = tippy(this._tooltipHost, Object.assign(Object.assign({ content: undefined, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
// TODO: Merge the following methods with the passed config

@@ -117,5 +122,8 @@ onCreate: instance => {

}, onShow: instance => {
this.zone.run(() => this.instance.setContent(this.resolveContent()));
this.isPopper && this.addCloseButton(instance);
}, onHidden: instance => {
this.isPopper && this.removeCloseButton(instance);
this.destroyView();
this.helipopperClose.next();
} }, this.resolveTheme()), this.helipopperOptions));

@@ -172,6 +180,6 @@ this.markDisabled(this._disabled);

closeButtonElement.innerHTML = closeIcon;
const closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());
const closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());
popper.appendChild(closeButtonElement);
instance.closeButtonElement = closeButtonElement;
instance.closeButtonSubscription = closeButtonSubcription;
instance.closeButtonSubscription = closeButtonSubscription;
}

@@ -192,10 +200,7 @@ removeCloseButton(instance) {

this.tplPortal.destroy();
this.tplPortal = null;
}
createConfig(config) {
const defaults = {
closeIcon: `
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">
<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>
</svg>
`,
closeIcon: icon,
beforeRender(content) {

@@ -207,2 +212,29 @@ return content;

}
resolveComponent(content) {
const factory = this.resolver.resolveComponentFactory(content);
const injector = this.injector || this.hostInjector;
this.innerComponentRef = factory.create(injector);
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef.hostView.detectChanges();
return this.innerComponentRef.location.nativeElement;
}
destroyComponent() {
this.innerComponentRef.destroy();
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef = null;
}
resolveContent() {
const content = this._content;
let finalContent;
if (content instanceof TemplateRef) {
finalContent = this.resolveTemplate(content);
}
else if (typeof content === 'string') {
finalContent = this.mergedConfig.beforeRender(content);
}
else {
finalContent = this.resolveComponent(content);
}
return finalContent;
}
};

@@ -213,2 +245,4 @@ HelipopperDirective.ctorParameters = () => [

{ type: NgZone },
{ type: ComponentFactoryResolver },
{ type: Injector },
{ type: undefined, decorators: [{ type: Inject, args: [HELIPOPPER_CONFIG,] }] }

@@ -241,2 +275,5 @@ ];

__decorate([
Input('helipopperInjector')
], HelipopperDirective.prototype, "injector", void 0);
__decorate([
Input('helipopperPlacement')

@@ -256,7 +293,10 @@ ], HelipopperDirective.prototype, "placement", null);

], HelipopperDirective.prototype, "helipopper", null);
__decorate([
Output()
], HelipopperDirective.prototype, "helipopperClose", void 0);
HelipopperDirective = __decorate([
Directive({ selector: `[helipopper]`, exportAs: 'helipopper' }),
__param(3, Inject(HELIPOPPER_CONFIG))
__param(5, Inject(HELIPOPPER_CONFIG))
], HelipopperDirective);
export { HelipopperDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helipopper.directive.js","sourceRoot":"ng://@ngneat/helipopper/","sources":["lib/helipopper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, Directive, ElementRef, Inject, Input, NgZone, OnDestroy, TemplateRef } from '@angular/core';\nimport tippy, { Instance, Props } from 'tippy.js';\nimport { forkJoin, fromEvent, Subject } from 'rxjs';\nimport { Options as PopperOptions } from '@popperjs/core';\nimport {\n  addClass,\n  closest,\n  coerceElement,\n  createElement,\n  dimensionsChanges,\n  inView,\n  isString,\n  TemplatePortal,\n  zoneStable\n} from './utils';\nimport { takeUntil } from 'rxjs/operators';\nimport { HELIPOPPER_CONFIG, HelipopperConfig, InstanceWithClose, Variation } from './helipopper.types';\n\n@Directive({ selector: `[helipopper]`, exportAs: 'helipopper' })\nexport class HelipopperDirective implements OnDestroy {\n  @Input()\n  helipopperOptions: Partial<Props> = {};\n\n  @Input('helipopperTextOverflow')\n  showOnlyOnTextOverflow = false;\n\n  // The element that the trigger event listeners are added to\n  @Input()\n  triggerTarget: Element;\n\n  @Input()\n  helipopperHost: Element;\n\n  @Input()\n  helipopperAppendTo: string | HTMLElement = document.body;\n\n  @Input()\n  helipopperTrigger: string | undefined;\n\n  @Input()\n  helipopperClass: string | Array<string> | undefined;\n\n  @Input()\n  helipopperOffset: [number, number] | undefined;\n\n  @Input('helipopperPlacement')\n  set placement(placement: PopperOptions['placement']) {\n    this._placement = placement;\n    this.setProps({ placement });\n  }\n\n  @Input('helipopperVariation')\n  set variation(variation: Variation) {\n    this._variation = variation;\n    this.setProps(this.resolveTheme());\n  }\n\n  @Input('helipopperDisabled')\n  set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    this.markDisabled(this._disabled);\n  }\n\n  @Input('helipopperSticky')\n  set sticky(isSticky: boolean) {\n    if (!this.instance) {\n      return;\n    }\n\n    if (isSticky) {\n      this.setProps({ trigger: 'manual', hideOnClick: false });\n      this.show();\n    } else {\n      this.hide();\n      this.setProps({ trigger: this.helipopperTrigger });\n    }\n  }\n\n  @Input() set helipopper(content: string | TemplateRef<any>) {\n    let _content;\n    if (content instanceof TemplateRef) {\n      _content = this.resolveTemplate(content);\n    } else {\n      _content = this.mergedConfig.beforeRender(content);\n    }\n\n    if (this.instance) {\n      this.instance.setContent(_content);\n      this.checkOverflow();\n    } else {\n      forkJoin([inView(this.host.nativeElement), zoneStable(this.zone)])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => this.create(_content));\n    }\n  }\n\n  private _destroy = new Subject();\n  private _placement: PopperOptions['placement'] = 'top';\n  private _disabled = false;\n  private _variation: Variation = 'tooltip';\n  private instance: Instance;\n  private tplPortal: TemplatePortal;\n  private mergedConfig: HelipopperConfig;\n\n  constructor(\n    private host: ElementRef,\n    private appRef: ApplicationRef,\n    private zone: NgZone,\n    @Inject(HELIPOPPER_CONFIG) private config: HelipopperConfig\n  ) {\n    this.mergedConfig = this.createConfig(config);\n  }\n\n  private get _tooltipTarget(): HTMLElement {\n    return coerceElement(this.triggerTarget) || this.host.nativeElement;\n  }\n\n  private get _tooltipHost(): HTMLElement {\n    return coerceElement(this.helipopperHost) || this.host.nativeElement;\n  }\n\n  private get isTooltip() {\n    return this._variation === 'tooltip';\n  }\n\n  private get isPopper() {\n    return this._variation === 'popper';\n  }\n\n  setProps(props: Partial<Props>) {\n    this.instance && this.instance.setProps(props);\n  }\n\n  hide() {\n    this.instance.hide();\n  }\n\n  show() {\n    this.instance.show();\n  }\n\n  ngOnDestroy() {\n    this.tplPortal && this.destroyTemplate();\n    this.instance && this.instance.destroy();\n    this.instance = null;\n    this._destroy.next();\n  }\n\n  private create(content) {\n    this.zone.runOutsideAngular(() => this.createInstance(content));\n  }\n\n  private createInstance(content) {\n    if (this.showOnlyOnTextOverflow) {\n      dimensionsChanges(this._tooltipHost)\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => {\n          this.markDisabled(this.isElementOverflow() === false);\n        });\n    }\n\n    this.helipopperTrigger = this.resolveTrigger();\n\n    this.instance = tippy(this._tooltipHost, {\n      content,\n      appendTo: this.getParent(),\n      arrow: !this.isTooltip,\n      allowHTML: true,\n      zIndex: 1000000,\n      trigger: this.helipopperTrigger,\n      placement: this._placement,\n      triggerTarget: this._tooltipTarget,\n      // TODO: Merge the following methods with the passed config\n      onCreate: instance => {\n        this.helipopperClass && addClass(instance.popper, this.helipopperClass);\n      },\n      onShow: instance => {\n        this.isPopper && this.addCloseButton(instance as InstanceWithClose);\n      },\n      onHidden: instance => {\n        this.isPopper && this.removeCloseButton(instance as InstanceWithClose);\n      },\n      ...this.resolveTheme(),\n      ...this.helipopperOptions\n    });\n\n    this.markDisabled(this._disabled);\n  }\n\n  private resolveTrigger() {\n    return this.helipopperTrigger || (this.isTooltip ? 'mouseenter' : 'click');\n  }\n\n  private resolveTemplate(content: TemplateRef<any>) {\n    if (this.tplPortal) {\n      this.destroyTemplate();\n    }\n    this.tplPortal = new TemplatePortal(content);\n    this.appRef.attachView(this.tplPortal.viewRef);\n\n    return this.tplPortal.elementRef;\n  }\n\n  private isElementOverflow() {\n    const element = this._tooltipTarget;\n    const parentEl = element.parentElement;\n    const parentTest = element.offsetWidth > parentEl.offsetWidth;\n    const elementTest = element.offsetWidth < element.scrollWidth;\n\n    return parentTest || elementTest;\n  }\n\n  private getParent() {\n    let containerElement;\n\n    if (isString(this.helipopperAppendTo)) {\n      containerElement = closest(this.host.nativeElement, this.helipopperAppendTo);\n    } else {\n      containerElement = this.helipopperAppendTo;\n    }\n\n    return containerElement || document.body;\n  }\n\n  private markDisabled(disabled = true) {\n    if (this.instance) {\n      disabled ? this.instance.disable() : this.instance.enable();\n    }\n  }\n\n  private resolveTheme() {\n    return {\n      offset: this.helipopperOffset || ([0, this.isTooltip ? 5 : 10] as [number, number]),\n      theme: this.isTooltip ? null : 'light',\n      arrow: this.isTooltip === false,\n      animation: this.isTooltip ? `scale` : null,\n      interactive: !this.isTooltip\n    };\n  }\n\n  private addCloseButton(instance: InstanceWithClose) {\n    const popper = instance.popper;\n    const closeIcon = this.mergedConfig.closeIcon;\n    const closeButtonElement = createElement('div');\n    addClass(closeButtonElement, 'tippy-close');\n    closeButtonElement.innerHTML = closeIcon;\n\n    const closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());\n    popper.appendChild(closeButtonElement);\n\n    instance.closeButtonElement = closeButtonElement;\n    instance.closeButtonSubscription = closeButtonSubcription;\n  }\n\n  private removeCloseButton(instance: InstanceWithClose) {\n    instance.popper.removeChild(instance.closeButtonElement);\n    instance.closeButtonSubscription.unsubscribe();\n    instance.closeButtonElement = null;\n    instance.closeButtonSubscription = null;\n  }\n\n  private checkOverflow() {\n    if (this.showOnlyOnTextOverflow) {\n      zoneStable(this.zone).subscribe(() => this.markDisabled(this.isElementOverflow() === false));\n    }\n  }\n\n  private destroyTemplate() {\n    this.appRef.detachView(this.tplPortal.viewRef);\n    this.tplPortal.destroy();\n  }\n\n  private createConfig(config: HelipopperConfig) {\n    const defaults: HelipopperConfig = {\n      closeIcon: `\n      <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n      `,\n      beforeRender(content: string): string {\n        return content;\n      }\n    };\n\n    return {\n      ...defaults,\n      ...config\n    };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helipopper.directive.js","sourceRoot":"ng://@ngneat/helipopper/","sources":["lib/helipopper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Inject,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  Type\n} from '@angular/core';\nimport tippy, { Instance, Props } from 'tippy.js';\nimport { forkJoin, fromEvent, Subject } from 'rxjs';\nimport { Options as PopperOptions } from '@popperjs/core';\nimport {\n  addClass,\n  closest,\n  coerceElement,\n  createElement,\n  dimensionsChanges,\n  inView,\n  isString,\n  TemplatePortal,\n  zoneStable\n} from './utils';\nimport { takeUntil } from 'rxjs/operators';\nimport { HELIPOPPER_CONFIG, HelipopperConfig, InstanceWithClose, Variation } from './helipopper.types';\n\nconst icon = `\n      <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n      `;\n\ntype Content = string | TemplateRef<any> | Type<any>;\n\n@Directive({ selector: `[helipopper]`, exportAs: 'helipopper' })\nexport class HelipopperDirective implements OnDestroy {\n  @Input()\n  helipopperOptions: Partial<Props> = {};\n\n  @Input('helipopperTextOverflow')\n  showOnlyOnTextOverflow = false;\n\n  // The element that the trigger event listeners are added to\n  @Input()\n  triggerTarget: Element;\n\n  @Input()\n  helipopperHost: Element;\n\n  @Input()\n  helipopperAppendTo: string | HTMLElement = document.body;\n\n  @Input()\n  helipopperTrigger: string | undefined;\n\n  @Input()\n  helipopperClass: string | Array<string> | undefined;\n\n  @Input()\n  helipopperOffset: [number, number] | undefined;\n\n  @Input('helipopperInjector')\n  injector: Injector | undefined;\n\n  @Input('helipopperPlacement')\n  set placement(placement: PopperOptions['placement']) {\n    this._placement = placement;\n    this.setProps({ placement });\n  }\n\n  @Input('helipopperVariation')\n  set variation(variation: Variation) {\n    this._variation = variation;\n    this.setProps(this.resolveTheme());\n  }\n\n  @Input('helipopperDisabled')\n  set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    this.markDisabled(this._disabled);\n  }\n\n  @Input('helipopperSticky')\n  set sticky(isSticky: boolean) {\n    if (!this.instance) {\n      return;\n    }\n\n    if (isSticky) {\n      this.setProps({ trigger: 'manual', hideOnClick: false });\n      this.show();\n    } else {\n      this.hide();\n      this.setProps({ trigger: this.helipopperTrigger });\n    }\n  }\n\n  @Input() set helipopper(content: Content) {\n    this._content = content;\n\n    if (this.instance) {\n      this.checkOverflow();\n    } else {\n      forkJoin([inView(this.host.nativeElement), zoneStable(this.zone)])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => this.create());\n    }\n  }\n\n  @Output() helipopperClose = new Subject();\n\n  private _content: Content;\n  private _destroy = new Subject();\n  private _placement: PopperOptions['placement'] = 'top';\n  private _disabled = false;\n  private _variation: Variation = 'tooltip';\n  private instance: Instance;\n  private tplPortal: TemplatePortal;\n  private mergedConfig: HelipopperConfig;\n  private innerComponentRef: ComponentRef<any>;\n\n  constructor(\n    private host: ElementRef,\n    private appRef: ApplicationRef,\n    private zone: NgZone,\n    private resolver: ComponentFactoryResolver,\n    private hostInjector: Injector,\n    @Inject(HELIPOPPER_CONFIG) private config: HelipopperConfig\n  ) {\n    this.mergedConfig = this.createConfig(config);\n  }\n\n  private get _tooltipTarget(): HTMLElement {\n    return coerceElement(this.triggerTarget) || this.host.nativeElement;\n  }\n\n  private get _tooltipHost(): HTMLElement {\n    return coerceElement(this.helipopperHost) || this.host.nativeElement;\n  }\n\n  private get isTooltip() {\n    return this._variation === 'tooltip';\n  }\n\n  private get isPopper() {\n    return this._variation === 'popper';\n  }\n\n  setProps(props: Partial<Props>) {\n    this.instance && this.instance.setProps(props);\n  }\n\n  hide() {\n    this.instance.hide();\n  }\n\n  show() {\n    this.instance.show();\n  }\n\n  ngOnDestroy() {\n    this.destroyView();\n    this.instance && this.instance.destroy();\n    this.instance = null;\n    this._destroy.next();\n  }\n\n  private destroyView() {\n    this.tplPortal && this.destroyTemplate();\n    this.innerComponentRef && this.destroyComponent();\n  }\n\n  private create() {\n    this.zone.runOutsideAngular(() => this.createInstance());\n  }\n\n  private createInstance() {\n    if (this.showOnlyOnTextOverflow) {\n      dimensionsChanges(this._tooltipHost)\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => {\n          this.markDisabled(this.isElementOverflow() === false);\n        });\n    }\n\n    this.helipopperTrigger = this.resolveTrigger();\n\n    this.instance = tippy(this._tooltipHost, {\n      content: undefined,\n      appendTo: this.getParent(),\n      arrow: !this.isTooltip,\n      allowHTML: true,\n      zIndex: 1000000,\n      trigger: this.helipopperTrigger,\n      placement: this._placement,\n      triggerTarget: this._tooltipTarget,\n      // TODO: Merge the following methods with the passed config\n      onCreate: instance => {\n        this.helipopperClass && addClass(instance.popper, this.helipopperClass);\n      },\n      onShow: instance => {\n        this.zone.run(() => this.instance.setContent(this.resolveContent()));\n        this.isPopper && this.addCloseButton(instance as InstanceWithClose);\n      },\n      onHidden: instance => {\n        this.isPopper && this.removeCloseButton(instance as InstanceWithClose);\n        this.destroyView();\n        this.helipopperClose.next();\n      },\n      ...this.resolveTheme(),\n      ...this.helipopperOptions\n    });\n\n    this.markDisabled(this._disabled);\n  }\n\n  private resolveTrigger() {\n    return this.helipopperTrigger || (this.isTooltip ? 'mouseenter' : 'click');\n  }\n\n  private resolveTemplate(content: TemplateRef<any>) {\n    if (this.tplPortal) {\n      this.destroyTemplate();\n    }\n    this.tplPortal = new TemplatePortal(content);\n    this.appRef.attachView(this.tplPortal.viewRef);\n\n    return this.tplPortal.elementRef;\n  }\n\n  private isElementOverflow() {\n    const element = this._tooltipTarget;\n    const parentEl = element.parentElement;\n    const parentTest = element.offsetWidth > parentEl.offsetWidth;\n    const elementTest = element.offsetWidth < element.scrollWidth;\n\n    return parentTest || elementTest;\n  }\n\n  private getParent() {\n    let containerElement;\n\n    if (isString(this.helipopperAppendTo)) {\n      containerElement = closest(this.host.nativeElement, this.helipopperAppendTo);\n    } else {\n      containerElement = this.helipopperAppendTo;\n    }\n\n    return containerElement || document.body;\n  }\n\n  private markDisabled(disabled = true) {\n    if (this.instance) {\n      disabled ? this.instance.disable() : this.instance.enable();\n    }\n  }\n\n  private resolveTheme() {\n    return {\n      offset: this.helipopperOffset || ([0, this.isTooltip ? 5 : 10] as [number, number]),\n      theme: this.isTooltip ? null : 'light',\n      arrow: this.isTooltip === false,\n      animation: this.isTooltip ? `scale` : null,\n      interactive: !this.isTooltip\n    };\n  }\n\n  private addCloseButton(instance: InstanceWithClose) {\n    const popper = instance.popper;\n    const closeIcon = this.mergedConfig.closeIcon;\n    const closeButtonElement = createElement('div');\n    addClass(closeButtonElement, 'tippy-close');\n    closeButtonElement.innerHTML = closeIcon;\n\n    const closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());\n    popper.appendChild(closeButtonElement);\n\n    instance.closeButtonElement = closeButtonElement;\n    instance.closeButtonSubscription = closeButtonSubscription;\n  }\n\n  private removeCloseButton(instance: InstanceWithClose) {\n    instance.popper.removeChild(instance.closeButtonElement);\n    instance.closeButtonSubscription.unsubscribe();\n    instance.closeButtonElement = null;\n    instance.closeButtonSubscription = null;\n  }\n\n  private checkOverflow() {\n    if (this.showOnlyOnTextOverflow) {\n      zoneStable(this.zone).subscribe(() => this.markDisabled(this.isElementOverflow() === false));\n    }\n  }\n\n  private destroyTemplate() {\n    this.appRef.detachView(this.tplPortal.viewRef);\n    this.tplPortal.destroy();\n    this.tplPortal = null;\n  }\n\n  private createConfig(config: HelipopperConfig) {\n    const defaults: HelipopperConfig = {\n      closeIcon: icon,\n      beforeRender(content: string): string {\n        return content;\n      }\n    };\n\n    return {\n      ...defaults,\n      ...config\n    };\n  }\n\n  private resolveComponent(content: Type<any>) {\n    const factory = this.resolver.resolveComponentFactory(content);\n    const injector = this.injector || this.hostInjector;\n    this.innerComponentRef = factory.create(injector);\n    this.appRef.attachView(this.innerComponentRef.hostView);\n    this.innerComponentRef.hostView.detectChanges();\n    return this.innerComponentRef.location.nativeElement;\n  }\n\n  private destroyComponent() {\n    this.innerComponentRef.destroy();\n    this.appRef.attachView(this.innerComponentRef.hostView);\n    this.innerComponentRef = null;\n  }\n\n  private resolveContent() {\n    const content = this._content;\n    let finalContent;\n\n    if (content instanceof TemplateRef) {\n      finalContent = this.resolveTemplate(content);\n    } else if (typeof content === 'string') {\n      finalContent = this.mergedConfig.beforeRender(content);\n    } else {\n      finalContent = this.resolveComponent(content);\n    }\n\n    return finalContent;\n  }\n}\n"]}
import { __assign, __decorate, __param } from "tslib";
import { ApplicationRef, Directive, ElementRef, Inject, Input, NgZone, OnDestroy, TemplateRef } from '@angular/core';
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, Inject, Injector, Input, NgZone, OnDestroy, Output, TemplateRef, Type } from '@angular/core';
import tippy from 'tippy.js';

@@ -8,7 +8,10 @@ import { forkJoin, fromEvent, Subject } from 'rxjs';

import { HELIPOPPER_CONFIG } from './helipopper.types';
var icon = "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ";
var HelipopperDirective = /** @class */ (function () {
function HelipopperDirective(host, appRef, zone, config) {
function HelipopperDirective(host, appRef, zone, resolver, hostInjector, config) {
this.host = host;
this.appRef = appRef;
this.zone = zone;
this.resolver = resolver;
this.hostInjector = hostInjector;
this.config = config;

@@ -18,2 +21,3 @@ this.helipopperOptions = {};

this.helipopperAppendTo = document.body;
this.helipopperClose = new Subject();
this._destroy = new Subject();

@@ -69,11 +73,4 @@ this._placement = 'top';

var _this = this;
var _content;
if (content instanceof TemplateRef) {
_content = this.resolveTemplate(content);
}
else {
_content = this.mergedConfig.beforeRender(content);
}
this._content = content;
if (this.instance) {
this.instance.setContent(_content);
this.checkOverflow();

@@ -84,3 +81,3 @@ }

.pipe(takeUntil(this._destroy))
.subscribe(function () { return _this.create(_content); });
.subscribe(function () { return _this.create(); });
}

@@ -129,3 +126,3 @@ },

HelipopperDirective.prototype.ngOnDestroy = function () {
this.tplPortal && this.destroyTemplate();
this.destroyView();
this.instance && this.instance.destroy();

@@ -135,7 +132,11 @@ this.instance = null;

};
HelipopperDirective.prototype.create = function (content) {
HelipopperDirective.prototype.destroyView = function () {
this.tplPortal && this.destroyTemplate();
this.innerComponentRef && this.destroyComponent();
};
HelipopperDirective.prototype.create = function () {
var _this = this;
this.zone.runOutsideAngular(function () { return _this.createInstance(content); });
this.zone.runOutsideAngular(function () { return _this.createInstance(); });
};
HelipopperDirective.prototype.createInstance = function (content) {
HelipopperDirective.prototype.createInstance = function () {
var _this = this;

@@ -150,3 +151,3 @@ if (this.showOnlyOnTextOverflow) {

this.helipopperTrigger = this.resolveTrigger();
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: content, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: undefined, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
// TODO: Merge the following methods with the passed config

@@ -156,5 +157,8 @@ onCreate: function (instance) {

}, onShow: function (instance) {
_this.zone.run(function () { return _this.instance.setContent(_this.resolveContent()); });
_this.isPopper && _this.addCloseButton(instance);
}, onHidden: function (instance) {
_this.isPopper && _this.removeCloseButton(instance);
_this.destroyView();
_this.helipopperClose.next();
} }, this.resolveTheme()), this.helipopperOptions));

@@ -213,6 +217,6 @@ this.markDisabled(this._disabled);

closeButtonElement.innerHTML = closeIcon;
var closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
var closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
popper.appendChild(closeButtonElement);
instance.closeButtonElement = closeButtonElement;
instance.closeButtonSubscription = closeButtonSubcription;
instance.closeButtonSubscription = closeButtonSubscription;
};

@@ -234,6 +238,7 @@ HelipopperDirective.prototype.removeCloseButton = function (instance) {

this.tplPortal.destroy();
this.tplPortal = null;
};
HelipopperDirective.prototype.createConfig = function (config) {
var defaults = {
closeIcon: "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ",
closeIcon: icon,
beforeRender: function (content) {

@@ -245,2 +250,29 @@ return content;

};
HelipopperDirective.prototype.resolveComponent = function (content) {
var factory = this.resolver.resolveComponentFactory(content);
var injector = this.injector || this.hostInjector;
this.innerComponentRef = factory.create(injector);
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef.hostView.detectChanges();
return this.innerComponentRef.location.nativeElement;
};
HelipopperDirective.prototype.destroyComponent = function () {
this.innerComponentRef.destroy();
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef = null;
};
HelipopperDirective.prototype.resolveContent = function () {
var content = this._content;
var finalContent;
if (content instanceof TemplateRef) {
finalContent = this.resolveTemplate(content);
}
else if (typeof content === 'string') {
finalContent = this.mergedConfig.beforeRender(content);
}
else {
finalContent = this.resolveComponent(content);
}
return finalContent;
};
HelipopperDirective.ctorParameters = function () { return [

@@ -250,2 +282,4 @@ { type: ElementRef },

{ type: NgZone },
{ type: ComponentFactoryResolver },
{ type: Injector },
{ type: undefined, decorators: [{ type: Inject, args: [HELIPOPPER_CONFIG,] }] }

@@ -278,2 +312,5 @@ ]; };

__decorate([
Input('helipopperInjector')
], HelipopperDirective.prototype, "injector", void 0);
__decorate([
Input('helipopperPlacement')

@@ -293,5 +330,8 @@ ], HelipopperDirective.prototype, "placement", null);

], HelipopperDirective.prototype, "helipopper", null);
__decorate([
Output()
], HelipopperDirective.prototype, "helipopperClose", void 0);
HelipopperDirective = __decorate([
Directive({ selector: "[helipopper]", exportAs: 'helipopper' }),
__param(3, Inject(HELIPOPPER_CONFIG))
__param(5, Inject(HELIPOPPER_CONFIG))
], HelipopperDirective);

@@ -301,2 +341,2 @@ return HelipopperDirective;

export { HelipopperDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helipopper.directive.js","sourceRoot":"ng://@ngneat/helipopper/","sources":["lib/helipopper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, Directive, ElementRef, Inject, Input, NgZone, OnDestroy, TemplateRef } from '@angular/core';\nimport tippy, { Instance, Props } from 'tippy.js';\nimport { forkJoin, fromEvent, Subject } from 'rxjs';\nimport { Options as PopperOptions } from '@popperjs/core';\nimport {\n  addClass,\n  closest,\n  coerceElement,\n  createElement,\n  dimensionsChanges,\n  inView,\n  isString,\n  TemplatePortal,\n  zoneStable\n} from './utils';\nimport { takeUntil } from 'rxjs/operators';\nimport { HELIPOPPER_CONFIG, HelipopperConfig, InstanceWithClose, Variation } from './helipopper.types';\n\n@Directive({ selector: `[helipopper]`, exportAs: 'helipopper' })\nexport class HelipopperDirective implements OnDestroy {\n  @Input()\n  helipopperOptions: Partial<Props> = {};\n\n  @Input('helipopperTextOverflow')\n  showOnlyOnTextOverflow = false;\n\n  // The element that the trigger event listeners are added to\n  @Input()\n  triggerTarget: Element;\n\n  @Input()\n  helipopperHost: Element;\n\n  @Input()\n  helipopperAppendTo: string | HTMLElement = document.body;\n\n  @Input()\n  helipopperTrigger: string | undefined;\n\n  @Input()\n  helipopperClass: string | Array<string> | undefined;\n\n  @Input()\n  helipopperOffset: [number, number] | undefined;\n\n  @Input('helipopperPlacement')\n  set placement(placement: PopperOptions['placement']) {\n    this._placement = placement;\n    this.setProps({ placement });\n  }\n\n  @Input('helipopperVariation')\n  set variation(variation: Variation) {\n    this._variation = variation;\n    this.setProps(this.resolveTheme());\n  }\n\n  @Input('helipopperDisabled')\n  set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    this.markDisabled(this._disabled);\n  }\n\n  @Input('helipopperSticky')\n  set sticky(isSticky: boolean) {\n    if (!this.instance) {\n      return;\n    }\n\n    if (isSticky) {\n      this.setProps({ trigger: 'manual', hideOnClick: false });\n      this.show();\n    } else {\n      this.hide();\n      this.setProps({ trigger: this.helipopperTrigger });\n    }\n  }\n\n  @Input() set helipopper(content: string | TemplateRef<any>) {\n    let _content;\n    if (content instanceof TemplateRef) {\n      _content = this.resolveTemplate(content);\n    } else {\n      _content = this.mergedConfig.beforeRender(content);\n    }\n\n    if (this.instance) {\n      this.instance.setContent(_content);\n      this.checkOverflow();\n    } else {\n      forkJoin([inView(this.host.nativeElement), zoneStable(this.zone)])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => this.create(_content));\n    }\n  }\n\n  private _destroy = new Subject();\n  private _placement: PopperOptions['placement'] = 'top';\n  private _disabled = false;\n  private _variation: Variation = 'tooltip';\n  private instance: Instance;\n  private tplPortal: TemplatePortal;\n  private mergedConfig: HelipopperConfig;\n\n  constructor(\n    private host: ElementRef,\n    private appRef: ApplicationRef,\n    private zone: NgZone,\n    @Inject(HELIPOPPER_CONFIG) private config: HelipopperConfig\n  ) {\n    this.mergedConfig = this.createConfig(config);\n  }\n\n  private get _tooltipTarget(): HTMLElement {\n    return coerceElement(this.triggerTarget) || this.host.nativeElement;\n  }\n\n  private get _tooltipHost(): HTMLElement {\n    return coerceElement(this.helipopperHost) || this.host.nativeElement;\n  }\n\n  private get isTooltip() {\n    return this._variation === 'tooltip';\n  }\n\n  private get isPopper() {\n    return this._variation === 'popper';\n  }\n\n  setProps(props: Partial<Props>) {\n    this.instance && this.instance.setProps(props);\n  }\n\n  hide() {\n    this.instance.hide();\n  }\n\n  show() {\n    this.instance.show();\n  }\n\n  ngOnDestroy() {\n    this.tplPortal && this.destroyTemplate();\n    this.instance && this.instance.destroy();\n    this.instance = null;\n    this._destroy.next();\n  }\n\n  private create(content) {\n    this.zone.runOutsideAngular(() => this.createInstance(content));\n  }\n\n  private createInstance(content) {\n    if (this.showOnlyOnTextOverflow) {\n      dimensionsChanges(this._tooltipHost)\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => {\n          this.markDisabled(this.isElementOverflow() === false);\n        });\n    }\n\n    this.helipopperTrigger = this.resolveTrigger();\n\n    this.instance = tippy(this._tooltipHost, {\n      content,\n      appendTo: this.getParent(),\n      arrow: !this.isTooltip,\n      allowHTML: true,\n      zIndex: 1000000,\n      trigger: this.helipopperTrigger,\n      placement: this._placement,\n      triggerTarget: this._tooltipTarget,\n      // TODO: Merge the following methods with the passed config\n      onCreate: instance => {\n        this.helipopperClass && addClass(instance.popper, this.helipopperClass);\n      },\n      onShow: instance => {\n        this.isPopper && this.addCloseButton(instance as InstanceWithClose);\n      },\n      onHidden: instance => {\n        this.isPopper && this.removeCloseButton(instance as InstanceWithClose);\n      },\n      ...this.resolveTheme(),\n      ...this.helipopperOptions\n    });\n\n    this.markDisabled(this._disabled);\n  }\n\n  private resolveTrigger() {\n    return this.helipopperTrigger || (this.isTooltip ? 'mouseenter' : 'click');\n  }\n\n  private resolveTemplate(content: TemplateRef<any>) {\n    if (this.tplPortal) {\n      this.destroyTemplate();\n    }\n    this.tplPortal = new TemplatePortal(content);\n    this.appRef.attachView(this.tplPortal.viewRef);\n\n    return this.tplPortal.elementRef;\n  }\n\n  private isElementOverflow() {\n    const element = this._tooltipTarget;\n    const parentEl = element.parentElement;\n    const parentTest = element.offsetWidth > parentEl.offsetWidth;\n    const elementTest = element.offsetWidth < element.scrollWidth;\n\n    return parentTest || elementTest;\n  }\n\n  private getParent() {\n    let containerElement;\n\n    if (isString(this.helipopperAppendTo)) {\n      containerElement = closest(this.host.nativeElement, this.helipopperAppendTo);\n    } else {\n      containerElement = this.helipopperAppendTo;\n    }\n\n    return containerElement || document.body;\n  }\n\n  private markDisabled(disabled = true) {\n    if (this.instance) {\n      disabled ? this.instance.disable() : this.instance.enable();\n    }\n  }\n\n  private resolveTheme() {\n    return {\n      offset: this.helipopperOffset || ([0, this.isTooltip ? 5 : 10] as [number, number]),\n      theme: this.isTooltip ? null : 'light',\n      arrow: this.isTooltip === false,\n      animation: this.isTooltip ? `scale` : null,\n      interactive: !this.isTooltip\n    };\n  }\n\n  private addCloseButton(instance: InstanceWithClose) {\n    const popper = instance.popper;\n    const closeIcon = this.mergedConfig.closeIcon;\n    const closeButtonElement = createElement('div');\n    addClass(closeButtonElement, 'tippy-close');\n    closeButtonElement.innerHTML = closeIcon;\n\n    const closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());\n    popper.appendChild(closeButtonElement);\n\n    instance.closeButtonElement = closeButtonElement;\n    instance.closeButtonSubscription = closeButtonSubcription;\n  }\n\n  private removeCloseButton(instance: InstanceWithClose) {\n    instance.popper.removeChild(instance.closeButtonElement);\n    instance.closeButtonSubscription.unsubscribe();\n    instance.closeButtonElement = null;\n    instance.closeButtonSubscription = null;\n  }\n\n  private checkOverflow() {\n    if (this.showOnlyOnTextOverflow) {\n      zoneStable(this.zone).subscribe(() => this.markDisabled(this.isElementOverflow() === false));\n    }\n  }\n\n  private destroyTemplate() {\n    this.appRef.detachView(this.tplPortal.viewRef);\n    this.tplPortal.destroy();\n  }\n\n  private createConfig(config: HelipopperConfig) {\n    const defaults: HelipopperConfig = {\n      closeIcon: `\n      <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n      `,\n      beforeRender(content: string): string {\n        return content;\n      }\n    };\n\n    return {\n      ...defaults,\n      ...config\n    };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helipopper.directive.js","sourceRoot":"ng://@ngneat/helipopper/","sources":["lib/helipopper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Inject,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  Type\n} from '@angular/core';\nimport tippy, { Instance, Props } from 'tippy.js';\nimport { forkJoin, fromEvent, Subject } from 'rxjs';\nimport { Options as PopperOptions } from '@popperjs/core';\nimport {\n  addClass,\n  closest,\n  coerceElement,\n  createElement,\n  dimensionsChanges,\n  inView,\n  isString,\n  TemplatePortal,\n  zoneStable\n} from './utils';\nimport { takeUntil } from 'rxjs/operators';\nimport { HELIPOPPER_CONFIG, HelipopperConfig, InstanceWithClose, Variation } from './helipopper.types';\n\nconst icon = `\n      <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n      `;\n\ntype Content = string | TemplateRef<any> | Type<any>;\n\n@Directive({ selector: `[helipopper]`, exportAs: 'helipopper' })\nexport class HelipopperDirective implements OnDestroy {\n  @Input()\n  helipopperOptions: Partial<Props> = {};\n\n  @Input('helipopperTextOverflow')\n  showOnlyOnTextOverflow = false;\n\n  // The element that the trigger event listeners are added to\n  @Input()\n  triggerTarget: Element;\n\n  @Input()\n  helipopperHost: Element;\n\n  @Input()\n  helipopperAppendTo: string | HTMLElement = document.body;\n\n  @Input()\n  helipopperTrigger: string | undefined;\n\n  @Input()\n  helipopperClass: string | Array<string> | undefined;\n\n  @Input()\n  helipopperOffset: [number, number] | undefined;\n\n  @Input('helipopperInjector')\n  injector: Injector | undefined;\n\n  @Input('helipopperPlacement')\n  set placement(placement: PopperOptions['placement']) {\n    this._placement = placement;\n    this.setProps({ placement });\n  }\n\n  @Input('helipopperVariation')\n  set variation(variation: Variation) {\n    this._variation = variation;\n    this.setProps(this.resolveTheme());\n  }\n\n  @Input('helipopperDisabled')\n  set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    this.markDisabled(this._disabled);\n  }\n\n  @Input('helipopperSticky')\n  set sticky(isSticky: boolean) {\n    if (!this.instance) {\n      return;\n    }\n\n    if (isSticky) {\n      this.setProps({ trigger: 'manual', hideOnClick: false });\n      this.show();\n    } else {\n      this.hide();\n      this.setProps({ trigger: this.helipopperTrigger });\n    }\n  }\n\n  @Input() set helipopper(content: Content) {\n    this._content = content;\n\n    if (this.instance) {\n      this.checkOverflow();\n    } else {\n      forkJoin([inView(this.host.nativeElement), zoneStable(this.zone)])\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => this.create());\n    }\n  }\n\n  @Output() helipopperClose = new Subject();\n\n  private _content: Content;\n  private _destroy = new Subject();\n  private _placement: PopperOptions['placement'] = 'top';\n  private _disabled = false;\n  private _variation: Variation = 'tooltip';\n  private instance: Instance;\n  private tplPortal: TemplatePortal;\n  private mergedConfig: HelipopperConfig;\n  private innerComponentRef: ComponentRef<any>;\n\n  constructor(\n    private host: ElementRef,\n    private appRef: ApplicationRef,\n    private zone: NgZone,\n    private resolver: ComponentFactoryResolver,\n    private hostInjector: Injector,\n    @Inject(HELIPOPPER_CONFIG) private config: HelipopperConfig\n  ) {\n    this.mergedConfig = this.createConfig(config);\n  }\n\n  private get _tooltipTarget(): HTMLElement {\n    return coerceElement(this.triggerTarget) || this.host.nativeElement;\n  }\n\n  private get _tooltipHost(): HTMLElement {\n    return coerceElement(this.helipopperHost) || this.host.nativeElement;\n  }\n\n  private get isTooltip() {\n    return this._variation === 'tooltip';\n  }\n\n  private get isPopper() {\n    return this._variation === 'popper';\n  }\n\n  setProps(props: Partial<Props>) {\n    this.instance && this.instance.setProps(props);\n  }\n\n  hide() {\n    this.instance.hide();\n  }\n\n  show() {\n    this.instance.show();\n  }\n\n  ngOnDestroy() {\n    this.destroyView();\n    this.instance && this.instance.destroy();\n    this.instance = null;\n    this._destroy.next();\n  }\n\n  private destroyView() {\n    this.tplPortal && this.destroyTemplate();\n    this.innerComponentRef && this.destroyComponent();\n  }\n\n  private create() {\n    this.zone.runOutsideAngular(() => this.createInstance());\n  }\n\n  private createInstance() {\n    if (this.showOnlyOnTextOverflow) {\n      dimensionsChanges(this._tooltipHost)\n        .pipe(takeUntil(this._destroy))\n        .subscribe(() => {\n          this.markDisabled(this.isElementOverflow() === false);\n        });\n    }\n\n    this.helipopperTrigger = this.resolveTrigger();\n\n    this.instance = tippy(this._tooltipHost, {\n      content: undefined,\n      appendTo: this.getParent(),\n      arrow: !this.isTooltip,\n      allowHTML: true,\n      zIndex: 1000000,\n      trigger: this.helipopperTrigger,\n      placement: this._placement,\n      triggerTarget: this._tooltipTarget,\n      // TODO: Merge the following methods with the passed config\n      onCreate: instance => {\n        this.helipopperClass && addClass(instance.popper, this.helipopperClass);\n      },\n      onShow: instance => {\n        this.zone.run(() => this.instance.setContent(this.resolveContent()));\n        this.isPopper && this.addCloseButton(instance as InstanceWithClose);\n      },\n      onHidden: instance => {\n        this.isPopper && this.removeCloseButton(instance as InstanceWithClose);\n        this.destroyView();\n        this.helipopperClose.next();\n      },\n      ...this.resolveTheme(),\n      ...this.helipopperOptions\n    });\n\n    this.markDisabled(this._disabled);\n  }\n\n  private resolveTrigger() {\n    return this.helipopperTrigger || (this.isTooltip ? 'mouseenter' : 'click');\n  }\n\n  private resolveTemplate(content: TemplateRef<any>) {\n    if (this.tplPortal) {\n      this.destroyTemplate();\n    }\n    this.tplPortal = new TemplatePortal(content);\n    this.appRef.attachView(this.tplPortal.viewRef);\n\n    return this.tplPortal.elementRef;\n  }\n\n  private isElementOverflow() {\n    const element = this._tooltipTarget;\n    const parentEl = element.parentElement;\n    const parentTest = element.offsetWidth > parentEl.offsetWidth;\n    const elementTest = element.offsetWidth < element.scrollWidth;\n\n    return parentTest || elementTest;\n  }\n\n  private getParent() {\n    let containerElement;\n\n    if (isString(this.helipopperAppendTo)) {\n      containerElement = closest(this.host.nativeElement, this.helipopperAppendTo);\n    } else {\n      containerElement = this.helipopperAppendTo;\n    }\n\n    return containerElement || document.body;\n  }\n\n  private markDisabled(disabled = true) {\n    if (this.instance) {\n      disabled ? this.instance.disable() : this.instance.enable();\n    }\n  }\n\n  private resolveTheme() {\n    return {\n      offset: this.helipopperOffset || ([0, this.isTooltip ? 5 : 10] as [number, number]),\n      theme: this.isTooltip ? null : 'light',\n      arrow: this.isTooltip === false,\n      animation: this.isTooltip ? `scale` : null,\n      interactive: !this.isTooltip\n    };\n  }\n\n  private addCloseButton(instance: InstanceWithClose) {\n    const popper = instance.popper;\n    const closeIcon = this.mergedConfig.closeIcon;\n    const closeButtonElement = createElement('div');\n    addClass(closeButtonElement, 'tippy-close');\n    closeButtonElement.innerHTML = closeIcon;\n\n    const closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());\n    popper.appendChild(closeButtonElement);\n\n    instance.closeButtonElement = closeButtonElement;\n    instance.closeButtonSubscription = closeButtonSubscription;\n  }\n\n  private removeCloseButton(instance: InstanceWithClose) {\n    instance.popper.removeChild(instance.closeButtonElement);\n    instance.closeButtonSubscription.unsubscribe();\n    instance.closeButtonElement = null;\n    instance.closeButtonSubscription = null;\n  }\n\n  private checkOverflow() {\n    if (this.showOnlyOnTextOverflow) {\n      zoneStable(this.zone).subscribe(() => this.markDisabled(this.isElementOverflow() === false));\n    }\n  }\n\n  private destroyTemplate() {\n    this.appRef.detachView(this.tplPortal.viewRef);\n    this.tplPortal.destroy();\n    this.tplPortal = null;\n  }\n\n  private createConfig(config: HelipopperConfig) {\n    const defaults: HelipopperConfig = {\n      closeIcon: icon,\n      beforeRender(content: string): string {\n        return content;\n      }\n    };\n\n    return {\n      ...defaults,\n      ...config\n    };\n  }\n\n  private resolveComponent(content: Type<any>) {\n    const factory = this.resolver.resolveComponentFactory(content);\n    const injector = this.injector || this.hostInjector;\n    this.innerComponentRef = factory.create(injector);\n    this.appRef.attachView(this.innerComponentRef.hostView);\n    this.innerComponentRef.hostView.detectChanges();\n    return this.innerComponentRef.location.nativeElement;\n  }\n\n  private destroyComponent() {\n    this.innerComponentRef.destroy();\n    this.appRef.attachView(this.innerComponentRef.hostView);\n    this.innerComponentRef = null;\n  }\n\n  private resolveContent() {\n    const content = this._content;\n    let finalContent;\n\n    if (content instanceof TemplateRef) {\n      finalContent = this.resolveTemplate(content);\n    } else if (typeof content === 'string') {\n      finalContent = this.mergedConfig.beforeRender(content);\n    } else {\n      finalContent = this.resolveComponent(content);\n    }\n\n    return finalContent;\n  }\n}\n"]}
import { __decorate, __param } from 'tslib';
import { ElementRef, InjectionToken, TemplateRef, ApplicationRef, NgZone, Inject, Input, Directive, NgModule } from '@angular/core';
import { ElementRef, InjectionToken, TemplateRef, ApplicationRef, NgZone, ComponentFactoryResolver, Injector, Inject, Input, Output, Directive, NgModule } from '@angular/core';
import tippy from 'tippy.js';

@@ -112,7 +112,14 @@ import { Observable, fromEvent, Subject, forkJoin } from 'rxjs';

const icon = `
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">
<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>
</svg>
`;
let HelipopperDirective = class HelipopperDirective {
constructor(host, appRef, zone, config) {
constructor(host, appRef, zone, resolver, hostInjector, config) {
this.host = host;
this.appRef = appRef;
this.zone = zone;
this.resolver = resolver;
this.hostInjector = hostInjector;
this.config = config;

@@ -122,2 +129,3 @@ this.helipopperOptions = {};

this.helipopperAppendTo = document.body;
this.helipopperClose = new Subject();
this._destroy = new Subject();

@@ -155,11 +163,4 @@ this._placement = 'top';

set helipopper(content) {
let _content;
if (content instanceof TemplateRef) {
_content = this.resolveTemplate(content);
}
else {
_content = this.mergedConfig.beforeRender(content);
}
this._content = content;
if (this.instance) {
this.instance.setContent(_content);
this.checkOverflow();

@@ -170,3 +171,3 @@ }

.pipe(takeUntil(this._destroy))
.subscribe(() => this.create(_content));
.subscribe(() => this.create());
}

@@ -196,3 +197,3 @@ }

ngOnDestroy() {
this.tplPortal && this.destroyTemplate();
this.destroyView();
this.instance && this.instance.destroy();

@@ -202,6 +203,10 @@ this.instance = null;

}
create(content) {
this.zone.runOutsideAngular(() => this.createInstance(content));
destroyView() {
this.tplPortal && this.destroyTemplate();
this.innerComponentRef && this.destroyComponent();
}
createInstance(content) {
create() {
this.zone.runOutsideAngular(() => this.createInstance());
}
createInstance() {
if (this.showOnlyOnTextOverflow) {

@@ -215,3 +220,3 @@ dimensionsChanges(this._tooltipHost)

this.helipopperTrigger = this.resolveTrigger();
this.instance = tippy(this._tooltipHost, Object.assign(Object.assign({ content, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
this.instance = tippy(this._tooltipHost, Object.assign(Object.assign({ content: undefined, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
// TODO: Merge the following methods with the passed config

@@ -221,5 +226,8 @@ onCreate: instance => {

}, onShow: instance => {
this.zone.run(() => this.instance.setContent(this.resolveContent()));
this.isPopper && this.addCloseButton(instance);
}, onHidden: instance => {
this.isPopper && this.removeCloseButton(instance);
this.destroyView();
this.helipopperClose.next();
} }, this.resolveTheme()), this.helipopperOptions));

@@ -276,6 +284,6 @@ this.markDisabled(this._disabled);

closeButtonElement.innerHTML = closeIcon;
const closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());
const closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(() => this.hide());
popper.appendChild(closeButtonElement);
instance.closeButtonElement = closeButtonElement;
instance.closeButtonSubscription = closeButtonSubcription;
instance.closeButtonSubscription = closeButtonSubscription;
}

@@ -296,10 +304,7 @@ removeCloseButton(instance) {

this.tplPortal.destroy();
this.tplPortal = null;
}
createConfig(config) {
const defaults = {
closeIcon: `
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fit="" preserveAspectRatio="xMidYMid meet" focusable="false">
<path d="M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z"></path>
</svg>
`,
closeIcon: icon,
beforeRender(content) {

@@ -311,2 +316,29 @@ return content;

}
resolveComponent(content) {
const factory = this.resolver.resolveComponentFactory(content);
const injector = this.injector || this.hostInjector;
this.innerComponentRef = factory.create(injector);
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef.hostView.detectChanges();
return this.innerComponentRef.location.nativeElement;
}
destroyComponent() {
this.innerComponentRef.destroy();
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef = null;
}
resolveContent() {
const content = this._content;
let finalContent;
if (content instanceof TemplateRef) {
finalContent = this.resolveTemplate(content);
}
else if (typeof content === 'string') {
finalContent = this.mergedConfig.beforeRender(content);
}
else {
finalContent = this.resolveComponent(content);
}
return finalContent;
}
};

@@ -317,2 +349,4 @@ HelipopperDirective.ctorParameters = () => [

{ type: NgZone },
{ type: ComponentFactoryResolver },
{ type: Injector },
{ type: undefined, decorators: [{ type: Inject, args: [HELIPOPPER_CONFIG,] }] }

@@ -345,2 +379,5 @@ ];

__decorate([
Input('helipopperInjector')
], HelipopperDirective.prototype, "injector", void 0);
__decorate([
Input('helipopperPlacement')

@@ -360,5 +397,8 @@ ], HelipopperDirective.prototype, "placement", null);

], HelipopperDirective.prototype, "helipopper", null);
__decorate([
Output()
], HelipopperDirective.prototype, "helipopperClose", void 0);
HelipopperDirective = __decorate([
Directive({ selector: `[helipopper]`, exportAs: 'helipopper' }),
__param(3, Inject(HELIPOPPER_CONFIG))
__param(5, Inject(HELIPOPPER_CONFIG))
], HelipopperDirective);

@@ -365,0 +405,0 @@

import { __read, __assign, __decorate, __param } from 'tslib';
import { ElementRef, InjectionToken, TemplateRef, ApplicationRef, NgZone, Inject, Input, Directive, NgModule } from '@angular/core';
import { ElementRef, InjectionToken, TemplateRef, ApplicationRef, NgZone, ComponentFactoryResolver, Injector, Inject, Input, Output, Directive, NgModule } from '@angular/core';
import tippy from 'tippy.js';

@@ -121,7 +121,10 @@ import { Observable, fromEvent, Subject, forkJoin } from 'rxjs';

var icon = "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ";
var HelipopperDirective = /** @class */ (function () {
function HelipopperDirective(host, appRef, zone, config) {
function HelipopperDirective(host, appRef, zone, resolver, hostInjector, config) {
this.host = host;
this.appRef = appRef;
this.zone = zone;
this.resolver = resolver;
this.hostInjector = hostInjector;
this.config = config;

@@ -131,2 +134,3 @@ this.helipopperOptions = {};

this.helipopperAppendTo = document.body;
this.helipopperClose = new Subject();
this._destroy = new Subject();

@@ -182,11 +186,4 @@ this._placement = 'top';

var _this = this;
var _content;
if (content instanceof TemplateRef) {
_content = this.resolveTemplate(content);
}
else {
_content = this.mergedConfig.beforeRender(content);
}
this._content = content;
if (this.instance) {
this.instance.setContent(_content);
this.checkOverflow();

@@ -197,3 +194,3 @@ }

.pipe(takeUntil(this._destroy))
.subscribe(function () { return _this.create(_content); });
.subscribe(function () { return _this.create(); });
}

@@ -242,3 +239,3 @@ },

HelipopperDirective.prototype.ngOnDestroy = function () {
this.tplPortal && this.destroyTemplate();
this.destroyView();
this.instance && this.instance.destroy();

@@ -248,7 +245,11 @@ this.instance = null;

};
HelipopperDirective.prototype.create = function (content) {
HelipopperDirective.prototype.destroyView = function () {
this.tplPortal && this.destroyTemplate();
this.innerComponentRef && this.destroyComponent();
};
HelipopperDirective.prototype.create = function () {
var _this = this;
this.zone.runOutsideAngular(function () { return _this.createInstance(content); });
this.zone.runOutsideAngular(function () { return _this.createInstance(); });
};
HelipopperDirective.prototype.createInstance = function (content) {
HelipopperDirective.prototype.createInstance = function () {
var _this = this;

@@ -263,3 +264,3 @@ if (this.showOnlyOnTextOverflow) {

this.helipopperTrigger = this.resolveTrigger();
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: content, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
this.instance = tippy(this._tooltipHost, __assign(__assign({ content: undefined, appendTo: this.getParent(), arrow: !this.isTooltip, allowHTML: true, zIndex: 1000000, trigger: this.helipopperTrigger, placement: this._placement, triggerTarget: this._tooltipTarget,
// TODO: Merge the following methods with the passed config

@@ -269,5 +270,8 @@ onCreate: function (instance) {

}, onShow: function (instance) {
_this.zone.run(function () { return _this.instance.setContent(_this.resolveContent()); });
_this.isPopper && _this.addCloseButton(instance);
}, onHidden: function (instance) {
_this.isPopper && _this.removeCloseButton(instance);
_this.destroyView();
_this.helipopperClose.next();
} }, this.resolveTheme()), this.helipopperOptions));

@@ -326,6 +330,6 @@ this.markDisabled(this._disabled);

closeButtonElement.innerHTML = closeIcon;
var closeButtonSubcription = fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
var closeButtonSubscription = fromEvent(closeButtonElement, 'click').subscribe(function () { return _this.hide(); });
popper.appendChild(closeButtonElement);
instance.closeButtonElement = closeButtonElement;
instance.closeButtonSubscription = closeButtonSubcription;
instance.closeButtonSubscription = closeButtonSubscription;
};

@@ -347,6 +351,7 @@ HelipopperDirective.prototype.removeCloseButton = function (instance) {

this.tplPortal.destroy();
this.tplPortal = null;
};
HelipopperDirective.prototype.createConfig = function (config) {
var defaults = {
closeIcon: "\n <svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"100%\" height=\"100%\" viewBox=\"0 0 24 24\" fit=\"\" preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\">\n<path d=\"M12.793 12l4.039-4.025c0.219-0.219 0.224-0.578 0.012-0.802-0.213-0.225-0.563-0.231-0.782-0.011l-4.062 4.049-4.062-4.049c-0.219-0.22-0.569-0.213-0.782 0.011s-0.208 0.583 0.012 0.802l4.039 4.025-4.039 4.025c-0.22 0.219-0.224 0.578-0.012 0.802 0.108 0.115 0.252 0.172 0.397 0.172 0.138 0 0.278-0.053 0.385-0.161l4.062-4.049 4.062 4.049c0.107 0.108 0.245 0.161 0.385 0.161 0.144 0 0.287-0.058 0.397-0.172 0.212-0.225 0.207-0.583-0.012-0.802l-4.039-4.025z\"></path>\n</svg>\n ",
closeIcon: icon,
beforeRender: function (content) {

@@ -358,2 +363,29 @@ return content;

};
HelipopperDirective.prototype.resolveComponent = function (content) {
var factory = this.resolver.resolveComponentFactory(content);
var injector = this.injector || this.hostInjector;
this.innerComponentRef = factory.create(injector);
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef.hostView.detectChanges();
return this.innerComponentRef.location.nativeElement;
};
HelipopperDirective.prototype.destroyComponent = function () {
this.innerComponentRef.destroy();
this.appRef.attachView(this.innerComponentRef.hostView);
this.innerComponentRef = null;
};
HelipopperDirective.prototype.resolveContent = function () {
var content = this._content;
var finalContent;
if (content instanceof TemplateRef) {
finalContent = this.resolveTemplate(content);
}
else if (typeof content === 'string') {
finalContent = this.mergedConfig.beforeRender(content);
}
else {
finalContent = this.resolveComponent(content);
}
return finalContent;
};
HelipopperDirective.ctorParameters = function () { return [

@@ -363,2 +395,4 @@ { type: ElementRef },

{ type: NgZone },
{ type: ComponentFactoryResolver },
{ type: Injector },
{ type: undefined, decorators: [{ type: Inject, args: [HELIPOPPER_CONFIG,] }] }

@@ -391,2 +425,5 @@ ]; };

__decorate([
Input('helipopperInjector')
], HelipopperDirective.prototype, "injector", void 0);
__decorate([
Input('helipopperPlacement')

@@ -406,5 +443,8 @@ ], HelipopperDirective.prototype, "placement", null);

], HelipopperDirective.prototype, "helipopper", null);
__decorate([
Output()
], HelipopperDirective.prototype, "helipopperClose", void 0);
HelipopperDirective = __decorate([
Directive({ selector: "[helipopper]", exportAs: 'helipopper' }),
__param(3, Inject(HELIPOPPER_CONFIG))
__param(5, Inject(HELIPOPPER_CONFIG))
], HelipopperDirective);

@@ -411,0 +451,0 @@ return HelipopperDirective;

@@ -1,5 +0,7 @@

import { ApplicationRef, ElementRef, NgZone, OnDestroy, TemplateRef } from '@angular/core';
import { ApplicationRef, ComponentFactoryResolver, ElementRef, Injector, NgZone, OnDestroy, TemplateRef, Type } from '@angular/core';
import { Props } from 'tippy.js';
import { Subject } from 'rxjs';
import { Options as PopperOptions } from '@popperjs/core';
import { HelipopperConfig, Variation } from './helipopper.types';
declare type Content = string | TemplateRef<any> | Type<any>;
export declare class HelipopperDirective implements OnDestroy {

@@ -9,2 +11,4 @@ private host;

private zone;
private resolver;
private hostInjector;
private config;

@@ -19,2 +23,3 @@ helipopperOptions: Partial<Props>;

helipopperOffset: [number, number] | undefined;
injector: Injector | undefined;
set placement(placement: PopperOptions['placement']);

@@ -24,3 +29,5 @@ set variation(variation: Variation);

set sticky(isSticky: boolean);
set helipopper(content: string | TemplateRef<any>);
set helipopper(content: Content);
helipopperClose: Subject<unknown>;
private _content;
private _destroy;

@@ -33,3 +40,4 @@ private _placement;

private mergedConfig;
constructor(host: ElementRef, appRef: ApplicationRef, zone: NgZone, config: HelipopperConfig);
private innerComponentRef;
constructor(host: ElementRef, appRef: ApplicationRef, zone: NgZone, resolver: ComponentFactoryResolver, hostInjector: Injector, config: HelipopperConfig);
private get _tooltipTarget();

@@ -43,2 +51,3 @@ private get _tooltipHost();

ngOnDestroy(): void;
private destroyView;
private create;

@@ -57,2 +66,6 @@ private createInstance;

private createConfig;
private resolveComponent;
private destroyComponent;
private resolveContent;
}
export {};

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"HelipopperModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"HelipopperDirective"}],"exports":[{"__symbolic":"reference","name":"HelipopperDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"defaults":[{}],"value":{"ngModule":{"__symbolic":"reference","name":"HelipopperModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵb"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"HelipopperDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":18,"character":1},"arguments":[{"selector":"[helipopper]","exportAs":"helipopper"}]}],"members":{"helipopperOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"showOnlyOnTextOverflow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3},"arguments":["helipopperTextOverflow"]}]}],"triggerTarget":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"helipopperHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"helipopperAppendTo":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"helipopperTrigger":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"helipopperClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"helipopperOffset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"placement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3},"arguments":["helipopperPlacement"]}]}],"variation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3},"arguments":["helipopperVariation"]}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":3},"arguments":["helipopperDisabled"]}]}],"sticky":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":3},"arguments":["helipopperSticky"]}]}],"helipopper":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":108,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":105,"character":18},{"__symbolic":"reference","module":"@angular/core","name":"ApplicationRef","line":106,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":107,"character":18},{"__symbolic":"reference","name":"ɵa"}]}],"setProps":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"create":[{"__symbolic":"method"}],"createInstance":[{"__symbolic":"method"}],"resolveTrigger":[{"__symbolic":"method"}],"resolveTemplate":[{"__symbolic":"method"}],"isElementOverflow":[{"__symbolic":"method"}],"getParent":[{"__symbolic":"method"}],"markDisabled":[{"__symbolic":"method"}],"resolveTheme":[{"__symbolic":"method"}],"addCloseButton":[{"__symbolic":"method"}],"removeCloseButton":[{"__symbolic":"method"}],"checkOverflow":[{"__symbolic":"method"}],"destroyTemplate":[{"__symbolic":"method"}],"createConfig":[{"__symbolic":"method"}]}},"ɵa":{"__symbolic":"interface"},"ɵb":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":13,"character":37},"arguments":["HELIPOPPER_CONFIG"]}},"origins":{"HelipopperModule":"./lib/helipopper.module","HelipopperDirective":"./lib/helipopper.directive","ɵa":"./lib/helipopper.types","ɵb":"./lib/helipopper.types"},"importAs":"@ngneat/helipopper"}
{"__symbolic":"module","version":4,"metadata":{"HelipopperModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"HelipopperDirective"}],"exports":[{"__symbolic":"reference","name":"HelipopperDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"defaults":[{}],"value":{"ngModule":{"__symbolic":"reference","name":"HelipopperModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵb"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"HelipopperDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":40,"character":1},"arguments":[{"selector":"[helipopper]","exportAs":"helipopper"}]}],"members":{"helipopperOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":42,"character":3}}]}],"showOnlyOnTextOverflow":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3},"arguments":["helipopperTextOverflow"]}]}],"triggerTarget":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"helipopperHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"helipopperAppendTo":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"helipopperTrigger":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":3}}]}],"helipopperClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"helipopperOffset":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":64,"character":3}}]}],"injector":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3},"arguments":["helipopperInjector"]}]}],"placement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":70,"character":3},"arguments":["helipopperPlacement"]}]}],"variation":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3},"arguments":["helipopperVariation"]}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3},"arguments":["helipopperDisabled"]}]}],"sticky":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3},"arguments":["helipopperSticky"]}]}],"helipopper":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":103,"character":3}}]}],"helipopperClose":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":115,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":133,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":128,"character":18},{"__symbolic":"reference","module":"@angular/core","name":"ApplicationRef","line":129,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":130,"character":18},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":131,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":132,"character":26},{"__symbolic":"reference","name":"ɵa"}]}],"setProps":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"destroyView":[{"__symbolic":"method"}],"create":[{"__symbolic":"method"}],"createInstance":[{"__symbolic":"method"}],"resolveTrigger":[{"__symbolic":"method"}],"resolveTemplate":[{"__symbolic":"method"}],"isElementOverflow":[{"__symbolic":"method"}],"getParent":[{"__symbolic":"method"}],"markDisabled":[{"__symbolic":"method"}],"resolveTheme":[{"__symbolic":"method"}],"addCloseButton":[{"__symbolic":"method"}],"removeCloseButton":[{"__symbolic":"method"}],"checkOverflow":[{"__symbolic":"method"}],"destroyTemplate":[{"__symbolic":"method"}],"createConfig":[{"__symbolic":"method"}],"resolveComponent":[{"__symbolic":"method"}],"destroyComponent":[{"__symbolic":"method"}],"resolveContent":[{"__symbolic":"method"}]}},"ɵa":{"__symbolic":"interface"},"ɵb":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":13,"character":37},"arguments":["HELIPOPPER_CONFIG"]}},"origins":{"HelipopperModule":"./lib/helipopper.module","HelipopperDirective":"./lib/helipopper.directive","ɵa":"./lib/helipopper.types","ɵb":"./lib/helipopper.types"},"importAs":"@ngneat/helipopper"}
{
"name": "@ngneat/helipopper",
"version": "1.0.0",
"version": "1.1.0",
"description": "A Powerful Tooltip and Popover for Angular Applications",
"schematics": "./schematics/collection.json",
"dependencies": {

@@ -6,0 +7,0 @@ "tslib": "^1.10.0",

@@ -26,3 +26,3 @@ <p align="center">

✅ Tooltip & Popover Variations <br>
✅ TemplateRef Support<br>
✅ TemplateRef/Component Support<br>
✅ Lazy Registration<br>

@@ -34,4 +34,5 @@ ✅ Manual Trigger Support<br>

## Installation
```
npm install @ngneat/helipopper
ng add @ngneat/helipopper
```

@@ -73,2 +74,10 @@

#### Component:
```html
<button [helipopper]="component" (helipopperClose)="onClose()">
Click Me
</button>
```
#### Text Overflow:

@@ -78,7 +87,4 @@

<ul style="max-width: 100px;">
<li class="ellipsis"
[helipopper]="text"
helipopperPlacement="right"
[helipopperTextOverflow]="true">
{{ text }}
<li class="ellipsis" [helipopper]="text" helipopperPlacement="right" [helipopperTextOverflow]="true">
{{ text }}
</li>

@@ -91,5 +97,3 @@ </ul>

```html
<span helipopper="Helpful Message"
helipopperTrigger="manual"
#tooltip="helipopper">Click Open to see me</span>
<span helipopper="Helpful Message" helipopperTrigger="manual" #tooltip="helipopper">Click Open to see me</span>

@@ -100,5 +104,6 @@ <button (click)="tooltip.show()">Open</button>

You can see more examples in our [playground](https://github.com/ngneat/helipopper/blob/master/src/app/app.component.html).
You can see more examples in our [playground](https://github.com/ngneat/helipopper/blob/master/src/app/app.component.html), or live [here](https://ngneat.github.io/helipopper/).
## Styling
Add the following style to your main `scss` file:

@@ -123,2 +128,3 @@

cursor: pointer;
z-index: 1;
}

@@ -158,3 +164,3 @@

| @Input | Type | Description | Default |
|------------------------|---------------------------|--------------------------------------------------------------|------------------------------------------------------------------------|
| ---------------------- | ------------------------- | ------------------------------------------------------------ | ---------------------------------------------------------------------- |
| helipopperVariation | `tooltip` \| `popper` | The tooltip type | `tooltip` |

@@ -171,3 +177,3 @@ | helipopper | `string` \| `TemplateRef` | The tooltip content | `none` |

| helipopperSticky | `Boolean` | Whether the tooltip should be sticky (i.e. always displayed) | `false` |
| helipopperTarget | `ElementRef` \| `Element` | The element(s) that the trigger event listeners are added to | `Host` | | Ex: `{ width: '100%', height: '70px' }` |
| helipopperTarget | `ElementRef` \| `Element` | The element(s) that the trigger event listeners are added to | `Host` | | Ex: `{ width: '100%', height: '70px' }` |

@@ -177,2 +183,3 @@ ## Config

- `beforeRender` - Hook that'll be called before rendering the tooltip content: ( applies only for string )
```ts

@@ -182,7 +189,9 @@ import { HelipopperModule } from '@ngneat/helipopper';

@NgModule({
imports: [HelipopperModule.forRoot({
beforeRender(content) {
return sanitize(content);
}
})]
imports: [
HelipopperModule.forRoot({
beforeRender(content) {
return sanitize(content);
}
})
]
})

@@ -204,2 +213,3 @@ export class AppModule {}

<td align="center"><a href="https://www.netbasal.com/"><img src="https://avatars1.githubusercontent.com/u/6745730?v=4" width="100px;" alt=""/><br /><sub><b>Netanel Basal</b></sub></a><br /><a href="https://github.com/@ngneat/helipopper/commits?author=NetanelBasal" title="Code">💻</a> <a href="https://github.com/@ngneat/helipopper/commits?author=NetanelBasal" title="Documentation">📖</a> <a href="#ideas-NetanelBasal" title="Ideas, Planning, & Feedback">🤔</a></td>
<td align="center"><a href="https://github.com/itayod"><img src="https://avatars2.githubusercontent.com/u/6719615?v=4" width="100px;" alt=""/><br /><sub><b>Itay Oded</b></sub></a><br /><a href="https://github.com/@ngneat/helipopper/commits?author=itayod" title="Code">💻</a></td>
</tr>

@@ -206,0 +216,0 @@ </table>

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc