ngx-tethys 18.1.0 → 18.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/core/overlay/abstract-overlay.config.d.ts +5 -0
  3. package/drag-drop/drag-content.directive.d.ts +1 -0
  4. package/drag-drop/drag-drop.service.d.ts +1 -0
  5. package/drag-drop/drag-handle.directive.d.ts +1 -0
  6. package/drag-drop/drag.directive.d.ts +1 -0
  7. package/drag-drop/drop-container.directive.d.ts +2 -5
  8. package/drag-drop/module.d.ts +4 -0
  9. package/esm2022/core/overlay/abstract-overlay.config.mjs +1 -1
  10. package/esm2022/core/overlay/abstract-overlay.service.mjs +2 -2
  11. package/esm2022/dialog/dialog-container.component.mjs +2 -2
  12. package/esm2022/drag-drop/drag-content.directive.mjs +2 -1
  13. package/esm2022/drag-drop/drag-drop.service.mjs +2 -1
  14. package/esm2022/drag-drop/drag-handle.directive.mjs +2 -1
  15. package/esm2022/drag-drop/drag.directive.mjs +2 -1
  16. package/esm2022/drag-drop/drop-container.directive.mjs +2 -1
  17. package/esm2022/drag-drop/module.mjs +9 -2
  18. package/esm2022/property/property-item.component.mjs +3 -3
  19. package/esm2022/version.mjs +2 -2
  20. package/fesm2022/ngx-tethys-core.mjs +1 -1
  21. package/fesm2022/ngx-tethys-core.mjs.map +1 -1
  22. package/fesm2022/ngx-tethys-dialog.mjs +1 -1
  23. package/fesm2022/ngx-tethys-dialog.mjs.map +1 -1
  24. package/fesm2022/ngx-tethys-drag-drop.mjs +13 -2
  25. package/fesm2022/ngx-tethys-drag-drop.mjs.map +1 -1
  26. package/fesm2022/ngx-tethys-property.mjs +2 -2
  27. package/fesm2022/ngx-tethys-property.mjs.map +1 -1
  28. package/fesm2022/ngx-tethys.mjs +1 -1
  29. package/fesm2022/ngx-tethys.mjs.map +1 -1
  30. package/package.json +1 -1
  31. package/schematics/version.d.ts +1 -1
  32. package/schematics/version.js +1 -1
  33. package/styles/modules/cdk/drag-drop.scss +1 -1
@@ -77,7 +77,7 @@ export class ThyPropertyItem {
77
77
  this.setEditing(keep);
78
78
  }
79
79
  hasOverlay() {
80
- return this.overlayOutsideClickDispatcher._attachedOverlays.length > this.originOverlays.length;
80
+ return !!this.overlayOutsideClickDispatcher._attachedOverlays.filter(overlay => !this.originOverlays.includes(overlay)).length;
81
81
  }
82
82
  subscribeClick() {
83
83
  if (this.thyEditable === true) {
@@ -95,7 +95,7 @@ export class ThyPropertyItem {
95
95
  }
96
96
  }
97
97
  subscribeOverlayDetach() {
98
- const openedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.slice(this.originOverlays.length);
98
+ const openedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.filter(overlay => !this.originOverlays.includes(overlay));
99
99
  const overlaysDetachments$ = openedOverlays.map(overlay => overlay.detachments());
100
100
  if (overlaysDetachments$.length) {
101
101
  combineLatest(overlaysDetachments$)
@@ -172,4 +172,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
172
172
  type: HostBinding,
173
173
  args: ['style.grid-column']
174
174
  }] } });
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-item.component.js","sourceRoot":"","sources":["../../../../src/property/property-item.component.ts","../../../../src/property/property-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThyClickDispatcher } from 'ngx-tethys/core';\nimport { ThyFlexibleText } from 'ngx-tethys/flexible-text';\nimport { combineLatest, fromEvent, Subject, Subscription, timer } from 'rxjs';\nimport { delay, filter, take, takeUntil } from 'rxjs/operators';\n\nimport { OverlayOutsideClickDispatcher, OverlayRef } from '@angular/cdk/overlay';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgZone,\n    numberAttribute,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    inject\n} from '@angular/core';\n\nimport { ThyProperties } from './properties.component';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nexport type ThyPropertyItemOperationTrigger = 'hover' | 'always';\n\n/**\n * 属性组件\n * @name thy-property-item\n */\n@Component({\n    selector: 'thy-property-item',\n    templateUrl: './property-item.component.html',\n    host: {\n        class: 'thy-property-item',\n        '[class.thy-property-item-operational]': '!!operation',\n        '[class.thy-property-item-operational-hover]': \"thyOperationTrigger === 'hover'\"\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [ThyFlexibleText, NgTemplateOutlet]\n})\nexport class ThyPropertyItem implements OnInit, OnChanges, OnDestroy {\n    private cdr = inject(ChangeDetectorRef);\n    private clickDispatcher = inject(ThyClickDispatcher);\n    private ngZone = inject(NgZone);\n    private overlayOutsideClickDispatcher = inject(OverlayOutsideClickDispatcher);\n    private parent = inject(ThyProperties);\n\n    /**\n     * 属性名称\n     * @type sting\n     * @default thyLabelText\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 设置属性是否是可编辑的\n     * @type sting\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty }) thyEditable: boolean;\n\n    /**\n     * 设置跨列的数量\n     * @type number\n     */\n    @Input({ transform: numberAttribute }) thySpan: number = 1;\n\n    /**\n     * 设置属性操作现实触发方式，默认 always 一直显示\n     * @type 'hover' | 'always'\n     */\n    @Input() thyOperationTrigger: ThyPropertyItemOperationTrigger = 'always';\n\n    @Output() thyEditingChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /**\n     * 属性名称自定义模板\n     * @type TemplateRef\n     */\n    @ContentChild('label', { static: true }) label!: TemplateRef<void>;\n\n    /**\n     * 属性内容编辑模板，只有在 thyEditable 为 true 时生效\n     * @type TemplateRef\n     */\n    @ContentChild('editor', { static: true }) editor!: TemplateRef<void>;\n\n    /**\n     * 操作区模板\n     * @type TemplateRef\n     */\n    @ContentChild('operation', { static: true }) operation!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild('contentTemplate', { static: true }) content!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild('item', { static: true }) itemContent: ElementRef<HTMLElement>;\n\n    editing: boolean;\n\n    changes$ = new Subject<SimpleChanges>();\n\n    private destroy$ = new Subject<void>();\n\n    private eventDestroy$ = new Subject<void>();\n\n    private originOverlays: OverlayRef[] = [];\n\n    private clickEventSubscription: Subscription;\n\n    @HostBinding('style.grid-column')\n    get gridColumn() {\n        return `span ${Math.min(this.thySpan, this.parent.thyColumn)}`;\n    }\n\n    isVertical = false;\n\n    constructor() {\n        this.originOverlays = [...this.overlayOutsideClickDispatcher._attachedOverlays] as OverlayRef[];\n    }\n\n    ngOnInit() {\n        this.subscribeClick();\n        this.parent.layout$.pipe(takeUntil(this.destroy$)).subscribe(layout => {\n            this.isVertical = layout === 'vertical';\n            this.cdr.markForCheck();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.thyEditable && changes.thyEditable.currentValue) {\n            this.subscribeClick();\n        } else {\n            this.setEditing(false);\n            this.eventDestroy$.next();\n            this.eventDestroy$.complete();\n\n            if (this.clickEventSubscription) {\n                this.clickEventSubscription.unsubscribe();\n                this.clickEventSubscription = null;\n            }\n        }\n    }\n\n    setEditing(editing: boolean) {\n        this.ngZone.run(() => {\n            if (!!this.editing !== !!editing) {\n                this.thyEditingChange.emit(editing);\n            }\n            this.editing = editing;\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * @deprecated please use setEditing(editing: boolean)\n     */\n    setKeepEditing(keep: boolean) {\n        this.setEditing(keep);\n    }\n\n    private hasOverlay() {\n        return this.overlayOutsideClickDispatcher._attachedOverlays.length > this.originOverlays.length;\n    }\n\n    private subscribeClick() {\n        if (this.thyEditable === true) {\n            this.ngZone.runOutsideAngular(() => {\n                if (this.clickEventSubscription) {\n                    return;\n                }\n                this.clickEventSubscription = fromEvent(this.itemContent.nativeElement, 'click')\n                    .pipe(takeUntil(this.eventDestroy$))\n                    .subscribe(() => {\n                        this.setEditing(true);\n                        this.bindEditorBlurEvent(this.itemContent.nativeElement);\n                    });\n            });\n        }\n    }\n\n    private subscribeOverlayDetach() {\n        const openedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.slice(this.originOverlays.length);\n        const overlaysDetachments$ = openedOverlays.map(overlay => overlay.detachments());\n        if (overlaysDetachments$.length) {\n            combineLatest(overlaysDetachments$)\n                .pipe(delay(50), take(1), takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.setEditing(false);\n                });\n        }\n    }\n\n    private subscribeDocumentClick(editorElement: HTMLElement) {\n        this.clickDispatcher\n            .clicked(0)\n            .pipe(\n                filter(event => {\n                    return !editorElement.contains(event.target as HTMLElement);\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private bindEditorBlurEvent(editorElement: HTMLElement) {\n        timer(0).subscribe(() => {\n            if (this.hasOverlay()) {\n                this.subscribeOverlayDetach();\n            } else {\n                this.subscribeDocumentClick(editorElement);\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n\n        this.eventDestroy$.next();\n        this.eventDestroy$.complete();\n    }\n}\n","<ng-template #contentTemplate>\n  <ng-content></ng-content>\n</ng-template>\n<div class=\"thy-property-item-label\">\n  @if (thyLabelText) {\n    <span thyFlexibleText [thyTooltipContent]=\"thyLabelText\">{{ thyLabelText }}</span>\n  }\n  @if (label) {\n    <span> <ng-template [ngTemplateOutlet]=\"label\"></ng-template></span>\n  }\n  @if (operation && isVertical) {\n    <div class=\"thy-property-item-operation\">\n      <ng-template [ngTemplateOutlet]=\"operation\"></ng-template>\n    </div>\n  }\n</div>\n<div class=\"thy-property-item-wrapper\">\n  <div\n    #item\n    class=\"thy-property-item-content\"\n    [class.thy-property-item-content-editable]=\"thyEditable\"\n    [class.thy-property-item-content-editing]=\"editing\">\n    <div class=\"thy-property-item-content-text\">\n      @if (content) {\n        <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n      }\n    </div>\n    @if (thyEditable) {\n      <div class=\"thy-property-item-content-editor\">\n        @if (editor) {\n          <ng-template [ngTemplateOutlet]=\"editor\"></ng-template>\n        }\n      </div>\n    }\n  </div>\n  @if (operation && !isVertical) {\n    <div class=\"thy-property-item-operation\">\n      <ng-template [ngTemplateOutlet]=\"operation\"></ng-template>\n    </div>\n  }\n</div>\n"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-item.component.js","sourceRoot":"","sources":["../../../../src/property/property-item.component.ts","../../../../src/property/property-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThyClickDispatcher } from 'ngx-tethys/core';\nimport { ThyFlexibleText } from 'ngx-tethys/flexible-text';\nimport { combineLatest, fromEvent, Subject, Subscription, timer } from 'rxjs';\nimport { delay, filter, take, takeUntil } from 'rxjs/operators';\n\nimport { OverlayOutsideClickDispatcher, OverlayRef } from '@angular/cdk/overlay';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgZone,\n    numberAttribute,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    inject\n} from '@angular/core';\n\nimport { ThyProperties } from './properties.component';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nexport type ThyPropertyItemOperationTrigger = 'hover' | 'always';\n\n/**\n * 属性组件\n * @name thy-property-item\n */\n@Component({\n    selector: 'thy-property-item',\n    templateUrl: './property-item.component.html',\n    host: {\n        class: 'thy-property-item',\n        '[class.thy-property-item-operational]': '!!operation',\n        '[class.thy-property-item-operational-hover]': \"thyOperationTrigger === 'hover'\"\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [ThyFlexibleText, NgTemplateOutlet]\n})\nexport class ThyPropertyItem implements OnInit, OnChanges, OnDestroy {\n    private cdr = inject(ChangeDetectorRef);\n    private clickDispatcher = inject(ThyClickDispatcher);\n    private ngZone = inject(NgZone);\n    private overlayOutsideClickDispatcher = inject(OverlayOutsideClickDispatcher);\n    private parent = inject(ThyProperties);\n\n    /**\n     * 属性名称\n     * @type sting\n     * @default thyLabelText\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 设置属性是否是可编辑的\n     * @type sting\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty }) thyEditable: boolean;\n\n    /**\n     * 设置跨列的数量\n     * @type number\n     */\n    @Input({ transform: numberAttribute }) thySpan: number = 1;\n\n    /**\n     * 设置属性操作现实触发方式，默认 always 一直显示\n     * @type 'hover' | 'always'\n     */\n    @Input() thyOperationTrigger: ThyPropertyItemOperationTrigger = 'always';\n\n    @Output() thyEditingChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /**\n     * 属性名称自定义模板\n     * @type TemplateRef\n     */\n    @ContentChild('label', { static: true }) label!: TemplateRef<void>;\n\n    /**\n     * 属性内容编辑模板，只有在 thyEditable 为 true 时生效\n     * @type TemplateRef\n     */\n    @ContentChild('editor', { static: true }) editor!: TemplateRef<void>;\n\n    /**\n     * 操作区模板\n     * @type TemplateRef\n     */\n    @ContentChild('operation', { static: true }) operation!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild('contentTemplate', { static: true }) content!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild('item', { static: true }) itemContent: ElementRef<HTMLElement>;\n\n    editing: boolean;\n\n    changes$ = new Subject<SimpleChanges>();\n\n    private destroy$ = new Subject<void>();\n\n    private eventDestroy$ = new Subject<void>();\n\n    private originOverlays: OverlayRef[] = [];\n\n    private clickEventSubscription: Subscription;\n\n    @HostBinding('style.grid-column')\n    get gridColumn() {\n        return `span ${Math.min(this.thySpan, this.parent.thyColumn)}`;\n    }\n\n    isVertical = false;\n\n    constructor() {\n        this.originOverlays = [...this.overlayOutsideClickDispatcher._attachedOverlays] as OverlayRef[];\n    }\n\n    ngOnInit() {\n        this.subscribeClick();\n        this.parent.layout$.pipe(takeUntil(this.destroy$)).subscribe(layout => {\n            this.isVertical = layout === 'vertical';\n            this.cdr.markForCheck();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.thyEditable && changes.thyEditable.currentValue) {\n            this.subscribeClick();\n        } else {\n            this.setEditing(false);\n            this.eventDestroy$.next();\n            this.eventDestroy$.complete();\n\n            if (this.clickEventSubscription) {\n                this.clickEventSubscription.unsubscribe();\n                this.clickEventSubscription = null;\n            }\n        }\n    }\n\n    setEditing(editing: boolean) {\n        this.ngZone.run(() => {\n            if (!!this.editing !== !!editing) {\n                this.thyEditingChange.emit(editing);\n            }\n            this.editing = editing;\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * @deprecated please use setEditing(editing: boolean)\n     */\n    setKeepEditing(keep: boolean) {\n        this.setEditing(keep);\n    }\n\n    private hasOverlay() {\n        return !!this.overlayOutsideClickDispatcher._attachedOverlays.filter(overlay => !this.originOverlays.includes(overlay)).length;\n    }\n\n    private subscribeClick() {\n        if (this.thyEditable === true) {\n            this.ngZone.runOutsideAngular(() => {\n                if (this.clickEventSubscription) {\n                    return;\n                }\n                this.clickEventSubscription = fromEvent(this.itemContent.nativeElement, 'click')\n                    .pipe(takeUntil(this.eventDestroy$))\n                    .subscribe(() => {\n                        this.setEditing(true);\n                        this.bindEditorBlurEvent(this.itemContent.nativeElement);\n                    });\n            });\n        }\n    }\n\n    private subscribeOverlayDetach() {\n        const openedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.filter(\n            overlay => !this.originOverlays.includes(overlay)\n        );\n        const overlaysDetachments$ = openedOverlays.map(overlay => overlay.detachments());\n        if (overlaysDetachments$.length) {\n            combineLatest(overlaysDetachments$)\n                .pipe(delay(50), take(1), takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.setEditing(false);\n                });\n        }\n    }\n\n    private subscribeDocumentClick(editorElement: HTMLElement) {\n        this.clickDispatcher\n            .clicked(0)\n            .pipe(\n                filter(event => {\n                    return !editorElement.contains(event.target as HTMLElement);\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private bindEditorBlurEvent(editorElement: HTMLElement) {\n        timer(0).subscribe(() => {\n            if (this.hasOverlay()) {\n                this.subscribeOverlayDetach();\n            } else {\n                this.subscribeDocumentClick(editorElement);\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n\n        this.eventDestroy$.next();\n        this.eventDestroy$.complete();\n    }\n}\n","<ng-template #contentTemplate>\n  <ng-content></ng-content>\n</ng-template>\n<div class=\"thy-property-item-label\">\n  @if (thyLabelText) {\n    <span thyFlexibleText [thyTooltipContent]=\"thyLabelText\">{{ thyLabelText }}</span>\n  }\n  @if (label) {\n    <span> <ng-template [ngTemplateOutlet]=\"label\"></ng-template></span>\n  }\n  @if (operation && isVertical) {\n    <div class=\"thy-property-item-operation\">\n      <ng-template [ngTemplateOutlet]=\"operation\"></ng-template>\n    </div>\n  }\n</div>\n<div class=\"thy-property-item-wrapper\">\n  <div\n    #item\n    class=\"thy-property-item-content\"\n    [class.thy-property-item-content-editable]=\"thyEditable\"\n    [class.thy-property-item-content-editing]=\"editing\">\n    <div class=\"thy-property-item-content-text\">\n      @if (content) {\n        <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n      }\n    </div>\n    @if (thyEditable) {\n      <div class=\"thy-property-item-content-editor\">\n        @if (editor) {\n          <ng-template [ngTemplateOutlet]=\"editor\"></ng-template>\n        }\n      </div>\n    }\n  </div>\n  @if (operation && !isVertical) {\n    <div class=\"thy-property-item-operation\">\n      <ng-template [ngTemplateOutlet]=\"operation\"></ng-template>\n    </div>\n  }\n</div>\n"]}
@@ -1,3 +1,3 @@
1
1
  import { Version } from '@angular/core';
2
- export const VERSION = new Version('18.1.0');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVyc2lvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxOC4xLjAnKTtcbiJdfQ==
2
+ export const VERSION = new Version('18.1.1');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVyc2lvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxOC4xLjEnKTtcbiJdfQ==
@@ -1125,7 +1125,7 @@ class ThyAbstractOverlayService {
1125
1125
  }
1126
1126
  else {
1127
1127
  const injector = this.createInjector(config, abstractOverlayRef, containerInstance);
1128
- const contentRef = containerInstance.attachComponentPortal(new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector));
1128
+ const contentRef = containerInstance.attachComponentPortal(new ComponentPortal(componentOrTemplateRef, config.viewContainerRef, injector, undefined, config.projectableNodes));
1129
1129
  if (config.initialState) {
1130
1130
  const metadata = reflectComponentType(componentOrTemplateRef);
1131
1131
  const inputsByTemplateName = keyBy(metadata.inputs, 'templateName');