mirror of
https://github.com/Redocly/redoc.git
synced 2024-11-24 01:23:43 +03:00
44 lines
1.4 KiB
TypeScript
44 lines
1.4 KiB
TypeScript
'use strict';
|
|
|
|
import {
|
|
Injectable,
|
|
ComponentFactory,
|
|
ComponentRef,
|
|
ViewContainerRef
|
|
} from '@angular/core';
|
|
|
|
@Injectable()
|
|
export class ContentProjector {
|
|
instantiateAndProject<T>(componentFactory: ComponentFactory<T>,
|
|
parentView:ViewContainerRef, projectedNodesOrComponents: any[]):ComponentRef<T> {
|
|
let contextInjector = parentView.parentInjector;
|
|
|
|
let projectedNodes = [];
|
|
let componentRefs:ComponentRef<any>[] = [];
|
|
|
|
for (let i=0; i < projectedNodesOrComponents.length; i++) {
|
|
let nodeOrCompRef = projectedNodesOrComponents[i];
|
|
if (nodeOrCompRef instanceof ComponentRef) {
|
|
projectedNodes.push(nodeOrCompRef.location.nativeElement);
|
|
componentRefs.push(nodeOrCompRef);
|
|
} else {
|
|
projectedNodes.push(nodeOrCompRef);
|
|
}
|
|
}
|
|
|
|
let parentCompRef = parentView.createComponent(componentFactory, null, contextInjector, [projectedNodes]);
|
|
|
|
// using private property to get view instance
|
|
let viewContainer = (<any>parentView)._view;
|
|
let viewData = (<any>parentView)._data;
|
|
viewData.embeddedViews = viewData.embeddedViews || [];
|
|
for (let i=0; i < componentRefs.length; i++) {
|
|
let compRef = componentRefs[i];
|
|
// attach view to containter change detector
|
|
viewData.embeddedViews.push((<any>compRef.hostView)._view);
|
|
(<any>compRef.hostView).attachToViewContainerRef(viewContainer);
|
|
}
|
|
return parentCompRef;
|
|
}
|
|
}
|