Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/thiagopg84/ngx-french-toast

With ngx-french-toast, you have a lightweight and customizable toast library for your Angular 14+ applications. Show informative toast messages to enhance user experience and provide important feedback or collect data with dynamically imported components.
https://github.com/thiagopg84/ngx-french-toast

angular angular14 made-from-scratch ngx-toast ngx-toastr toast toast-notifications toastr

Last synced: 3 months ago
JSON representation

With ngx-french-toast, you have a lightweight and customizable toast library for your Angular 14+ applications. Show informative toast messages to enhance user experience and provide important feedback or collect data with dynamically imported components.

Awesome Lists containing this project

README

        

# ngx-french-toast


ngx-french-toast logo

### Check the Changelog for updates! 📌

### You can test all features in ngx-french-toast playground app.
---
# Features

- Fully built in Angular, without any external dependencies. Oui, trÚs indépendant!
- Customizable toast appearance, including duration, colors, and positioning. Like a beret, you can style it to perfection!
- Unique feature: Dynamically embed components within the toast for maximum flexibility and créativité. C'est magnifique!
- Total control over toast visibility: `infinite` and `pinned` properties allow users to arrange toasts based on their importance and ensure critical messages stay in focus.


## Compatibility Matrix



Angular
ngx-french-toast




14^ - 15^
1.3.x


16^
1.4.x


17^
2.x


18^
18.x




# Installation

To install ngx-french-toast, simply follow these Ă©tapes:

### 1. Run the following command to install the package via npm:

```
npm install ngx-french-toast
```

### 2. Import the `FrenchToastModule` in your Angular module:

#### Standard apps
```typescript
import { FrenchToastModule, ToastPosition, ToastConfig } from 'ngx-french-toast';

// optional configuration object:
const config: ToastConfig = {
colors: {
danger: '#a20000', // Background color for the danger toast
dangerText: '#ffffff', // Text color for the danger toast
info: '#2d96f8', // Background color for the info toast
infoText: '#ffffff', // Text color for the info toast
success: '#2df877', // Background color for the success toast
successText: '#ffffff', // Text color for the success toast
warning: '#f8bb2d', // Background color for the warning toast
warningText: '#ffffff', // Text color for the warning toast
timebar: 'linear-gradient(45deg, #2b6bbf, #10425b)', // Or a single color -- background color for the time bar
autoGradient: false, // Controls whether the background will be an automatically generated gradient or not based on single input colors
},
defaultDuration: 100000,
position: ToastPosition.TOP_RIGHT, // As elegant as the Eiffel Tower!
limit: 3,
font: {
contentFontSize: '13px', // This will accept any CSS unit (rem, em, px etc.)
titleFontSize: '15px', // Same here ;)
family: 'Athiti' // TrÚs élégant!
}
};

@NgModule({
imports: [
// ...
FrenchToastModule.forRoot(config)
],
// ...
})
export class AppModule { }
```

#### Standalone apps
```typescript
import { provideFrenchToast, ToastPosition } from 'ngx-french-toast';

bootstrapApplication(AppComponent, {
providers: [
provideFrenchToast({
defaultDuration: 10000,
position: ToastPosition.BOTTOM_RIGHT,
limit: 2,
font: {
contentFontSize: '13px',
titleFontSize: '15px',
family: 'Athiti'
}
})
]
})
.catch((err) => console.error(err));
```

### 3. Et voilĂ ! You're ready to start using ngx-french-toast in your Angular application.


# Usage

Here's a simple example demonstrating how to use ngx-french-toast:

```typescript
import { Component } from '@angular/core';
import { ToastService } from 'ngx-french-toast';

@Component({
selector: 'app-example',
template: `
Show Toast
`
})
export class ExampleComponent {
constructor(private toastService: ToastService) {}

showToast(): void {
this.toastService.success({
title: 'Knock, knock!',
content: 'Who\'s there? Eiffel. Eiffel who? Eiffel in love with you!' // Mon Dieu, l'amour!
});
}
}
```

# Toast Types

ngx-french-toast provides 4 toast types. Each of them has its own method:

- `success()`: Shows a success toast. C'est magnifique!
- `danger()`: Shows a danger toast. Oh lĂ  lĂ !
- `info()`: Shows an info toast. VoilĂ !
- `warning()`: Shows a warning toast. Attention!

You can use these methods of your `ToastService` instance to show toasts in your application. For example:

```typescript
this.toastService.success({ title: 'Success', content: 'Your task has been completed with finesse!' });
this.toastService.danger({ title: 'Danger', content: 'Something went wrong! Oh lĂ  lĂ !' });
this.toastService.info({ title: 'Info', content: 'Here are some important details for you.' });
this.toastService.warning({ title: 'Warning', content: 'Be cautious! Danger may be lurking nearby.' });
```

# Toast Input Object

Each toast has the following customizable properties:

```typescript
this.toastService.success({
title: 'Toast Title',
content: 'Lorem ipsum dolor sit amet.', // this will be ignored if you're embedding a component ;)
_id: `success-toast--${this.id}`, // if you leave it blank, the ID will be automatically generated
component: SomeComponent,
duration: 10000,
icon: '../assets/svg/sprite.svg#icon-success', // or a URL of a .png, for example
infinite: true, // if infinite is true, the duration will be ignored
pinned: true, // when set to true, this toast will remain fixed in its position even if new toasts are added, unless the next toast is also pinned
context: { // this will be available within SomeComponent!
name: 'Jean Pierre',
email: '[email protected]'
}
});
```

# Embedding Components Dynamically

To embed components dynamically just call any method from your instance of `ToastService` and pass an object with the `component` and `title` properties. For example:

```typescript
this.toastService.success({
component: ExampleComponent,
title: 'Oui, mon ami!',
context: {
name: 'Jean Pierre',
email: '[email protected]'
} // the content and type of context is up to you!
});
```


## Grabbing the `context` object from the embedded component
To have access to the `context` object from within your dynamically embedded component, you just have to create a `context` variable in your embedded component to receive the content you declared when calling the `ToastService`:
```typescript
context: { name: string, email: string }; // the type is up to you :)
```

## Programmatically closing the parent toast from the embedded component
To close the parent toast from the embedded component, users should follow these steps:

### ⚠ Attention! This is a breaking change.
~~1. In the embedded component (e.g., `ExampleComponent`), define an `EventEmitter` named `destroyToast` as an `@Output()` property:~~

```diff
- @Output() destroyToast: EventEmitter = new EventEmitter(false);
```
1. In the embedded component (e.g., `ExampleComponent`), inject an instance of `ToastService` and the parent component (`ToastComponent`) as dependencies:
```typescript
import { ToastComponent, ToastService } from 'ngx-french-toast';

constructor(private toastService: ToastService, private toast: ToastComponent) {}
```

2. Call the `destroyToast` method from `ToastService`, passing the parent component as a parameter:

```typescript
closeToast(): void {
this.toastService.destroyToast(this.toast);
}
```


To summarize, here's an example for the whole section:

```typescript
import { Output, EventEmitter } from '@angular/core';

@Component({
selector: 'app-example',
template: `

My email: {{ context.email }}


Five stars!;
`
})
export class ExampleComponent {
context: { name: string, email: string };

constructor(private toastService: ToastService, private toast: ToastComponent) {}

rate(rate: number): void {
this.someApi.rate(rate).subscribe({
next: () => {
this.toastService.destroyToast(this.toast);
}
});
}
}
```

Passing the parent component to the `destroyToast` method allows `ToastService` to find the `ToastComponent` within visible toasts and close it. TrĂšs beau!


# Using Icons

You can customize the toast appearance by adding icons. Simply pass an `icon` property inside the config object when calling the toast service. The `icon` property accepts a string that can link directly to images or SVG sprite files. Here are a few examples:

Using an SVG from a sprite:

```typescript
this.toastService.success({ title: 'Success', icon: '../assets/svg/sprite.svg#icon-success' }); // Comme un baguette of success!
```

Using an image:

```typescript
this.toastService.success({ title: 'Success', icon: '../assets/imgs/success.png' }); // C'est magnifique!
```

Note: Make sure to provide the correct path to the image or SVG file. Parfait!


# Clearing Toasts Programmatically

Sometimes, you might need to remove all toasts from the screen at once. To do this programmatically, simply call the `clearAllToasts()` method from your `ToastService` instance:

```typescript
this.toastService.clearAllToasts();
```

This can be particularly useful when, for instance, you want to reset the toast notifications or clear the screen after a certain action has been taken.


# Contributions

Contributions to ngx-french-toast are welcome! If you find a bug, have a feature request, or want to contribute code improvements, please submit an issue, or fork it, or just let me know and we'll figure it out 😊


# Contact

If you have any questions, suggestions, or feedback, you can reach out to me via [email protected] or find me on LinkedIn. Don't hesitate to say "Bonjour!" and share your thoughts. Let's connect and make the ngx-french-toast community even stronger! đŸ’ȘđŸ„

Made with ❀ (and lots of croissants) for Angular Angular Logo.

Merci beaucoup for using ngx-french-toast! I hope it brings a touch of crĂ©ativitĂ© to your Angular applications. Bon appĂ©tit! 🍞