mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ADF-3118] translation support for notification service (snackbars) (#3427)
* translation support for snackbar * unit tests
This commit is contained in:
committed by
Eugenio Romano
parent
6909c459a8
commit
2f51b9f2b8
@@ -23,6 +23,8 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||
import { MatSnackBar, MatSnackBarModule } from '@angular/material';
|
||||
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
|
||||
import { NotificationService } from './notification.service';
|
||||
import { TranslationMock } from '../mock/translation.service.mock';
|
||||
import { TranslationService } from './translation.service';
|
||||
|
||||
@Component({
|
||||
template: '',
|
||||
@@ -47,6 +49,7 @@ class ProvidesNotificationServiceComponent {
|
||||
|
||||
describe('NotificationService', () => {
|
||||
let fixture: ComponentFixture<ProvidesNotificationServiceComponent>;
|
||||
let translationService: TranslationService;
|
||||
|
||||
beforeEach(async(() => {
|
||||
TestBed.configureTestingModule({
|
||||
@@ -60,11 +63,12 @@ describe('NotificationService', () => {
|
||||
NotificationService,
|
||||
MatSnackBar,
|
||||
OVERLAY_PROVIDERS,
|
||||
LiveAnnouncer
|
||||
LiveAnnouncer,
|
||||
{ provide: TranslationService, useClass: TranslationMock }
|
||||
]
|
||||
});
|
||||
|
||||
TestBed.compileComponents();
|
||||
translationService = TestBed.get(TranslationService);
|
||||
}));
|
||||
|
||||
beforeEach(() => {
|
||||
@@ -72,6 +76,18 @@ describe('NotificationService', () => {
|
||||
fixture.detectChanges();
|
||||
});
|
||||
|
||||
it('should translate messages', (done) => {
|
||||
spyOn(translationService, 'instant').and.callThrough();
|
||||
|
||||
let promise = fixture.componentInstance.sendMessage();
|
||||
promise.afterDismissed().subscribe(() => {
|
||||
expect(translationService.instant).toHaveBeenCalled();
|
||||
done();
|
||||
});
|
||||
|
||||
fixture.detectChanges();
|
||||
});
|
||||
|
||||
it('should open a message notification bar', (done) => {
|
||||
let promise = fixture.componentInstance.sendMessage();
|
||||
promise.afterDismissed().subscribe(() => {
|
||||
|
@@ -17,36 +17,42 @@
|
||||
|
||||
import { Injectable } from '@angular/core';
|
||||
import { MatSnackBar, MatSnackBarRef } from '@angular/material';
|
||||
import { TranslationService } from './translation.service';
|
||||
|
||||
@Injectable()
|
||||
export class NotificationService {
|
||||
|
||||
static DEFAULT_DURATION_MESSAGE: number = 5000;
|
||||
|
||||
constructor(public snackbar: MatSnackBar) {
|
||||
constructor(private snackBar: MatSnackBar,
|
||||
private translationService: TranslationService) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Opens a snackbar notification to show a message.
|
||||
* @param message The message to show
|
||||
* Opens a SnackBar notification to show a message.
|
||||
* @param message The message (or resource key) to show.
|
||||
* @param millisecondsDuration Time before notification disappears after being shown
|
||||
* @returns Information/control object for the snackbar
|
||||
* @returns Information/control object for the SnackBar
|
||||
*/
|
||||
public openSnackMessage(message: string, millisecondsDuration?: number): MatSnackBarRef<any> {
|
||||
return this.snackbar.open(message, null, {
|
||||
openSnackMessage(message: string, millisecondsDuration?: number): MatSnackBarRef<any> {
|
||||
const translatedMessage = this.translationService.instant(message);
|
||||
|
||||
return this.snackBar.open(translatedMessage, null, {
|
||||
duration: millisecondsDuration || NotificationService.DEFAULT_DURATION_MESSAGE
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Opens a snackbar notification with a message and a response button.
|
||||
* @param message The message to show
|
||||
* Opens a SnackBar notification with a message and a response button.
|
||||
* @param message The message (or resource key) to show.
|
||||
* @param action Caption for the response button
|
||||
* @param millisecondsDuration Time before the notification disappears (unless the button is clicked)
|
||||
* @returns Information/control object for the snackbar
|
||||
* @returns Information/control object for the SnackBar
|
||||
*/
|
||||
public openSnackMessageAction(message: string, action: string, millisecondsDuration?: number): MatSnackBarRef<any> {
|
||||
return this.snackbar.open(message, action, {
|
||||
openSnackMessageAction(message: string, action: string, millisecondsDuration?: number): MatSnackBarRef<any> {
|
||||
const translatedMessage = this.translationService.instant(message);
|
||||
|
||||
return this.snackBar.open(translatedMessage, action, {
|
||||
duration: millisecondsDuration || NotificationService.DEFAULT_DURATION_MESSAGE
|
||||
});
|
||||
}
|
||||
|
Reference in New Issue
Block a user