Table of Contents generated with DocToc
The AdvGrowlModule is a wrapper around the growl module from PrimeNG. This wrapper was created because PrimeNG is missing some features.
You can find a working demo of the growl module on the following link: https://primeng-advanced-growl.firebaseapp.com/
- PrimeNG module does not offer a central service to create growl messages. The PrimeNG message modul strongly couples the template and the component. You need to include the growl component in each template.
- PrimeNG growl offers us to define a sticky property to remove the messages. When we set the lifetime of the messages to 3 seconds all messages will be removed after the specified time. The problem comes when a message gets created 2 seconds after the first message. This message will not be removed after the specified 3 seconds. This message will be removed 1 seconds after creation. This is the point where the 3 seconds from the first message have passed.
- The AdvGrowlModule provides you the sticky feature with a unique lifetime for each message. The specified lifetime is unique for each message. The growl message will only disappear after the given time has elapsed or you pressed the cancel button on the growl message.
- The PrimeNGAdvancedGrowl module provides you a messageservice. With the help of this service you have a central way to create growl messages.
PrimeNGAdvancedGrowl is an node_module and therefore it is provided over npm. To install it node and npm are required.
npm install --save primeng-advanced-growl
To have all the primeNG styles available you need to import the following stylesheets in your application:
"../node_modules/font-awesome/scss/font-awesome.scss",
"../node_modules/primeng/resources/primeng.css",
"../node_modules/primeng/resources/themes/omega/theme.scss"
To use the AdvGrowlService and the AdvGrowlComponent you need to import the AdvGrowlModul in your appliction.
import {AdvGrowlModule} from 'primeng-advanced-growl';
@NgModule({
declarations: [AppComponent],
imports: [AdvGrowlModule]
})
...
The AdvGrowlModule exports a component named AdvGrowlComponent. You need to include this component once in your app.component.html. With the help of this component the advanced PrimeNG growl messages can be displayed.
<app-navbar></app-navbar>
<adv-growl></adv-growl>
<div class="container">
<router-outlet></router-outlet>
</div>
The advanced growl messages component has the following in- and outputs.
Input | Description |
---|---|
style | Inline styles that should be applied to the growl component of PrimeNG |
styleClass | Style class for the growl component of PrimeNG |
life: number (default = 0) | A number that represents the lifetime of each growl message. If set to 3000 each message will be disappear after 3 seconds. If no life param is passed to the components the growl messages are sticky and do not disappear until you call clearMessages or click on the cancel x on a message |
freezeMessagesOnHover: boolean (default: false) | This flag is only useful if you also pass a life time. When you pass this property to the component messages are freezed when you hover over them. Let's say you have for example 3 messages all with a lifetime of 3 seconds. When you hover after 2 seconds over the second message all messages on the screen are freezed and do not disappear. After you leave the messages each message will disappear after the specified lifetime. With the pauseOnlyHoveredMessage you can control if you want all messages or only the hoverd message to disappear |
pauseOnlyHoveredMessage (default: false) | This flag indicates if only the hovered message should be paused. If set to true only the hoverd message will be paused. If set to false all messages will be paused on hover. Notice that this flag is only useful if you set a lifetime that is bigger than 0 and you set the freezeMessagesOnHover flag to true |
messageSpots (default: 0 (unlimited)) | This property gives you the possibility to limit the number of messages displayed on screen. This feature is very useful in combination with the life property. With this combination all messages that can currently not be displayed due to missing message spots will be cached. Those cached messages will appear as soon as a spot is available. Notice that a dynamic change of this property during runtime removes all currently displayed messages from screen |
Event | Description |
---|---|
onClose: EventEmitter | Emits an event with the closed message. This message is from type AdvPrimeMessage. |
onClick: EventEmitter | Emits an event with the message from the clicked element. This message is from type AdvPrimeMessage. |
onMessagesChanges: EventEmitter<Array> | Each time a message is created or removed it emits an array of all messages shown on the screen. If you subscribe to this emitter you always know which messages are on the screen. |
export interface AdvPrimeMessage {
id: string;
severity: string;
summary: string;
detail: string;
additionalProperties?: any;
}
The AdvGrowlService allows you to create and delete messages. The AdvGrowlService can be accessed over dependency injection inside your component.
import {AdvGrowlService} from 'primeng-advanced-growl';
@Component({
selector: ...,
templateUrl: ...
})
export class SampleComponent{
constructor(private advGrowlService: AdvGrowlService){
}
}
The AdvGrowlService provides the following methods to create messages. Each method expects the message content and a message title.
- createSuccessMessage(messageContent: string, summary: string, additionalProperties?: any): void
- createInfoMessage(messageContent: string, summary: string, additionalProperties?: any): void
- createWarningMessage(messageContent: string, summary: string, additionalProperties?: any): void
- createErrorMessage(messageContent: string, summary: string, additionalProperties?: any): void
To clear all messages you can call the clearMessages() method from the AdvGrowlService.
Inside the test folder you can find different examples how to use the library. Below we listed some code samples for common use cases.
If we want to avoid the creation of multiple messages with the same summary or type we could do the following inside our component.
import {AdvPrimeMessage} from '../../lib/messages/adv-growl.model';
@Component({
selector: 'sample-app',
template: `<adv-growl [life]="2500"
(onMessagesChanges)="onMessages($event)">
</adv-growl>
<button pButton type="button"
(click)="createNonDuplicatedSuccessMessage()"
class="ui-button-success"
label="Create success message if none on screen">
</button>
`
})
export class AppComponent {
messages = [];
constructor(private advMessagesService: AdvGrowlService) {
}
public createSuccessMessage(): void {
this.advMessagesService.createSuccessMessage('Awesome success message content', 'Awesome success', {
clickMessage: 'Awesome click'
});
}
public onMessages(messages) {
this.messages = messages;
}
public createNonDuplicatedSuccessMessage(): void {
const index = this.messages.findIndex(message => message.summary === 'Awesome success');
if (index < 0) {
this.createSuccessMessage()
}
}
}
If you want to pass some additional informations to your message you can do this by passing those as last optional parameter to the success, warning, info or error method. When you click on your message the event will then contain your additionalProperties.
import {AdvPrimeMessage} from '../../lib/messages/adv-growl.model';
@Component({
selector: 'sample-app',
template: `<adv-growl [life]="2500"
(onMessagesChanges)="onMessages($event)"
(onClick)="logMessage($event)">
</adv-growl>
<button pButton type="button"
(click)="createSuccessMessageWithAdditionalInfos()"
class="ui-button-success"
label="Create success message with additional properties">
</button>
`
})
export class AppComponent {
messages = [];
constructor(private advMessagesService: AdvGrowlService) {
}
public createSuccessMessageWithAdditionalInfos(): void {
this.advMessagesService.createSuccessMessage('Awesome success message content', 'Awesome success', {
clickMessage: 'Awesome click'
});
}
public logMessage(message: AdvPrimeMessage) {
if (message.additionalProperties) {
console.log(message.additionalProperties.clickMessage)
} else {
console.log('You clicked on message', message)
}
}
}