@tinkoff/ng-polymorpheus
Advanced tools
Comparing version 4.0.1 to 4.0.2
@@ -47,3 +47,3 @@ (function (global, factory) { | ||
} | ||
PolymorpheusComponent.prototype.createInjector = function (injector, context) { | ||
PolymorpheusComponent.prototype.createInjector = function (injector, useValue) { | ||
return i0.Injector.create({ | ||
@@ -54,3 +54,3 @@ parent: this.injector || injector, | ||
provide: POLYMORPHEUS_CONTEXT, | ||
useValue: context, | ||
useValue: useValue, | ||
}, | ||
@@ -101,2 +101,6 @@ ], | ||
/** | ||
* @deprecated: use {@link PolymorpheusContext} instead | ||
* Primitive types used as content by {@link PolymorpheusOutletDirective} | ||
*/ | ||
var PrimitiveContext = /** @class */ (function () { | ||
@@ -115,2 +119,15 @@ function PrimitiveContext($implicit) { | ||
}()); | ||
var PolymorpheusContext = /** @class */ (function () { | ||
function PolymorpheusContext($implicit) { | ||
this.$implicit = $implicit; | ||
} | ||
Object.defineProperty(PolymorpheusContext.prototype, "polymorpheusOutlet", { | ||
get: function () { | ||
return this.$implicit; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
return PolymorpheusContext; | ||
}()); | ||
@@ -134,5 +151,5 @@ var PolymorpheusOutletDirective = /** @class */ (function () { | ||
}); | ||
PolymorpheusOutletDirective.prototype.ngOnChanges = function (_a) { | ||
PolymorpheusOutletDirective.prototype.ngOnChanges = function (_b) { | ||
var _this = this; | ||
var content = _a.content; | ||
var content = _b.content; | ||
if (this.viewRef) { | ||
@@ -149,5 +166,6 @@ this.viewRef.context = this.getContext(); | ||
if (isComponent(this.content)) { | ||
var proxy = new Proxy(this.context, { | ||
get: function (_, key) { return _this.context[key]; }, | ||
}); | ||
var proxy = this.context && | ||
new Proxy(this.context, { | ||
get: function (_, key) { var _a; return (_a = _this.context) === null || _a === void 0 ? void 0 : _a[key]; }, | ||
}); | ||
var injector = this.content.createInjector(this.injector, proxy); | ||
@@ -168,8 +186,12 @@ var componentFactory = injector | ||
}; | ||
PolymorpheusOutletDirective.ngTemplateContextGuard = function (_dir, _ctx) { | ||
return true; | ||
}; | ||
PolymorpheusOutletDirective.prototype.getContext = function () { | ||
return isTemplate(this.content) | ||
? this.context | ||
: new PrimitiveContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
if (isTemplate(this.content) || isComponent(this.content)) { | ||
return this.context; | ||
} | ||
return new PolymorpheusContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
}; | ||
@@ -176,0 +198,0 @@ return PolymorpheusOutletDirective; |
@@ -12,3 +12,3 @@ import { Injector, Type } from '@angular/core'; | ||
constructor(component: Type<T>, injector?: Injector | null); | ||
createInjector(injector: Injector, context: C): Injector; | ||
createInjector(injector: Injector, useValue?: C): Injector; | ||
} |
import { DoCheck, Injector, OnChanges, SimpleChanges, TemplateRef, ViewContainerRef } from '@angular/core'; | ||
import { PrimitiveContext } from '../classes/primitive-context'; | ||
import { PolymorpheusContext } from '../classes/context'; | ||
import { PolymorpheusContent } from '../types/content'; | ||
@@ -12,7 +12,8 @@ import * as i0 from "@angular/core"; | ||
content: PolymorpheusContent<C>; | ||
context: C; | ||
constructor(viewContainerRef: ViewContainerRef, injector: Injector, templateRef: TemplateRef<PrimitiveContext>); | ||
context?: C; | ||
constructor(viewContainerRef: ViewContainerRef, injector: Injector, templateRef: TemplateRef<PolymorpheusContext<string>>); | ||
private get template(); | ||
ngOnChanges({ content }: SimpleChanges): void; | ||
ngDoCheck(): void; | ||
static ngTemplateContextGuard<T>(_dir: PolymorpheusOutletDirective<T>, _ctx: any): _ctx is PolymorpheusContext<string>; | ||
private getContext; | ||
@@ -19,0 +20,0 @@ static ɵfac: i0.ɵɵFactoryDeclaration<PolymorpheusOutletDirective<any>, never>; |
@@ -14,3 +14,3 @@ import { Injector } from '@angular/core'; | ||
} | ||
createInjector(injector, context) { | ||
createInjector(injector, useValue) { | ||
return Injector.create({ | ||
@@ -21,3 +21,3 @@ parent: this.injector || injector, | ||
provide: POLYMORPHEUS_CONTEXT, | ||
useValue: context, | ||
useValue, | ||
}, | ||
@@ -28,2 +28,2 @@ ], | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcG9seW1vcnBoZXVzL3NyYy9jbGFzc2VzL2NvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFPLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBRXZEOzs7OztHQUtHO0FBQ0gsTUFBTSxPQUFPLHFCQUFxQjtJQUM5QixZQUNhLFNBQWtCLEVBQ1YsV0FBNEIsSUFBSTtRQUR4QyxjQUFTLEdBQVQsU0FBUyxDQUFTO1FBQ1YsYUFBUSxHQUFSLFFBQVEsQ0FBd0I7SUFDbEQsQ0FBQztJQUVKLGNBQWMsQ0FBQyxRQUFrQixFQUFFLE9BQVU7UUFDekMsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQ25CLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxJQUFJLFFBQVE7WUFDakMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSxvQkFBb0I7b0JBQzdCLFFBQVEsRUFBRSxPQUFPO2lCQUNwQjthQUNKO1NBQ0osQ0FBQyxDQUFDO0lBQ1AsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RvciwgVHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7UE9MWU1PUlBIRVVTX0NPTlRFWFR9IGZyb20gJy4uL3Rva2Vucy9jb250ZXh0JztcclxuXHJcbi8qKlxyXG4gKiBXcmFwcGVyIGNsYXNzIGZvciBhIGNvbXBvbmVudCB0aGF0IHdpbGwgYmUgdXNlZCBhcyBjb250ZW50IGZvciB7QGxpbmsgUG9seW1vcnBoZXVzT3V0bGV0RGlyZWN0aXZlfVxyXG4gKlxyXG4gKiBAcGFyYW0gY29tcG9uZW50IOKAlCBhbiBBbmd1bGFyIGNvbXBvbmVudCB0byBiZSBkeW5hbWljYWxseSBjcmVhdGVkXHJcbiAqIEBwYXJhbSBpbmplY3RvciDigJQgb3B0aW9uYWwge0BsaW5rIEluamVjdG9yfSBmb3IgbGF6eSBsb2FkZWQgbW9kdWxlIGNhc2VcclxuICovXHJcbmV4cG9ydCBjbGFzcyBQb2x5bW9ycGhldXNDb21wb25lbnQ8VCwgQyBleHRlbmRzIFJlY29yZDxhbnksIGFueT4+IHtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHJlYWRvbmx5IGNvbXBvbmVudDogVHlwZTxUPixcclxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3RvciB8IG51bGwgPSBudWxsLFxyXG4gICAgKSB7fVxyXG5cclxuICAgIGNyZWF0ZUluamVjdG9yKGluamVjdG9yOiBJbmplY3RvciwgY29udGV4dDogQyk6IEluamVjdG9yIHtcclxuICAgICAgICByZXR1cm4gSW5qZWN0b3IuY3JlYXRlKHtcclxuICAgICAgICAgICAgcGFyZW50OiB0aGlzLmluamVjdG9yIHx8IGluamVjdG9yLFxyXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgICAgICBwcm92aWRlOiBQT0xZTU9SUEhFVVNfQ09OVEVYVCxcclxuICAgICAgICAgICAgICAgICAgICB1c2VWYWx1ZTogY29udGV4dCxcclxuICAgICAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIF0sXHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbn1cclxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcG9seW1vcnBoZXVzL3NyYy9jbGFzc2VzL2NvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFPLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBRXZEOzs7OztHQUtHO0FBQ0gsTUFBTSxPQUFPLHFCQUFxQjtJQUM5QixZQUNhLFNBQWtCLEVBQ1YsV0FBNEIsSUFBSTtRQUR4QyxjQUFTLEdBQVQsU0FBUyxDQUFTO1FBQ1YsYUFBUSxHQUFSLFFBQVEsQ0FBd0I7SUFDbEQsQ0FBQztJQUVKLGNBQWMsQ0FBQyxRQUFrQixFQUFFLFFBQVk7UUFDM0MsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQ25CLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxJQUFJLFFBQVE7WUFDakMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSxvQkFBb0I7b0JBQzdCLFFBQVE7aUJBQ1g7YUFDSjtTQUNKLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0b3IsIFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1BPTFlNT1JQSEVVU19DT05URVhUfSBmcm9tICcuLi90b2tlbnMvY29udGV4dCc7XHJcblxyXG4vKipcclxuICogV3JhcHBlciBjbGFzcyBmb3IgYSBjb21wb25lbnQgdGhhdCB3aWxsIGJlIHVzZWQgYXMgY29udGVudCBmb3Ige0BsaW5rIFBvbHltb3JwaGV1c091dGxldERpcmVjdGl2ZX1cclxuICpcclxuICogQHBhcmFtIGNvbXBvbmVudCDigJQgYW4gQW5ndWxhciBjb21wb25lbnQgdG8gYmUgZHluYW1pY2FsbHkgY3JlYXRlZFxyXG4gKiBAcGFyYW0gaW5qZWN0b3Ig4oCUIG9wdGlvbmFsIHtAbGluayBJbmplY3Rvcn0gZm9yIGxhenkgbG9hZGVkIG1vZHVsZSBjYXNlXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgUG9seW1vcnBoZXVzQ29tcG9uZW50PFQsIEMgZXh0ZW5kcyBSZWNvcmQ8YW55LCBhbnk+PiB7XHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICByZWFkb25seSBjb21wb25lbnQ6IFR5cGU8VD4sXHJcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IgfCBudWxsID0gbnVsbCxcclxuICAgICkge31cclxuXHJcbiAgICBjcmVhdGVJbmplY3RvcihpbmplY3RvcjogSW5qZWN0b3IsIHVzZVZhbHVlPzogQyk6IEluamVjdG9yIHtcclxuICAgICAgICByZXR1cm4gSW5qZWN0b3IuY3JlYXRlKHtcclxuICAgICAgICAgICAgcGFyZW50OiB0aGlzLmluamVjdG9yIHx8IGluamVjdG9yLFxyXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgICAgICBwcm92aWRlOiBQT0xZTU9SUEhFVVNfQ09OVEVYVCxcclxuICAgICAgICAgICAgICAgICAgICB1c2VWYWx1ZSxcclxuICAgICAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIF0sXHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbn1cclxuIl19 |
import { ChangeDetectorRef, ComponentFactoryResolver, Directive, Input, TemplateRef, } from '@angular/core'; | ||
import { PolymorpheusComponent } from '../classes/component'; | ||
import { PrimitiveContext } from '../classes/primitive-context'; | ||
import { PolymorpheusContext } from '../classes/context'; | ||
import { PolymorpheusTemplate } from './template'; | ||
@@ -31,5 +31,6 @@ import * as i0 from "@angular/core"; | ||
if (isComponent(this.content)) { | ||
const proxy = new Proxy(this.context, { | ||
get: (_, key) => this.context[key], | ||
}); | ||
const proxy = this.context && | ||
new Proxy(this.context, { | ||
get: (_, key) => { var _a; return (_a = this.context) === null || _a === void 0 ? void 0 : _a[key]; }, | ||
}); | ||
const injector = this.content.createInjector(this.injector, proxy); | ||
@@ -50,8 +51,12 @@ const componentFactory = injector | ||
} | ||
static ngTemplateContextGuard(_dir, _ctx) { | ||
return true; | ||
} | ||
getContext() { | ||
return isTemplate(this.content) | ||
? this.context | ||
: new PrimitiveContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
if (isTemplate(this.content) || isComponent(this.content)) { | ||
return this.context; | ||
} | ||
return new PolymorpheusContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
} | ||
@@ -82,2 +87,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outlet.js","sourceRoot":"","sources":["../../../../projects/ng-polymorpheus/src/directives/outlet.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,iBAAiB,EACjB,wBAAwB,EAExB,SAAS,EAIT,KAAK,EAGL,WAAW,GAEd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,qBAAqB,EAAC,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAC,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,EAAC,oBAAoB,EAAC,MAAM,YAAY,CAAC;;AAKhD,MAAM,OAAO,2BAA2B;IAYpC,YACqB,gBAAkC,EAClC,QAAkB,EAClB,WAA0C;QAF1C,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,aAAQ,GAAR,QAAQ,CAAU;QAClB,gBAAW,GAAX,WAAW,CAA+B;QAR/D,YAAO,GAA2B,EAAE,CAAC;IASlC,CAAC;IAEJ,IAAY,QAAQ;QAChB,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;SAChC;QAED,OAAO,IAAI,CAAC,OAAO,YAAY,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;IACjF,CAAC;IAED,WAAW,CAAC,EAAC,OAAO,EAAgB;QAChC,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;SAC5C;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,YAAY,EAAE,CAAC;SACpE;QAED,IAAI,CAAC,OAAO,EAAE;YACV,OAAO;SACV;QAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAE9B,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC3B,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE;gBAClC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAc,CAAC;aAChD,CAAC,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YACnE,MAAM,gBAAgB,GAAG,QAAQ;iBAC5B,GAAG,CAAC,wBAAwB,CAAC;iBAC7B,uBAAuB,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAErD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CACrD,gBAAgB,EAChB,CAAC,EACD,QAAQ,CACX,CAAC;SACL;aAAM;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CACnD,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,UAAU,EAAE,CACpB,CAAC;SACL;IACL,CAAC;IAED,SAAS;QACL,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;SACxB;IACL,CAAC;IAEO,UAAU;QACd,OAAO,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC;YAC3B,CAAC,CAAC,IAAI,CAAC,OAAO;YACd,CAAC,CAAC,IAAI,gBAAgB,CAChB,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU;gBAC9B,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;gBAC5B,CAAC,CAAC,IAAI,CAAC,OAAO,CACrB,CAAC;IACZ,CAAC;;2IA7EQ,2BAA2B;+HAA3B,2BAA2B;2FAA3B,2BAA2B;kBAHvC,SAAS;mBAAC;oBACP,QAAQ,EAAE,sBAAsB;iBACnC;wJAQG,OAAO;sBADN,KAAK;uBAAC,oBAAoB;gBAI3B,OAAO;sBADN,KAAK;uBAAC,2BAA2B;;AAuEtC,SAAS,WAAW,CAChB,OAA+B;IAE/B,OAAO,OAAO,YAAY,oBAAoB,CAAC;AACnD,CAAC;AAED,SAAS,WAAW,CAChB,OAA+B;IAE/B,OAAO,OAAO,YAAY,qBAAqB,CAAC;AACpD,CAAC;AAED,SAAS,UAAU,CACf,OAA+B;IAE/B,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,OAAO,YAAY,WAAW,CAAC;AAClE,CAAC","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    ComponentFactoryResolver,\r\n    ComponentRef,\r\n    Directive,\r\n    DoCheck,\r\n    EmbeddedViewRef,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    SimpleChanges,\r\n    TemplateRef,\r\n    ViewContainerRef,\r\n} from '@angular/core';\r\nimport {PolymorpheusComponent} from '../classes/component';\r\nimport {PrimitiveContext} from '../classes/primitive-context';\r\nimport {PolymorpheusContent} from '../types/content';\r\nimport {PolymorpheusTemplate} from './template';\r\n\r\n@Directive({\r\n    selector: '[polymorpheusOutlet]',\r\n})\r\nexport class PolymorpheusOutletDirective<C extends Record<any, any>>\r\n    implements OnChanges, DoCheck {\r\n    private viewRef?: EmbeddedViewRef<unknown>;\r\n\r\n    private componentRef?: ComponentRef<unknown>;\r\n\r\n    @Input('polymorpheusOutlet')\r\n    content: PolymorpheusContent<C> = '';\r\n\r\n    @Input('polymorpheusOutletContext')\r\n    context!: C;\r\n\r\n    constructor(\r\n        private readonly viewContainerRef: ViewContainerRef,\r\n        private readonly injector: Injector,\r\n        private readonly templateRef: TemplateRef<PrimitiveContext>,\r\n    ) {}\r\n\r\n    private get template(): TemplateRef<unknown> {\r\n        if (isDirective(this.content)) {\r\n            return this.content.template;\r\n        }\r\n\r\n        return this.content instanceof TemplateRef ? this.content : this.templateRef;\r\n    }\r\n\r\n    ngOnChanges({content}: SimpleChanges) {\r\n        if (this.viewRef) {\r\n            this.viewRef.context = this.getContext();\r\n        }\r\n\r\n        if (this.componentRef) {\r\n            this.componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n        }\r\n\r\n        if (!content) {\r\n            return;\r\n        }\r\n\r\n        this.viewContainerRef.clear();\r\n\r\n        if (isComponent(this.content)) {\r\n            const proxy = new Proxy(this.context, {\r\n                get: (_, key) => this.context[key as keyof C],\r\n            });\r\n            const injector = this.content.createInjector(this.injector, proxy);\r\n            const componentFactory = injector\r\n                .get(ComponentFactoryResolver)\r\n                .resolveComponentFactory(this.content.component);\r\n\r\n            this.componentRef = this.viewContainerRef.createComponent(\r\n                componentFactory,\r\n                0,\r\n                injector,\r\n            );\r\n        } else {\r\n            this.viewRef = this.viewContainerRef.createEmbeddedView(\r\n                this.template,\r\n                this.getContext(),\r\n            );\r\n        }\r\n    }\r\n\r\n    ngDoCheck() {\r\n        if (isDirective(this.content)) {\r\n            this.content.check();\r\n        }\r\n    }\r\n\r\n    private getContext(): unknown {\r\n        return isTemplate(this.content)\r\n            ? this.context\r\n            : new PrimitiveContext(\r\n                  typeof this.content === 'function'\r\n                      ? this.content(this.context)\r\n                      : this.content,\r\n              );\r\n    }\r\n}\r\n\r\nfunction isDirective<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusTemplate<C> {\r\n    return content instanceof PolymorpheusTemplate;\r\n}\r\n\r\nfunction isComponent<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusComponent<any, C> {\r\n    return content instanceof PolymorpheusComponent;\r\n}\r\n\r\nfunction isTemplate<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusTemplate<C> | TemplateRef<C> {\r\n    return isDirective(content) || content instanceof TemplateRef;\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outlet.js","sourceRoot":"","sources":["../../../../projects/ng-polymorpheus/src/directives/outlet.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    ComponentFactoryResolver,\r\n    ComponentRef,\r\n    Directive,\r\n    DoCheck,\r\n    EmbeddedViewRef,\r\n    Injector,\r\n    Input,\r\n    OnChanges,\r\n    SimpleChanges,\r\n    TemplateRef,\r\n    ViewContainerRef,\r\n} from '@angular/core';\r\nimport {PolymorpheusComponent} from '../classes/component';\r\nimport {PolymorpheusContext} from '../classes/context';\r\nimport {PolymorpheusContent} from '../types/content';\r\nimport {PolymorpheusTemplate} from './template';\r\n\r\n@Directive({\r\n    selector: '[polymorpheusOutlet]',\r\n})\r\nexport class PolymorpheusOutletDirective<C extends Record<any, any>>\r\n    implements OnChanges, DoCheck {\r\n    private viewRef?: EmbeddedViewRef<unknown>;\r\n\r\n    private componentRef?: ComponentRef<unknown>;\r\n\r\n    @Input('polymorpheusOutlet')\r\n    content: PolymorpheusContent<C> = '';\r\n\r\n    @Input('polymorpheusOutletContext')\r\n    context?: C;\r\n\r\n    constructor(\r\n        private readonly viewContainerRef: ViewContainerRef,\r\n        private readonly injector: Injector,\r\n        private readonly templateRef: TemplateRef<PolymorpheusContext<string>>,\r\n    ) {}\r\n\r\n    private get template(): TemplateRef<unknown> {\r\n        if (isDirective(this.content)) {\r\n            return this.content.template;\r\n        }\r\n\r\n        return this.content instanceof TemplateRef ? this.content : this.templateRef;\r\n    }\r\n\r\n    ngOnChanges({content}: SimpleChanges) {\r\n        if (this.viewRef) {\r\n            this.viewRef.context = this.getContext();\r\n        }\r\n\r\n        if (this.componentRef) {\r\n            this.componentRef.injector.get(ChangeDetectorRef).markForCheck();\r\n        }\r\n\r\n        if (!content) {\r\n            return;\r\n        }\r\n\r\n        this.viewContainerRef.clear();\r\n\r\n        if (isComponent(this.content)) {\r\n            const proxy =\r\n                this.context &&\r\n                new Proxy(this.context, {\r\n                    get: (_, key) => this.context?.[key as keyof C],\r\n                });\r\n            const injector = this.content.createInjector(this.injector, proxy);\r\n            const componentFactory = injector\r\n                .get(ComponentFactoryResolver)\r\n                .resolveComponentFactory(this.content.component);\r\n\r\n            this.componentRef = this.viewContainerRef.createComponent(\r\n                componentFactory,\r\n                0,\r\n                injector,\r\n            );\r\n        } else {\r\n            this.viewRef = this.viewContainerRef.createEmbeddedView(\r\n                this.template,\r\n                this.getContext(),\r\n            );\r\n        }\r\n    }\r\n\r\n    ngDoCheck() {\r\n        if (isDirective(this.content)) {\r\n            this.content.check();\r\n        }\r\n    }\r\n\r\n    static ngTemplateContextGuard<T>(\r\n        _dir: PolymorpheusOutletDirective<T>,\r\n        _ctx: any,\r\n    ): _ctx is PolymorpheusContext<string> {\r\n        return true;\r\n    }\r\n\r\n    private getContext(): unknown {\r\n        if (isTemplate(this.content) || isComponent(this.content)) {\r\n            return this.context;\r\n        }\r\n\r\n        return new PolymorpheusContext(\r\n            typeof this.content === 'function'\r\n                ? this.content(this.context!)\r\n                : this.content,\r\n        );\r\n    }\r\n}\r\n\r\nfunction isDirective<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusTemplate<C> {\r\n    return content instanceof PolymorpheusTemplate;\r\n}\r\n\r\nfunction isComponent<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusComponent<any, C> {\r\n    return content instanceof PolymorpheusComponent;\r\n}\r\n\r\nfunction isTemplate<C extends Record<any, any>>(\r\n    content: PolymorpheusContent<C>,\r\n): content is PolymorpheusTemplate<C> | TemplateRef<C> {\r\n    return isDirective(content) || content instanceof TemplateRef;\r\n}\r\n"]} |
@@ -21,3 +21,3 @@ import * as i0 from '@angular/core'; | ||
} | ||
createInjector(injector, context) { | ||
createInjector(injector, useValue) { | ||
return Injector.create({ | ||
@@ -28,3 +28,3 @@ parent: this.injector || injector, | ||
provide: POLYMORPHEUS_CONTEXT, | ||
useValue: context, | ||
useValue, | ||
}, | ||
@@ -71,2 +71,6 @@ ], | ||
/** | ||
* @deprecated: use {@link PolymorpheusContext} instead | ||
* Primitive types used as content by {@link PolymorpheusOutletDirective} | ||
*/ | ||
class PrimitiveContext { | ||
@@ -80,2 +84,10 @@ constructor($implicit) { | ||
} | ||
class PolymorpheusContext { | ||
constructor($implicit) { | ||
this.$implicit = $implicit; | ||
} | ||
get polymorpheusOutlet() { | ||
return this.$implicit; | ||
} | ||
} | ||
@@ -107,5 +119,6 @@ class PolymorpheusOutletDirective { | ||
if (isComponent(this.content)) { | ||
const proxy = new Proxy(this.context, { | ||
get: (_, key) => this.context[key], | ||
}); | ||
const proxy = this.context && | ||
new Proxy(this.context, { | ||
get: (_, key) => { var _a; return (_a = this.context) === null || _a === void 0 ? void 0 : _a[key]; }, | ||
}); | ||
const injector = this.content.createInjector(this.injector, proxy); | ||
@@ -126,8 +139,12 @@ const componentFactory = injector | ||
} | ||
static ngTemplateContextGuard(_dir, _ctx) { | ||
return true; | ||
} | ||
getContext() { | ||
return isTemplate(this.content) | ||
? this.context | ||
: new PrimitiveContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
if (isTemplate(this.content) || isComponent(this.content)) { | ||
return this.context; | ||
} | ||
return new PolymorpheusContext(typeof this.content === 'function' | ||
? this.content(this.context) | ||
: this.content); | ||
} | ||
@@ -134,0 +151,0 @@ } |
{ | ||
"name": "@tinkoff/ng-polymorpheus", | ||
"version": "4.0.1", | ||
"version": "4.0.2", | ||
"peerDependencies": { | ||
@@ -5,0 +5,0 @@ "@angular/core": ">=12.0.0" |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
97954
746