Skip to content

Render any child view somewhere else on the page.

License

Notifications You must be signed in to change notification settings

medokin/angular-wormhole

This branch is 27 commits behind topaxi/ng-wormhole:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

d9cfbb9 · Apr 10, 2018

History

15 Commits
Jan 20, 2017
Apr 7, 2017
Apr 10, 2018
Jan 20, 2017
Jan 25, 2017
Apr 10, 2018
Jan 20, 2017
Mar 10, 2017
Apr 10, 2018
May 8, 2017
Apr 7, 2017
Apr 7, 2017

Repository files navigation

Angular Wormhole

This component allows rendering all of its content to be rendered elsewhere on the page.

Why?

Sometimes a dialog or tooltip has to be rendered outside of an element, as CSS stacking contexts may interfere with positioning.

Installation

$ yarn add angular-wormhole

Import AngularWormholeModule in your app:

import { NgModule } from '@angular/core';
import { AngularWormholeModule } from 'angular-wormhole';

@NgModule({
  imports: [
    AngularWormholeModule
  ]
})
export class AppModule {}

Example usage

index.html

<body>
  <my-angular-app></my-angular-app>
  <div id="wormhole-target"></div>
</body>

In a component template:

<ng-wormhole to="#wormhole-target">
  <my-popover>...</my-popover>
</ng-wormhole>

The <my-popover> component will then be rendered in the #wormhole-target element, it will also automatically cleaned up once your component will be destroyed.

Attributes

to: selector Which element to append to.

<ng-wormhole to="#wormhole-target">
  <my-popover>...</my-popover>
</ng-wormhole>

Inputs

to: selector Which element to append to.

<ng-wormhole [to]="'#wormhole-target'">
  <my-popover>...</my-popover>
</ng-wormhole>

renderInPlace: boolean = false Should the component render its children in place?

<ng-wormhole to="#wormhole-target" [renderInPlace]="true">
  <my-popover>...</my-popover>
</ng-wormhole>

Credits

This component is heavily inspired by ember-wormhole. Contributions from @stefanpenner, @krisselden, @chrislopresto, @lukemelia, @raycohen and others.

About

Render any child view somewhere else on the page.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 100.0%