Angular 8+ wrapper for Tippy.js
Install from npm:
npm i ngx-tippy-wrapper --save
Import NgxTippyModule:
import { NgxTippyModule } from 'ngx-tippy-wrapper';
Then in your base module:
@NgModule({
imports: [
...,
NgxTippyModule
],
...
})
Import base style file to your main style file:
@import 'tippy.js/dist/tippy.css'
or angular.json:
"architect": {
"build": {
...,
"options": {
...,
"styles": ["./node_modules/tippy.js/dist/tippy.css", ...]
}
Apply directive for element and pass content through attribute:
<span ngxTippy data-tippy-content="Tooltip">
Tippy
</span>
You can apply props with input binding
In template:
<span
ngxTippy
data-tippy-content="Tooltip with props"
[tippyProps]="{
arrow: false,
placement: 'bottom'
}"
>
Tippy
</span>
Or pass props from component:
<span ngxTippy data-tippy-content="Tooltip with props" [tippyProps]="tippyProps">
Tippy
</span>
...
import { NgxTippyProps } from 'ngx-tippy-wrapper';
@Component({...})
export class DemoComponent implements OnInit {
tippyProps: NgxTippyProps = {
trigger: 'click',
allowHTML: true
};
...
}
Prop name | Prop type | Example |
---|---|---|
tippyProps | NgxTippyProps | [tippyProps]="{ arrow: false, placement: 'bottom' }" |
tippyName | string | [tippyName]="'awesomeName'" |
classNames | Array | [classNames]="['customClass', 'nextClass']" |
tippyProps - list of all props
tippyName - name for tippy instance, required for accessing and control specific instance
classNames - add custom classes to the tippy element, same as theme
prop, but without adding -theme
as a suffix
- String
<span ngxTippy [tippyProps]="tippyPropsWithString">
Tippy with string content
</span>
...
import { NgxTippyProps } from 'ngx-tippy-wrapper';
@Component({...})
export class DemoComponent implements OnInit {
tippyPropsWithString: NgxTippyProps = {
content: '<strong>Bolded content</strong>'
};
...
}
- Element or Element.innerHTML
<div>
<span ngxTippy [tippyProps]="tippyContent">
Tippy with HTML content
</span>
<!-- If passing element itself -->
<div #tippyTemplate>
<span>Some content</span>
<h2>Caption</h2>
<button>Action</button>
...
</div>
<!-- If passing element innerHTML -->
<div #tippyTemplate style="display: none;">
<span>Some content</span>
<h2>Caption</h2>
<button>Action</button>
...
</div>
</div>
...
import { NgxTippyProps } from 'ngx-tippy-wrapper';
@Component({...})
export class DemoComponent implements OnInit {
@ViewChild('tippyTemplate', { static: true }) tippyTemplate: ElementRef;
tippyContent: NgxTippyProps = {...};
ngOnInit() {
// Pass element itself
this.tippyContent.content = this.tippyTemplate.nativeElement;
// Pass element innerHTML
this.tippyContent.content = this.tippyTemplate.nativeElement.innerHTML;
}
...
}
For accessing and control specific tippy instance you need pass tippyName
prop
Then import NgxTippyService:
...
import { NgxTippyService } from 'ngx-tippy-wrapper';
@Component({...})
export class DemoComponent implements OnInit {
constructor(private tippyService: NgxTippyService) {}
...
}
Through service you can use all methods described here and some additional:
Method name | Method parameter/parameters | Method short description |
---|---|---|
Working with instances | ||
getTippyInstance() | name: string | Get specific instance |
getAllTippyInstances() | - | Get all tippy instances |
Tippy state management | ||
showTippy() | name: string, transitionDuration?: number | Programmatically show the tippy |
hideTippy() | name: string, transitionDuration?: number | Programmatically hide the tippy |
disableTippy() | name: string | Temporarily prevent a tippy from showing or hiding |
enableTippy() | name: string | Re-enable a tippy |
setTippyProps() | name: string, tippyProps: NgxTippyProps | Update any tippy props |
setTippyContent() | name: string, tippyContent: NgxTippyContent | Update the content for tippy |
destroyTippyInstance() | name: string | Destroy and clean up the tippy instance |
Static methods | ||
setDefaultProps() | tippyProps: NgxTippyProps | Set the default props for each new tippy instance |
showAllTippies() | transitionDuration? :number | Show all tippies |
hideAllTippies() | hideImmediately?: boolean | Hide all visible tippies |
hideAllTippiesExcept() | names: Array, transitionDuration?: number | Hide all tippies except some, passed as array |
import { NgxTippyService } from 'ngx-tippy-wrapper';
@Component({...})
export class DemoComponent implements OnInit {
constructor(private tippyService: NgxTippyService) {}
ngOnInit() {
this.tippyService.tippyInstancesChanges.subscribe(...);
}
...
}
For using multiple tippys on a single element - nest elements with applied directive:
<div
ngxTippy
data-tippy-content="First tooltip"
[tippyProps]="{
placement: 'top'
}"
>
<div
ngxTippy
data-tippy-content="Second tooltip"
[tippyProps]="{
placement: 'bottom'
}"
>
<div
ngxTippy
data-tippy-content="Third tooltip"
[tippyProps]="{
placement: 'right'
}"
>
Tippy root element
</div>
</div>
</div>
For singleton using - put in tippys inside ngx-tippy-singleton component:
<ngx-tippy-singleton [tippyProps]="{...}">
<button ngxTippy data-tippy-content="First tooltip">
Button
</button>
<button ngxTippy data-tippy-content="Second tooltip">
Button
</button>
</ngx-tippy-singleton>