100 lines
4.0 KiB
TypeScript
100 lines
4.0 KiB
TypeScript
import { CommonModule } from '@angular/common';
|
|
import { Component } from '@angular/core';
|
|
import {MessageService } from 'primeng/api';
|
|
import { ButtonModule } from 'primeng/button';
|
|
import { InputTextModule } from 'primeng/inputtext';
|
|
import { ToastModule } from 'primeng/toast';
|
|
import { MessageModule } from 'primeng/message';
|
|
import { FormsModule } from '@angular/forms';
|
|
|
|
@Component({
|
|
standalone: true,
|
|
imports:[CommonModule,ToastModule,ButtonModule,InputTextModule,MessageModule,FormsModule],
|
|
template:`
|
|
<div class="flex flex-col md:flex-row gap-8">
|
|
<div class="md:w-1/2">
|
|
<div class="card">
|
|
<div class="font-semibold text-xl mb-4">Toast</div>
|
|
<div class="flex flex-wrap gap-2">
|
|
<p-button (click)="showSuccessViaToast()" label="Success" severity="success" />
|
|
<p-button (click)="showInfoViaToast()" label="Info" severity="info" />
|
|
<p-button (click)="showWarnViaToast()" label="Warn" severity="warn" />
|
|
<p-button (click)="showErrorViaToast()" label="Error" severity="danger" />
|
|
</div>
|
|
|
|
<div class="font-semibold text-xl mt-4 mb-4">Inline</div>
|
|
<div class="flex flex-wrap mb-4 gap-2">
|
|
<input pInputText [(ngModel)]="username" placeholder="Username" aria-label="username" class="ng-dirty ng-invalid"/>
|
|
<p-message severity="error">Username is required</p-message>
|
|
</div>
|
|
<div class="flex flex-wrap gap-2">
|
|
<input pInputText [(ngModel)]="email" placeholder="Email" aria-label="email" class="ng-dirty ng-invalid" />
|
|
<p-message severity="error" icon="pi pi-times-circle" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="md:w-1/2">
|
|
<div class="card">
|
|
<div class="font-semibold text-xl mb-4">Message</div>
|
|
<div class="flex flex-col gap-4 mb-4">
|
|
<p-message severity="success">Success Message</p-message>
|
|
<p-message severity="info">Info Message</p-message>
|
|
<p-message severity="warn">Warn Message</p-message>
|
|
<p-message severity="error">Error Message</p-message>
|
|
<p-message severity="secondary">Secondary Message</p-message>
|
|
<p-message severity="contrast">Contrast Message</p-message>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
`,
|
|
providers: [MessageService]
|
|
})
|
|
export class MessagesDoc {
|
|
|
|
msgs = [];
|
|
|
|
username: string | undefined
|
|
|
|
email: string | undefined
|
|
|
|
constructor(private service: MessageService) { }
|
|
|
|
showInfoViaToast() {
|
|
this.service.add({ key: 'tst', severity: 'info', summary: 'Info Message', detail: 'PrimeNG rocks' });
|
|
}
|
|
|
|
showWarnViaToast() {
|
|
this.service.add({ key: 'tst', severity: 'warn', summary: 'Warn Message', detail: 'There are unsaved changes' });
|
|
}
|
|
|
|
showErrorViaToast() {
|
|
this.service.add({ key: 'tst', severity: 'error', summary: 'Error Message', detail: 'Validation failed' });
|
|
}
|
|
|
|
showSuccessViaToast() {
|
|
this.service.add({ key: 'tst', severity: 'success', summary: 'Success Message', detail: 'Message sent' });
|
|
}
|
|
|
|
showInfoViaMessages() {
|
|
this.msgs = [];
|
|
this.msgs.push({ severity: 'info', summary: 'Info Message', detail: 'PrimeNG rocks' });
|
|
}
|
|
|
|
showWarnViaMessages() {
|
|
this.msgs = [];
|
|
this.msgs.push({ severity: 'warn', summary: 'Warn Message', detail: 'There are unsaved changes' });
|
|
}
|
|
|
|
showErrorViaMessages() {
|
|
this.msgs = [];
|
|
this.msgs.push({ severity: 'error', summary: 'Error Message', detail: 'Validation failed' });
|
|
}
|
|
|
|
showSuccessViaMessages() {
|
|
this.msgs = [];
|
|
this.msgs.push({ severity: 'success', summary: 'Success Message', detail: 'Message sent' });
|
|
}
|
|
|
|
}
|