Create and show tooltip on multiple targets in Angular Tooltip component
19 Sep 20226 minutes to read
Tooltip can be created and shown on multiple targets within a container by defining the specific target elements to the target property. So, the tooltip is initialized only on matched targets within a container.
In this case, the tooltip content is assigned from the title attribute of the target element.
import { Component, ViewChild } from '@angular/core';
@Component({
selector: 'my-app',
template: `
<div id="tool">
<form id="details" role="form">
<div id="user">
<div class="info">User Name:</div>
<ejs-tooltip #tooltip position='RightCenter' title="Please enter your name">
<div class="inputs"><input type="text" id="uname" class="e-info e-input" name="firstname" title="Please enter your name"></div>
</ejs-tooltip>
</div>
<br/>
<div>
<div class="info">Email Address:</div>
<ejs-tooltip position='RightCenter' title="Enter a valid email address">
<div class="inputs"><input type="text" id="mail" class="e-info e-input" name="email" title="Enter a valid email address"></div>
</ejs-tooltip>
</div>
<br/>
<div>
<div class="info">Password:</div>
<ejs-tooltip #tooltippwd position='RightCenter' title="Be at least 8 characters length">
<div class="inputs"><input id="pwd" type="password" class="e-info e-input" name="password" title="Be at least 8 characters length"></div>
</ejs-tooltip>
</div>
<br/>
<div>
<div class="info">Confirm Password:</div>
<ejs-tooltip position='RightCenter' title="Re-enter your password">
<div class="inputs"><input id="cpwd" type="password" class="e-info e-input" name="Cpwd" title="Re-enter your password"></div>
</ejs-tooltip>
</div>
<br/>
<div class="btn">
<input id="sample" ejs-button type="button" value="Submit" (click)="submitdata($event)" />
<input id="clear" ejs-button type="reset" value="Reset" (click)="cleardata($event)" />
</div>
</form>
</div>
`,
})
export class AppComponent {
@ViewChild('tooltip')
tooltip: TooltipComponent
@ViewChild('tooltippwd')
tooltipcontrol: TooltipComponent
submitdata(event){
let name = document.getElementById('uname').value;
let pwd = document.getElementById('pwd').value;
let cpwd = document.getElementById('cpwd').value;
if(name.length > 0 & name.length < 4){
document.getElementById('uname').title = 'Required Minimum 4 Characters';
document.getElementById('uname').style.backgroundColor = 'red';
let target = document.getElementById('uname');
this.tooltip.open(target);
} else {
document.getElementById('uname').style.backgroundColor = 'white';
}
if(pwd !== '' && pwd.length < 8){
document.getElementById('pwd').title = 'Required Minimum 8 Characters';
document.getElementById('pwd').style.backgroundColor = 'red';
let pwdtarget = document.getElementById('pwd');
this.tooltipcontrol.open(pwdtarget);
} else {
document.getElementById('pwd').style.backgroundColor = 'white';
}
if(name.length >= 4 && pwd !== '' && pwd.length >= 8 && pwd == cpwd ){
alert('Form Submitted');
} else {
alert('Details are not Valid');
}
}
cleardata(event){
document.getElementById('uname').style.backgroundColor = 'white';
document.getElementById('pwd').style.backgroundColor = 'white';
let target = document.getElementById('uname');
this.tooltip.close(target);
document.getElementById('uname').title = 'Please enter your name';
let pwdtarget = document.getElementById('pwd');
this.tooltipcontrol.close(pwdtarget);
}
}
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { TooltipModule } from '@syncfusion/ej2-angular-popups';
import { ButtonModule } from '@syncfusion/ej2-angular-buttons';
import { AppComponent } from './app.component';
/**
* Module
*/
@NgModule({
imports: [
BrowserModule,
TooltipModule, ButtonModule
],
declarations: [AppComponent],
bootstrap: [AppComponent]
})
export class AppModule { }
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';
enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);