mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-23 21:31:29 +01:00
Add toastr component (#568)
This commit is contained in:
parent
5db94cc9d0
commit
a6b95b15e3
85
angular/src/components/toastr.component.ts
Normal file
85
angular/src/components/toastr.component.ts
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
import {
|
||||||
|
animate,
|
||||||
|
state,
|
||||||
|
style,
|
||||||
|
transition,
|
||||||
|
trigger
|
||||||
|
} from '@angular/animations';
|
||||||
|
import { CommonModule } from '@angular/common';
|
||||||
|
import { Component, ModuleWithProviders, NgModule } from '@angular/core';
|
||||||
|
import { DefaultNoComponentGlobalConfig, GlobalConfig, Toast as BaseToast, ToastPackage, ToastrService, TOAST_CONFIG } from 'ngx-toastr';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: '[toast-component2]',
|
||||||
|
template: `
|
||||||
|
<button *ngIf="options.closeButton" (click)="remove()" type="button" class="toast-close-button" aria-label="Close">
|
||||||
|
<span aria-hidden="true">×</span>
|
||||||
|
</button>
|
||||||
|
<div class="icon">
|
||||||
|
<i></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div *ngIf="title" [class]="options.titleClass" [attr.aria-label]="title">
|
||||||
|
{{ title }} <ng-container *ngIf="duplicatesCount">[{{ duplicatesCount + 1 }}]</ng-container>
|
||||||
|
</div>
|
||||||
|
<div *ngIf="message && options.enableHtml" role="alertdialog" aria-live="polite"
|
||||||
|
[class]="options.messageClass" [innerHTML]="message">
|
||||||
|
</div>
|
||||||
|
<div *ngIf="message && !options.enableHtml" role="alertdialog" aria-live="polite"
|
||||||
|
[class]="options.messageClass" [attr.aria-label]="message">
|
||||||
|
{{ message }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div *ngIf="options.progressBar">
|
||||||
|
<div class="toast-progress" [style.width]="width + '%'"></div>
|
||||||
|
</div>
|
||||||
|
`,
|
||||||
|
animations: [
|
||||||
|
trigger('flyInOut', [
|
||||||
|
state('inactive', style({ opacity: 0 })),
|
||||||
|
state('active', style({ opacity: 1 })),
|
||||||
|
state('removed', style({ opacity: 0 })),
|
||||||
|
transition(
|
||||||
|
'inactive => active',
|
||||||
|
animate('{{ easeTime }}ms {{ easing }}')
|
||||||
|
),
|
||||||
|
transition(
|
||||||
|
'active => removed',
|
||||||
|
animate('{{ easeTime }}ms {{ easing }}')
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
],
|
||||||
|
preserveWhitespaces: false,
|
||||||
|
})
|
||||||
|
export class BitwardenToast extends BaseToast {
|
||||||
|
constructor(protected toastrService: ToastrService, public toastPackage: ToastPackage) {
|
||||||
|
super(toastrService, toastPackage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const BitwardenToastGlobalConfig: GlobalConfig = {
|
||||||
|
...DefaultNoComponentGlobalConfig,
|
||||||
|
toastComponent: BitwardenToast,
|
||||||
|
};
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [CommonModule],
|
||||||
|
declarations: [BitwardenToast],
|
||||||
|
exports: [BitwardenToast],
|
||||||
|
})
|
||||||
|
export class BitwardenToastModule {
|
||||||
|
static forRoot(config: Partial<GlobalConfig> = {}): ModuleWithProviders<BitwardenToastModule> {
|
||||||
|
return {
|
||||||
|
ngModule: BitwardenToastModule,
|
||||||
|
providers: [
|
||||||
|
{
|
||||||
|
provide: TOAST_CONFIG,
|
||||||
|
useValue: {
|
||||||
|
default: BitwardenToastGlobalConfig,
|
||||||
|
config: config,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
@ -3,7 +3,6 @@ import {
|
|||||||
LOCALE_ID,
|
LOCALE_ID,
|
||||||
NgModule,
|
NgModule,
|
||||||
} from '@angular/core';
|
} from '@angular/core';
|
||||||
import { ToasterModule } from 'angular2-toaster';
|
|
||||||
|
|
||||||
import { ApiService } from 'jslib-common/services/api.service';
|
import { ApiService } from 'jslib-common/services/api.service';
|
||||||
import { AppIdService } from 'jslib-common/services/appId.service';
|
import { AppIdService } from 'jslib-common/services/appId.service';
|
||||||
@ -80,9 +79,6 @@ import { UnauthGuardService } from './unauth-guard.service';
|
|||||||
import { ValidationService } from './validation.service';
|
import { ValidationService } from './validation.service';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
|
||||||
ToasterModule,
|
|
||||||
],
|
|
||||||
declarations: [],
|
declarations: [],
|
||||||
providers: [
|
providers: [
|
||||||
{ provide: 'WINDOW', useValue: window },
|
{ provide: 'WINDOW', useValue: window },
|
||||||
|
@ -1,6 +1,10 @@
|
|||||||
import { DeviceType } from '../enums/deviceType';
|
import { DeviceType } from '../enums/deviceType';
|
||||||
import { ThemeType } from '../enums/themeType';
|
import { ThemeType } from '../enums/themeType';
|
||||||
|
|
||||||
|
interface ToastOptions {
|
||||||
|
timeout?: number;
|
||||||
|
}
|
||||||
|
|
||||||
export abstract class PlatformUtilsService {
|
export abstract class PlatformUtilsService {
|
||||||
identityClientId: string;
|
identityClientId: string;
|
||||||
getDevice: () => DeviceType;
|
getDevice: () => DeviceType;
|
||||||
@ -20,7 +24,7 @@ export abstract class PlatformUtilsService {
|
|||||||
supportsWebAuthn: (win: Window) => boolean;
|
supportsWebAuthn: (win: Window) => boolean;
|
||||||
supportsDuo: () => boolean;
|
supportsDuo: () => boolean;
|
||||||
showToast: (type: 'error' | 'success' | 'warning' | 'info', title: string, text: string | string[],
|
showToast: (type: 'error' | 'success' | 'warning' | 'info', title: string, text: string | string[],
|
||||||
options?: any) => void;
|
options?: ToastOptions) => void;
|
||||||
showDialog: (body: string, title?: string, confirmText?: string, cancelText?: string,
|
showDialog: (body: string, title?: string, confirmText?: string, cancelText?: string,
|
||||||
type?: string, bodyIsHtml?: boolean) => Promise<boolean>;
|
type?: string, bodyIsHtml?: boolean) => Promise<boolean>;
|
||||||
isDev: () => boolean;
|
isDev: () => boolean;
|
||||||
|
Loading…
Reference in New Issue
Block a user