Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@tinkoff/ng-polymorpheus

Package Overview
Dependencies
Maintainers
16
Versions
36
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@tinkoff/ng-polymorpheus - npm Package Compare versions

Comparing version 4.0.1 to 4.0.2

classes/context.d.ts

46

bundles/tinkoff-ng-polymorpheus.umd.js

@@ -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":"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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 {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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc