Skip to content

Commit

Permalink
feat(popover): support passing template context
Browse files Browse the repository at this point in the history
* Fixes valor-software#1682 by adding a new @input for popover directive so that
context can be passed when content is TemplateRef.
  • Loading branch information
harunurhan committed Aug 16, 2017
1 parent 5dd456b commit 2b5c805
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 4 deletions.
9 changes: 5 additions & 4 deletions src/component-loader/component-loader.class.ts
Original file line number Diff line number Diff line change
Expand Up @@ -107,13 +107,13 @@ export class ComponentLoader<T> {
}

// todo: appendChild to element or document.querySelector(this.container)
public show(opts: { content?: string | TemplateRef<any>, [key: string]: any } = {}): ComponentRef<T> {
public show(opts: { content?: string | TemplateRef<any>, context?: any, [key: string]: any } = {}): ComponentRef<T> {
this._subscribePositioning();
this._innerComponent = null;

if (!this._componentRef) {
this.onBeforeShow.emit();
this._contentRef = this._getContentRef(opts.content);
this._contentRef = this._getContentRef(opts.content, opts.context);
const injector = ReflectiveInjector.resolveAndCreate(this._providers, this._injector);

this._componentRef = this._componentFactory.create(injector, this._contentRef.nodes);
Expand Down Expand Up @@ -257,14 +257,15 @@ export class ComponentLoader<T> {
this._zoneSubscription = null;
}

private _getContentRef(content: string | TemplateRef<any> | any): ContentRef {
private _getContentRef(content: string | TemplateRef<any> | any, context?: any): ContentRef {
if (!content) {
return new ContentRef([]);
}

if (content instanceof TemplateRef) {
if (this._viewContainerRef) {
const viewRef = this._viewContainerRef.createEmbeddedView<TemplateRef<T>>(content);
const viewRef = this._viewContainerRef.createEmbeddedView<TemplateRef<T>>(content, context);
viewRef.markForCheck();
return new ContentRef([viewRef.rootNodes], viewRef);
}
const viewRef = content.createEmbeddedView({});
Expand Down
5 changes: 5 additions & 0 deletions src/popover/popover.directive.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ export class PopoverDirective implements OnInit, OnDestroy {
* Content to be displayed as popover.
*/
@Input() public popover: string | TemplateRef<any>;
/**
* Context to be used if popover is a template.
*/
@Input() public popoverContext: any;
/**
* Title of a popover.
*/
Expand Down Expand Up @@ -99,6 +103,7 @@ export class PopoverDirective implements OnInit, OnDestroy {
.position({attachment: this.placement})
.show({
content: this.popover,
context: this.popoverContext,
placement: this.placement,
title: this.popoverTitle,
containerClass: this.containerClass
Expand Down

0 comments on commit 2b5c805

Please sign in to comment.