Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/4gray/ngx-whats-new
A simple library for creating multi-modal windows
https://github.com/4gray/ngx-whats-new
Last synced: 2 months ago
JSON representation
A simple library for creating multi-modal windows
- Host: GitHub
- URL: https://github.com/4gray/ngx-whats-new
- Owner: 4gray
- Created: 2021-04-05T14:48:41.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T13:10:07.000Z (3 months ago)
- Last Synced: 2024-10-28T16:49:17.425Z (3 months ago)
- Language: TypeScript
- Size: 2.1 MB
- Stars: 0
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- fucking-awesome-angular - ngx-whats-new - A simple library for creating multi-modal windows. (Table of contents / Third Party Components)
- awesome-angular - ngx-whats-new - A simple library for creating multi-modal windows. (Table of contents / Third Party Components)
- trackawesomelist - ngx-whats-new (⭐3) - A simple library for creating multi-modal windows. (Recently Updated / [Nov 29, 2024](/content/2024/11/29/README.md))
README
# NgxWhatsNew
Ngx-whats-new is an angular module with a multi-modal component that is typically used to present new features of your application.
![ngx-whats-new screencast](screencast.gif)
```
npm i ngx-whats-new
```## Usage example:
[Codesandbox example](https://codesandbox.io/s/ngx-whats-new-demo-nxc8b?file=/src/main.ts)
Import the component:
```typescript
import { NgModule } from "@angular/core";
import { NgxWhatsNewComponent } from "ngx-whats-new";
import { AppComponent } from "./app.component";@NgModule({
declarations: [AppComponent],
imports: [NgxWhatsNewComponent],
bootstrap: [AppComponent],
})
export class AppModule {}
```Use `` in your component:
app.component.html
```html
Open Dialog```
app.component.ts
```typescript
@ViewChild('whatsNew') private readonly modal?: NgxWhatsNewComponent;/** Options for the modal */
public options: DialogOptions = {
enableKeyboardNavigation: true,
clickableNavigationDots: true,
disableClose: false,
customStyle: {
width: '500px',
backgroundColor: '#fff',
borderSize: '1px',
textColor: '#222',
borderRadius: '10px',
boxShadow: '0px 0px 10px 5px #999',
},
};/** definition of all modals to show */
modals = [
{
title: 'Whats new in v1.0.0',
html: 'Lorem ipsum dolor sit amet, consectetur adipiscing el aspect et just.
test ',
image: {
height: 500,
src: 'https://picsum.photos/500',
altText:
'In v1.0.0, lorem ipsum dolor sit amet.',
},
button: {
text: 'Okay',
textColor: '#fff',
bgColor: '#333',
position: 'center',
},
},
...
];public openDialog(): void {
this.modal?.open();
}public onOpen(): void {
console.log('Dialog opened');
}public onClose(): void {
console.log('Dialog closed');
}public onNavigation($event: NavigationEvent) {
console.info('Previous item:', $event.previousItem);
console.info('Current item:', $event.currentItem);
}
```> [!NOTE]
> Optionally, you could use `@if` to conditionally render the component. Like so:
>
> app.component.html
>
> ```html
> @if (isDialogVisible) {
> #whatsNew
> (opened)="onOpen()"
> (closed)="onClose()"
> (navigation)="onNavigation($event)"
> [items]="modals"
> [options]="options"
> />
> }
> ```
>
> app.component.ts
>
> ```typescript
> public isDialogVisible: boolean | undefined;
>
> public openDialog(): void {
> isDialogVisible = true;
> }
>
> public onClose(): void {
> isDialogVisible = false;
> }
> ```## Available Options:
General options:
```typescript
interface DialogOptions {
disableClose?: boolean;
enableKeyboardNavigation?: boolean;
clickableNavigationDots?: boolean;
customStyle: {
width?: string;
boxShadow?: string;
backgroundColor?: string;
textColor?: string;
borderRadius?: string;
borderSize?: string;
};
}
```Options of a single modal window:
```typescript
interface WhatsNewItem {
title?: string;
text?: string;
html?: string;
image?: {
src: string;
height?: number;
bgColor?: string;
altText: string;
};
button?: {
text: string;
textColor: string;
bgColor: string;
position?: "left" | "center" | "right";
};
}
```