Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

ngx-modialog-7

brakowski315MIT9.0.2TypeScript support: included

Modal / Dialog for Angular

angular, bootstrap, vex, modal

readme

ngx-modialog (previously angular2-modal)


This project is looking for a new maintainer, see #414 for details.


ngx-modialog version 5.x.x works with angular 5.x.x

IMPORTANT - V4 BREAKING CHANGE:

Version 4.x.x contains some breaking changes, please see the CHANGELOG

Library has been renamed from version 3.0.2

Modal / Dialog implementation for angular.

  • Easy to use API via Fluent API Presets (alert, prompt, confirm)
  • Can render Component's, TemplateRef's and literal string
  • Extendable via plugins.
  • Easy to use
    modal.alert()
    .title('Hello World')
    .body('In Angular')
    .open();

Available plugins:

Install

npm install ngx-modialog

Basic plunker playground (bootstrap plugin):

ngx-modialog @ 4.x.x

http://plnkr.co/edit/lV7zsw7Yqossgs9JOfQU?p=preview

ngx-modialog @ 3.x.x

http://plnkr.co/edit/2ppVYl517GI1Byv8vVbG?p=preview

Quick start

In your application root module definition add ModalModule and the plugin you want to use:

We will use the bootstrap plugin (BootstrapModalModule) for this introduction.

import { ModalModule } from 'ngx-modialog';
import { BootstrapModalModule } from 'ngx-modialog/plugins/bootstrap';

// lots of code...

@NgModule({
  bootstrap: [ /* ... */ ],
  declarations: [ /* ... */ ],
  imports: [
    /* ... */
    ModalModule.forRoot(),
    BootstrapModalModule
  ],
})
export class AppModule { /* lots of code... */ }

In any angular component or service inject the Modal service and open a modal:

import { Component, ViewContainerRef } from '@angular/core';
import { Overlay } from 'ngx-modialog';
import { Modal } from 'ngx-modialog/plugins/bootstrap';

@Component({
  selector: 'my-app',
  template: `<button (click)="onClick()">Alert</button>`
})
export class AppComponent {
  constructor(public modal: Modal) { }

  onClick() {
    const dialogRef = this.modal.alert()
        .size('lg')
        .showClose(true)
        .title('A simple Alert style modal window')
        .body(`
            <h4>Alert is a classic (title/body/footer) 1 button modal window that 
            does not block.</h4>
            <b>Configuration:</b>
            <ul>
                <li>Non blocking (click anywhere outside to dismiss)</li>
                <li>Size large</li>
                <li>Dismissed with default keyboard key (ESC)</li>
                <li>Close wth button click</li>
                <li>HTML content</li>
            </ul>`)
        .open();

    dialogRef.result
        .then( result => alert(`The result is: ${result}`) );
  }
}

If you are using ngx-modialog version 3.X.X or below, open() returned a promise so replace the last 2 lines with:

   dialogRef
       .then( dialogRef => {
           dialogRef.result.then( result => alert(`The result is: ${result}`);
       });

We are using the alert() method, one of 3 (prompt, confirm)) fluent-api methods we call drop-ins

We then use the result property to wait for the modal closing event.

Notes:

  • Fluent API methods (drop-ins) are pre-configured (presets) methods that allow easy configuration and execution, you can create custom presets - see the demo application.
  • For more control use the open() method, which is used by all drop in's internally.
  • We import the Modal service from the plugin and not from the root library. Import from the root should work but being explicit allow using multiple plugins.

Demo App

The Demo application is a full implementation of the library with the native plugins.

View it at shlomiassaf.github.io/ngx-modialog

The demo application is part of this repository and it is a great place to learn by example.

Bootstrap / VEX features:

  • Customizable with components, Presets and more...
  • Select cancel/quit key.
  • Cascading modals.
  • Element blocking.
  • Blocking / Non blocking modal.
  • Modal as a component, replace the content by supplying a custom component.

The demo application comes with a dynamic modal generator for the Boostrap plugin

Plugins

Plugins serve as a concrete UI implementation for a modal.

It can be an implementation for a known library (e.g: bootstrap) or something completely unique

While ngx-modialog has some built in plugins it is also possible to use external plugins from NPM, if someone decide to build one.

Built a plugin? I would love to know :)

Known bugs

The dialog closes when removing the target DOM element in a click event

ref issue#111

To avoid this problem use event.stopPropagation(); or put the element removal inside a setTimeout call


HELP WANTED!

As a sole author I find it difficult to maintain multiple open source projects. As a result it is hard for me to replay rapidly to requests/help/etc...

If you would like to contribute, please contact me, the community will thank you.

You can contribute via:

  • Implementing features & Bug fixes
  • Documentation (Extremely important)
  • Issue management

Thank you!

Shlomi.


changelog

4.0.0-beta.3 (2017-08-29)

Features

4.0.0-beta.2 (2017-08-15)

Bug Fixes

  • error with OutsideEventPlugin that would lead to calling undefined function (#379) (c313962), closes #239

Features

4.0.0-beta.1 (2017-08-13)

Code Refactoring

  • dont return a promise when opening a dialog (#383) (21f54ee)

BREAKING CHANGES

  • Calling modal.open() returned a Promise of DialogRef. The async operation is not required and exists due to legacy angular implementation of dynamic components. modal.open() now returns the DialogRef instance and NOT the Promise.

You need to refactor your codebase to accomodate this change, this is a big change and it is required to remove the complexity working with DialogRef.

Plugin authoers: Maybe type does not exists anymore. If you retuned the dialog instance from your Modal implementations there is not much to refactor other then types here and there.

If you return Promise of DialogRef you will have to refactor your code.

4.0.0-beta.0 (2017-08-13)

Code Refactoring

BREAKING CHANGES

  • Angular version 5 comes with a breaking change which results in an internal breaking change which remove API options

Bindings are no longer supported when opening a modal. Providing bindings was, from day one, a shortcut to a manual operation. If you used bindings before, instead provide an injector with the bindings inside.

Most of the users should not feel this change as usage of bindings should be minimal.

If you wrote a plugin you should feel this, follow the change set for one of the native plugins as an conversion example.

3.0.2 (2017-08-11)

Features

  • bootstrap: support bootstrap 4 (23cb2a0), closes #280

3.0.1 (2017-06-21)

Bug Fixes

3.0.0 (2017-06-20)

Bug Fixes

  • handle document for angular universal (2f98e75)
  • refactor: use ng-template instead of template
  • refactor: remove defaultOverlayTarget directive
  • build: revamp the build process, use FESM and flat compiler metadata for faster, smaller bundles.
  • refactor: replace custom <swpCmp> with ngComponentOutlet

BREAKING CHANGES

  • Moving to use <ng-template> will break applications running on < 4
  • Applications using defaultOverlayTarget (all of them) will have to omit it

2.0.2 (2016-11-08)

Bug Fixes

  • non ESM module bundlers (webpack1) can't load plugins (ef35c80), closes #244

2.0.1 (2016-10-06)

Bug Fixes

  • do not include node reference in package output (5dfc9aa), closes #213
  • bootstrap: set proper types for size and dialogClass in BSModalContextBuilder (955b02b), closes #205

2.0.0-beta.14 (2016-10-03)

Bug Fixes

Code Refactoring

Features

  • support setting an injector when creating a modal (overlay). injector is optional. (c0a9b71)

BREAKING CHANGES

  • build: NPM Package now comes with ES6 Module version (ESM) and an ES5 UMD bundle (1 file), this should'nt have any effect. (CJS version removed) ES6 version contains d.ts files as well as metadata.json files for AoT Compilation.

This breaking change mainly effect the development process of angular2-modal. To support AoT a complete restructiing of the NPM package and build process was needed. Some devDependencies removed and some changed. Development process is now managed by Webpack 2. It is recommended to delete the node_modules directory and npm install again.

2.0.0-beta.13 (2016-09-17)

2.0.0-beta.12 (2016-09-01)

Bug Fixes

  • bootstrap: removed the dependency of the FormModule in the prompt modal (07fcce8)
  • remove Renderer use in the Modal service, create projetables in the overlay component (71a5c2c), closes #174 #175

Features

2.0.0-beta.11 (2016-08-30)

Features

  • DefaultOverlayTarget: directive to the the default view container, can be used instead of the manual way which has some boilerplate (8d0c932)
  • SwapComponent: a directive that creates a dynamic component inside a template (bd8182e)
  • add overlayConfigFactory, a factory/helper to make it easy to open custom modals using the open() method (852fd17)
  • allow registering dynamic components (250f234)
  • builders inheriting from OverlayContextBuilder return an OverlayConfig, simple and quick way to open modals (d115100)
  • support for TemplateRef and literal string as modal content (2e6f6a0)
  • support stacks of a specific group (i.e: overlay stack per plugin) (18acd51)
  • TemplateRef can access the dialog so it can control the modal and access the context (5e6c59e)
  • VEX: support ContainerContent (cb1f779)

Bug Fixes

  • css dialog container should not bind to class and style (e8196e8)
  • overlay component should hide overflow when inside element (cf432b3)
  • wrong banner in build (2c9bca5)
  • bootstrap: backdrop position should be absolute when inside element (33201ae)
  • bootstrap: undeclared component in module (76a7c08), closes #168
  • VEX: normalize context (97adecd)

Code Refactoring

  • CSSDialogContainer support for ContainerContent (support string, TepmlateRef and Components as content) (975afea)

BREAKING CHANGES

  • until now a modal can only open a component, this change allows a modal to open A ContainerContent which is a type the can be string, TemplateRef or a component (Type). To support this feature some partially breaking changes were made in the Modal class For developers using the library the modal.open(componentType: any, config?: OverlayConfig), the 1st parameter is now called content and it's type is ContainerContent: modal.open(content: ContainerContent, config?: OverlayConfig). For developers building plugins the same rule apply on the 2nd parameter of thecreate method. Also, the createModal method is deprecated, plugins should now use the createBackdrop and createContainer methods. Each container component supplied to createContainer must express <ng-content in it's template so the content (string, templateRef, component) can be injected into it.
  • method CSSDialogContainer.addComponent() was removed since modal containers are based on ng-content. Also removed the bindings for tabindex and role, they are now static

2.0.0-beta.10 (2016-08-23)

Code Refactoring

  • implement overlay stack per plugin for vex & bootstrap (2c9bca5)
  • move dynamic CSS/Style component to use direct element update (via renderer) instead of binding. Binding is bad for animation and since the whole purpose of this base class is to support animation direct access is needed. (7fb6c12)

Bug Fixes

  • wrong banner in build (2c9bca5)
  • change overlay destroy order, first run hooks, then observable then destroy overlay component ref (18acd51)
  • fix backdrop "on show" flicker in bootstrap plugin (7fb6c12)

Features

  • allow registering dynamic components (250f234)
  • support stacks of a specific group (i.e: overlay stack per plugin) (18acd51)

2.0.0-beta.9 (2016-08-22)

Code Refactoring

  • overlay: add inElement as a base context property (overlay-context) (8ec342c)
  • overlay: add remove inside property from OverlayConfig (8ec342c)

BREAKING CHANGES

  • overlay: OverlayConfig no longer sets the bounds area of the overlay, instead the context is used which means it is now user configurable

2.0.0-beta.8 (2016-08-22)

Bug Fixes

  • fixed incorrect inside element resolution logic (69895b6)

BREAKING CHANGES

  • previously if inside config property was not set (undefined) and viewContainerRef was supplied inElement resolved to true, now only if inside is explicitly true the modal is considered to be inside an element (i.e: inside the view container)

2.0.0-beta.7 (2016-08-21)

Bug Fixes

  • typo in overlay selector (f091153)
  • bootstrap: modal wont animate when closing via clicking outside of modal bounds (7b73461)
  • vex: modal wont animate on close/dismiss (7b73461)

2.0.0-beta.6 (2016-08-21)

Bug Fixes

  • import paths for systemjs (c6fff42)
  • import paths for systemjs (987e21b)
  • reference directory with index.ts to the index file directly (18a3ba8)
  • rename relative exports (ee66675)

Features

  • use overlay DOM structure
  • use CSS animation for plugins based on CSS libraries (e.g: bootstrap, vex)

BREAKING CHANGES

  • The modal open() command now accepts different variables.
  • plugin structure change (affects plugin development only)

1.1.4 (2016-08-21)

Bug Fixes

  • be greedy when replacing d.ts imports (2347cf2)

1.1.3 (2016-08-21)

Bug Fixes

  • github publishing (7e1f343)
  • demo-vex: remove button from noButtons example (0418ecf)
  • vex: missing setter in the api (2699bf5)
  • set context on function call (bab38c0)
  • set focus trap for VEX and set focus on container (c1f33a8)
  • vex: set focus on internal element to workaround bug with css animation and focus outline (22bfcab), closes #121
  • systemJS not working due to barrel imports and relative paths (2f72ebe)
  • trap focus inside bootstrap container - fixes #113 (c7113b4)
  • us workaround to allow uglify/minify, see angular/angular#10618 (bcd4525), closes #157

Features

  • animation: in / out animation in bootstrap plugin (63ad352)
  • core: support Angular RC5 (e4bbcc4)
  • vex: support Angular RC5 (2783d51)

1.0.0 (2016-05-10)