@wavemaker/app-ng-runtime 11.8.0-next.27310 → 11.8.0-next.27312

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.
@@ -1740,14 +1740,15 @@
1740
1740
  }] }], null); })();
1741
1741
 
1742
1742
  class LazyLoadDirective {
1743
- constructor(inj, templateRef, viewContainer) {
1743
+ constructor(inj, templateRef, viewContainer, explicitContext = {}) {
1744
1744
  this.templateRef = templateRef;
1745
1745
  this.viewContainer = viewContainer;
1746
+ this.context = {};
1746
1747
  let viewParentApp = inj ? inj.get(i1.App) : i0.inject(i1.App);
1747
1748
  let lView = inj._lView;
1748
1749
  this.viewParent = i1.findParent(lView, viewParentApp);
1749
1750
  //this.context = (inj as any).view.context;
1750
- this.context = inj._lView[8];
1751
+ lodashEs.extend(this.context, inj._lView[8], explicitContext);
1751
1752
  }
1752
1753
  set lazyLoad(expr) {
1753
1754
  this.unSubscribeFn = i1.$watch(expr, this.viewParent, this.context, (val) => {
@@ -1760,7 +1761,7 @@
1760
1761
  ngOnDestroy() {
1761
1762
  this.unSubscribeFn();
1762
1763
  }
1763
- static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i0__namespace.TemplateRef), i0__namespace.ɵɵdirectiveInject(i0__namespace.ViewContainerRef)); }; }
1764
+ static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i0__namespace.TemplateRef), i0__namespace.ɵɵdirectiveInject(i0__namespace.ViewContainerRef), i0__namespace.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
1764
1765
  static { this.ɵdir = /*@__PURE__*/ i0__namespace.ɵɵdefineDirective({ type: LazyLoadDirective, selectors: [["", "lazyLoad", ""]], inputs: { lazyLoad: "lazyLoad" } }); }
1765
1766
  }
1766
1767
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0__namespace.ɵsetClassMetadata(LazyLoadDirective, [{
@@ -1768,7 +1769,12 @@
1768
1769
  args: [{
1769
1770
  selector: '[lazyLoad]'
1770
1771
  }]
1771
- }], () => [{ type: i0__namespace.Injector }, { type: i0__namespace.TemplateRef }, { type: i0__namespace.ViewContainerRef }], { lazyLoad: [{
1772
+ }], () => [{ type: i0__namespace.Injector }, { type: i0__namespace.TemplateRef }, { type: i0__namespace.ViewContainerRef }, { type: undefined, decorators: [{
1773
+ type: i0.Inject,
1774
+ args: ['EXPLICIT_CONTEXT']
1775
+ }, {
1776
+ type: i0.Optional
1777
+ }] }], { lazyLoad: [{
1772
1778
  type: i0.Input
1773
1779
  }] }); })();
1774
1780
 
@@ -2082,13 +2088,11 @@
2082
2088
  }] }, { type: i0__namespace.ComponentFactoryResolver }, { type: i1__namespace.PartialRefProvider }], null); })();
2083
2089
 
2084
2090
  class ShowInDeviceDirective {
2085
- constructor(elRef, widget, viewContainerRef, inj, templateRef) {
2086
- this.elRef = elRef;
2087
- this.widget = widget;
2091
+ constructor(viewContainerRef, inj, templateRef, explicitContext) {
2088
2092
  this.viewContainerRef = viewContainerRef;
2089
2093
  this.templateRef = templateRef;
2090
- //this.context = (inj as any).view.context;
2091
- this.context = inj._lView[8];
2094
+ this.context = {};
2095
+ lodashEs.extend(this.context, inj._lView[8], explicitContext);
2092
2096
  window.addEventListener('resize', this.onResize.bind(this));
2093
2097
  }
2094
2098
  set wmShowInDevice(devices) {
@@ -2133,7 +2137,7 @@
2133
2137
  ngOnDestroy() {
2134
2138
  window.removeEventListener('resize', this.onResize);
2135
2139
  }
2136
- static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0__namespace.ɵɵdirectiveInject(i0__namespace.ElementRef), i0__namespace.ɵɵdirectiveInject(WidgetRef), i0__namespace.ɵɵdirectiveInject(i0__namespace.ViewContainerRef), i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i0__namespace.TemplateRef)); }; }
2140
+ static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0__namespace.ɵɵdirectiveInject(i0__namespace.ViewContainerRef), i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i0__namespace.TemplateRef), i0__namespace.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
2137
2141
  static { this.ɵdir = /*@__PURE__*/ i0__namespace.ɵɵdefineDirective({ type: ShowInDeviceDirective, selectors: [["", "wmShowInDevice", ""]], inputs: { wmShowInDevice: "wmShowInDevice" } }); }
2138
2142
  }
2139
2143
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0__namespace.ɵsetClassMetadata(ShowInDeviceDirective, [{
@@ -2141,10 +2145,12 @@
2141
2145
  args: [{
2142
2146
  selector: '[wmShowInDevice]'
2143
2147
  }]
2144
- }], () => [{ type: i0__namespace.ElementRef }, { type: BaseComponent, decorators: [{
2148
+ }], () => [{ type: i0__namespace.ViewContainerRef }, { type: i0__namespace.Injector }, { type: i0__namespace.TemplateRef }, { type: undefined, decorators: [{
2145
2149
  type: i0.Inject,
2146
- args: [WidgetRef]
2147
- }] }, { type: i0__namespace.ViewContainerRef }, { type: i0__namespace.Injector }, { type: i0__namespace.TemplateRef }], { wmShowInDevice: [{
2150
+ args: ['EXPLICIT_CONTEXT']
2151
+ }, {
2152
+ type: i0.Optional
2153
+ }] }], { wmShowInDevice: [{
2148
2154
  type: i0.Input
2149
2155
  }] }); })();
2150
2156
 
@@ -1,18 +1,15 @@
1
- import { ElementRef, ViewContainerRef, Injector, TemplateRef, OnDestroy } from '@angular/core';
2
- import { BaseComponent } from '../widgets/common/base/base.component';
1
+ import { Injector, OnDestroy, TemplateRef, ViewContainerRef } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
3
  export declare class ShowInDeviceDirective implements OnDestroy {
5
- private elRef;
6
- private widget;
7
4
  private viewContainerRef;
8
5
  private templateRef;
9
6
  private readonly context;
10
7
  private devices;
11
8
  private embeddedView;
12
- constructor(elRef: ElementRef, widget: BaseComponent, viewContainerRef: ViewContainerRef, inj: Injector, templateRef: TemplateRef<any>);
9
+ constructor(viewContainerRef: ViewContainerRef, inj: Injector, templateRef: TemplateRef<any>, explicitContext: any);
13
10
  set wmShowInDevice(devices: any);
14
11
  private onResize;
15
12
  ngOnDestroy(): void;
16
- static ɵfac: i0.ɵɵFactoryDeclaration<ShowInDeviceDirective, never>;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<ShowInDeviceDirective, [null, null, null, { optional: true; }]>;
17
14
  static ɵdir: i0.ɵɵDirectiveDeclaration<ShowInDeviceDirective, "[wmShowInDevice]", never, { "wmShowInDevice": { "alias": "wmShowInDevice"; "required": false; }; }, {}, never, never, false, never>;
18
15
  }
@@ -1,17 +1,13 @@
1
- import { Directive, ElementRef, ViewContainerRef, Inject, Input, Injector, TemplateRef } from '@angular/core';
1
+ import { Directive, Inject, Injector, Input, Optional, TemplateRef, ViewContainerRef } from '@angular/core';
2
2
  import { isLargeTabletLandscape, isLargeTabletPortrait } from '@wm/core';
3
- import { WidgetRef } from '../widgets/framework/types';
4
- import { BaseComponent } from '../widgets/common/base/base.component';
3
+ import { extend } from "lodash-es";
5
4
  import * as i0 from "@angular/core";
6
- import * as i1 from "../widgets/common/base/base.component";
7
5
  export class ShowInDeviceDirective {
8
- constructor(elRef, widget, viewContainerRef, inj, templateRef) {
9
- this.elRef = elRef;
10
- this.widget = widget;
6
+ constructor(viewContainerRef, inj, templateRef, explicitContext) {
11
7
  this.viewContainerRef = viewContainerRef;
12
8
  this.templateRef = templateRef;
13
- //this.context = (inj as any).view.context;
14
- this.context = inj._lView[8];
9
+ this.context = {};
10
+ extend(this.context, inj._lView[8], explicitContext);
15
11
  window.addEventListener('resize', this.onResize.bind(this));
16
12
  }
17
13
  set wmShowInDevice(devices) {
@@ -56,7 +52,7 @@ export class ShowInDeviceDirective {
56
52
  ngOnDestroy() {
57
53
  window.removeEventListener('resize', this.onResize);
58
54
  }
59
- static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(WidgetRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef)); }; }
55
+ static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
60
56
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ShowInDeviceDirective, selectors: [["", "wmShowInDevice", ""]], inputs: { wmShowInDevice: "wmShowInDevice" } }); }
61
57
  }
62
58
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ShowInDeviceDirective, [{
@@ -64,10 +60,12 @@ export class ShowInDeviceDirective {
64
60
  args: [{
65
61
  selector: '[wmShowInDevice]'
66
62
  }]
67
- }], () => [{ type: i0.ElementRef }, { type: i1.BaseComponent, decorators: [{
63
+ }], () => [{ type: i0.ViewContainerRef }, { type: i0.Injector }, { type: i0.TemplateRef }, { type: undefined, decorators: [{
68
64
  type: Inject,
69
- args: [WidgetRef]
70
- }] }, { type: i0.ViewContainerRef }, { type: i0.Injector }, { type: i0.TemplateRef }], { wmShowInDevice: [{
65
+ args: ['EXPLICIT_CONTEXT']
66
+ }, {
67
+ type: Optional
68
+ }] }], { wmShowInDevice: [{
71
69
  type: Input
72
70
  }] }); })();
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-in-device.directive.js","sourceRoot":"","sources":["../../../../../projects/components/base/src/directives/show-in-device.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Attribute,\n    Directive,\n    ElementRef,\n    ViewContainerRef,\n    Inject,\n    Input,\n    Injector,\n    TemplateRef,\n    OnDestroy\n} from '@angular/core';\nimport { isLargeTabletLandscape, isLargeTabletPortrait } from '@wm/core';\n\nimport { WidgetRef } from '../widgets/framework/types';\nimport { BaseComponent } from '../widgets/common/base/base.component';\n\n@Directive({\n    selector: '[wmShowInDevice]'\n})\nexport class ShowInDeviceDirective implements OnDestroy {\n    private readonly context;\n    private devices;\n    private embeddedView;\n    constructor(\n        private elRef: ElementRef,\n        @Inject(WidgetRef) private widget: BaseComponent,\n        private viewContainerRef: ViewContainerRef,\n        inj: Injector,\n        private templateRef: TemplateRef<any>\n    ) {\n\n        //this.context = (inj as any).view.context;\n        this.context = (inj as any)._lView[8];\n\n        window.addEventListener('resize', this.onResize.bind(this));\n    }\n    @Input() set wmShowInDevice(devices) {\n        this.devices = devices.split(',');\n        this.onResize();\n    }\n    /*\n    This function handles the rendering of widgets based on the configured showindevice property\n    for the widget.\n    1. For Large Screen, create the view only when min-width is 1200px(except when the viewport is an Ipad Pro 13 inch(Landscape))\n    2. For Laptop/Tablet Landscape, create the view only when either min-width is 992px and max-width is 1199px(except when the viewport is an Ipad Pro 13 inch(Portrait)), or its an Ipad Pro 13 inch(Landscape))\n    3. For Tablet Portrait, create the view only when either min-width is 768px and max-width is 991px, or its an Ipad Pro 13 inch(Portrait))\n    4. For Mobile, create the view only when max-width is 767px.\n    5. For all, always render the view.\n     */\n    private onResize($event?) {\n\n        const lgWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg') || '1200px';\n        const mdWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-md') || '992px';\n        const smWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-sm') || '768px';\n        const lgTabLandScapeWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg-tab-landscape') || '1366px';\n        const lgTabPortraitWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg-tab-portrait') || '1024px';\n        const lgWidthMin = parseFloat(lgWidth)-1;\n        const lgUnit =  lgWidthMin + \"px\";\n        const mdWidthMin = parseFloat(mdWidth)-1;\n        const mdUnit = mdWidthMin + \"px\";\n        const smWidthMin = parseFloat(smWidth)-1;\n        const smUnit = smWidthMin + \"px\";\n        if (\n            (this.devices.indexOf('lg') > -1 && window.matchMedia(\"(min-width: \"+lgWidth+\")\").matches && !isLargeTabletLandscape(lgTabLandScapeWidth, lgTabPortraitWidth))\n            ||  (this.devices.indexOf('md') > -1 && (isLargeTabletLandscape(lgTabLandScapeWidth, lgTabPortraitWidth) || (window.matchMedia(\"(min-width: \"+mdWidth+\") and (max-width: \"+lgUnit +\")\").matches && !isLargeTabletPortrait(lgTabLandScapeWidth, lgTabPortraitWidth))))\n            ||  (this.devices.indexOf('sm') > -1 && (window.matchMedia(\"(min-width: \"+smWidth+\") and (max-width: \"+mdUnit+\")\").matches || isLargeTabletPortrait(lgTabLandScapeWidth, lgTabPortraitWidth)))\n            ||  (this.devices.indexOf('xs') > -1 && window.matchMedia(\"(max-width: \"+smUnit+\")\").matches)\n            ||  (this.devices.indexOf('all') > -1)) {\n            if (!this.embeddedView) {\n                this.embeddedView = this.viewContainerRef.createEmbeddedView(this.templateRef, this.context);\n            }\n        } else {\n            this.viewContainerRef.clear();\n            this.embeddedView = '';\n        }\n\n    }\n\n    ngOnDestroy() {\n        window.removeEventListener('resize', this.onResize);\n    }\n}\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-in-device.directive.js","sourceRoot":"","sources":["../../../../../projects/components/base/src/directives/show-in-device.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Inject, Injector, Input, OnDestroy, Optional, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {isLargeTabletLandscape, isLargeTabletPortrait} from '@wm/core';\nimport {extend} from \"lodash-es\";\n\n@Directive({\n    selector: '[wmShowInDevice]'\n})\nexport class ShowInDeviceDirective implements OnDestroy {\n    private readonly context = {};\n    private devices;\n    private embeddedView;\n    constructor(\n        private viewContainerRef: ViewContainerRef,\n        inj: Injector,\n        private templateRef: TemplateRef<any>,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        extend(this.context, (inj as any)._lView[8], explicitContext);\n\n        window.addEventListener('resize', this.onResize.bind(this));\n    }\n    @Input() set wmShowInDevice(devices) {\n        this.devices = devices.split(',');\n        this.onResize();\n    }\n    /*\n    This function handles the rendering of widgets based on the configured showindevice property\n    for the widget.\n    1. For Large Screen, create the view only when min-width is 1200px(except when the viewport is an Ipad Pro 13 inch(Landscape))\n    2. For Laptop/Tablet Landscape, create the view only when either min-width is 992px and max-width is 1199px(except when the viewport is an Ipad Pro 13 inch(Portrait)), or its an Ipad Pro 13 inch(Landscape))\n    3. For Tablet Portrait, create the view only when either min-width is 768px and max-width is 991px, or its an Ipad Pro 13 inch(Portrait))\n    4. For Mobile, create the view only when max-width is 767px.\n    5. For all, always render the view.\n     */\n    private onResize($event?) {\n\n        const lgWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg') || '1200px';\n        const mdWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-md') || '992px';\n        const smWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-sm') || '768px';\n        const lgTabLandScapeWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg-tab-landscape') || '1366px';\n        const lgTabPortraitWidth = getComputedStyle(document.documentElement).getPropertyValue('--screen-lg-tab-portrait') || '1024px';\n        const lgWidthMin = parseFloat(lgWidth)-1;\n        const lgUnit =  lgWidthMin + \"px\";\n        const mdWidthMin = parseFloat(mdWidth)-1;\n        const mdUnit = mdWidthMin + \"px\";\n        const smWidthMin = parseFloat(smWidth)-1;\n        const smUnit = smWidthMin + \"px\";\n        if (\n            (this.devices.indexOf('lg') > -1 && window.matchMedia(\"(min-width: \"+lgWidth+\")\").matches && !isLargeTabletLandscape(lgTabLandScapeWidth, lgTabPortraitWidth))\n            ||  (this.devices.indexOf('md') > -1 && (isLargeTabletLandscape(lgTabLandScapeWidth, lgTabPortraitWidth) || (window.matchMedia(\"(min-width: \"+mdWidth+\") and (max-width: \"+lgUnit +\")\").matches && !isLargeTabletPortrait(lgTabLandScapeWidth, lgTabPortraitWidth))))\n            ||  (this.devices.indexOf('sm') > -1 && (window.matchMedia(\"(min-width: \"+smWidth+\") and (max-width: \"+mdUnit+\")\").matches || isLargeTabletPortrait(lgTabLandScapeWidth, lgTabPortraitWidth)))\n            ||  (this.devices.indexOf('xs') > -1 && window.matchMedia(\"(max-width: \"+smUnit+\")\").matches)\n            ||  (this.devices.indexOf('all') > -1)) {\n            if (!this.embeddedView) {\n                this.embeddedView = this.viewContainerRef.createEmbeddedView(this.templateRef, this.context);\n            }\n        } else {\n            this.viewContainerRef.clear();\n            this.embeddedView = '';\n        }\n\n    }\n\n    ngOnDestroy() {\n        window.removeEventListener('resize', this.onResize);\n    }\n}\n"]}
@@ -1,15 +1,17 @@
1
- import { Directive, inject, Injector, Input, TemplateRef, ViewContainerRef } from '@angular/core';
1
+ import { Directive, Inject, inject, Injector, Input, Optional, TemplateRef, ViewContainerRef } from '@angular/core';
2
2
  import { $watch, App, findParent } from '@wm/core';
3
+ import { extend } from "lodash-es";
3
4
  import * as i0 from "@angular/core";
4
5
  export class LazyLoadDirective {
5
- constructor(inj, templateRef, viewContainer) {
6
+ constructor(inj, templateRef, viewContainer, explicitContext = {}) {
6
7
  this.templateRef = templateRef;
7
8
  this.viewContainer = viewContainer;
9
+ this.context = {};
8
10
  let viewParentApp = inj ? inj.get(App) : inject(App);
9
11
  let lView = inj._lView;
10
12
  this.viewParent = findParent(lView, viewParentApp);
11
13
  //this.context = (inj as any).view.context;
12
- this.context = inj._lView[8];
14
+ extend(this.context, inj._lView[8], explicitContext);
13
15
  }
14
16
  set lazyLoad(expr) {
15
17
  this.unSubscribeFn = $watch(expr, this.viewParent, this.context, (val) => {
@@ -22,7 +24,7 @@ export class LazyLoadDirective {
22
24
  ngOnDestroy() {
23
25
  this.unSubscribeFn();
24
26
  }
25
- static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef)); }; }
27
+ static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
26
28
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: LazyLoadDirective, selectors: [["", "lazyLoad", ""]], inputs: { lazyLoad: "lazyLoad" } }); }
27
29
  }
28
30
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LazyLoadDirective, [{
@@ -30,7 +32,12 @@ export class LazyLoadDirective {
30
32
  args: [{
31
33
  selector: '[lazyLoad]'
32
34
  }]
33
- }], () => [{ type: i0.Injector }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }], { lazyLoad: [{
35
+ }], () => [{ type: i0.Injector }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
36
+ type: Inject,
37
+ args: ['EXPLICIT_CONTEXT']
38
+ }, {
39
+ type: Optional
40
+ }] }], { lazyLoad: [{
34
41
  type: Input
35
42
  }] }); })();
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1sb2FkLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvYmFzZS9zcmMvd2lkZ2V0cy9jb21tb24vbGF6eS1sb2FkL2xhenktbG9hZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBdUIsV0FBVyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXJILE9BQU8sRUFBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBQyxNQUFNLFVBQVUsQ0FBQzs7QUFLakQsTUFBTSxPQUFPLGlCQUFpQjtJQU0xQixZQUNJLEdBQWEsRUFDTCxXQUE2QixFQUM3QixhQUErQjtRQUQvQixnQkFBVyxHQUFYLFdBQVcsQ0FBa0I7UUFDN0Isa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBRXZDLElBQUksYUFBYSxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3JELElBQUksS0FBSyxHQUFJLEdBQVcsQ0FBQyxNQUFNLENBQUM7UUFDaEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUMsS0FBSyxFQUFFLGFBQWEsQ0FBQyxDQUFBO1FBQ2xELDJDQUEyQztRQUMzQyxJQUFJLENBQUMsT0FBTyxHQUFJLEdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELElBQ0ksUUFBUSxDQUFDLElBQUk7UUFDYixJQUFJLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FDdkIsSUFBSSxFQUNKLElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLE9BQU8sRUFDWixDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQzVCLElBQUksQ0FBQyxZQUFZLEdBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztnQkFDM0YsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3pCLENBQUM7UUFDTCxDQUFDLENBQ0osQ0FBQztJQUNOLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pCLENBQUM7a0ZBbkNRLGlCQUFpQjtvRUFBakIsaUJBQWlCOztpRkFBakIsaUJBQWlCO2NBSDdCLFNBQVM7ZUFBQztnQkFDUCxRQUFRLEVBQUUsWUFBWTthQUN6QjtrR0FvQk8sUUFBUTtrQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIGluamVjdCwgSW5qZWN0b3IsIElucHV0LCBPbkRlc3Ryb3ksIE9wdGlvbmFsLCBUZW1wbGF0ZVJlZiwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7JHdhdGNoLCBBcHAsIGZpbmRQYXJlbnR9IGZyb20gJ0B3bS9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbbGF6eUxvYWRdJ1xufSlcbmV4cG9ydCBjbGFzcyBMYXp5TG9hZERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gICAgcHJpdmF0ZSByZWFkb25seSB2aWV3UGFyZW50OiBhbnk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjb250ZXh0O1xuICAgIHByaXZhdGUgZW1iZWRkZWRWaWV3O1xuICAgIHByaXZhdGUgdW5TdWJzY3JpYmVGbjogRnVuY3Rpb247XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgaW5qOiBJbmplY3RvcixcbiAgICAgICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmXG4gICAgKSB7XG4gICAgICAgIGxldCB2aWV3UGFyZW50QXBwID0gaW5qID8gaW5qLmdldChBcHApIDogaW5qZWN0KEFwcCk7XG4gICAgICAgIGxldCBsVmlldyA9IChpbmogYXMgYW55KS5fbFZpZXc7XG4gICAgICAgIHRoaXMudmlld1BhcmVudCA9IGZpbmRQYXJlbnQobFZpZXcsIHZpZXdQYXJlbnRBcHApXG4gICAgICAgIC8vdGhpcy5jb250ZXh0ID0gKGluaiBhcyBhbnkpLnZpZXcuY29udGV4dDtcbiAgICAgICAgdGhpcy5jb250ZXh0ID0gKGluaiBhcyBhbnkpLl9sVmlld1s4XTtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBsYXp5TG9hZChleHByKSB7XG4gICAgICAgIHRoaXMudW5TdWJzY3JpYmVGbiA9ICR3YXRjaChcbiAgICAgICAgICAgIGV4cHIsXG4gICAgICAgICAgICB0aGlzLnZpZXdQYXJlbnQsXG4gICAgICAgICAgICB0aGlzLmNvbnRleHQsXG4gICAgICAgICAgICAodmFsKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKCF0aGlzLmVtYmVkZGVkVmlldyAmJiB2YWwpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5lbWJlZGRlZFZpZXcgID0gdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmLCB0aGlzLmNvbnRleHQpO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnVuU3Vic2NyaWJlRm4oKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKSB7XG4gICAgICAgIHRoaXMudW5TdWJzY3JpYmVGbigpO1xuICAgIH1cbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1sb2FkLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvYmFzZS9zcmMvd2lkZ2V0cy9jb21tb24vbGF6eS1sb2FkL2xhenktbG9hZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxNQUFNLEVBQ04sTUFBTSxFQUNOLFFBQVEsRUFDUixLQUFLLEVBRUwsUUFBUSxFQUNSLFdBQVcsRUFDWCxnQkFBZ0IsRUFDbkIsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFDLE1BQU0sVUFBVSxDQUFDO0FBQ2pELE9BQU8sRUFBQyxNQUFNLEVBQUMsTUFBTSxXQUFXLENBQUM7O0FBS2pDLE1BQU0sT0FBTyxpQkFBaUI7SUFNMUIsWUFDSSxHQUFhLEVBQ0wsV0FBNkIsRUFDN0IsYUFBK0IsRUFDQyxrQkFBdUIsRUFBRTtRQUZ6RCxnQkFBVyxHQUFYLFdBQVcsQ0FBa0I7UUFDN0Isa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBUDFCLFlBQU8sR0FBRyxFQUFFLENBQUM7UUFVMUIsSUFBSSxhQUFhLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDckQsSUFBSSxLQUFLLEdBQUksR0FBVyxDQUFDLE1BQU0sQ0FBQztRQUNoQyxJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUE7UUFDbEQsMkNBQTJDO1FBQzNDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFHLEdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUVELElBQ0ksUUFBUSxDQUFDLElBQUk7UUFDYixJQUFJLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FDdkIsSUFBSSxFQUNKLElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLE9BQU8sRUFDWixDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQzVCLElBQUksQ0FBQyxZQUFZLEdBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztnQkFDM0YsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3pCLENBQUM7UUFDTCxDQUFDLENBQ0osQ0FBQztJQUNOLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pCLENBQUM7a0ZBcENRLGlCQUFpQiwySUFVZCxrQkFBa0I7b0VBVnJCLGlCQUFpQjs7aUZBQWpCLGlCQUFpQjtjQUg3QixTQUFTO2VBQUM7Z0JBQ1AsUUFBUSxFQUFFLFlBQVk7YUFDekI7O3NCQVdRLE1BQU07dUJBQUMsa0JBQWtCOztzQkFBRyxRQUFRO3FCQVVyQyxRQUFRO2tCQURYLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIERpcmVjdGl2ZSxcbiAgICBJbmplY3QsXG4gICAgaW5qZWN0LFxuICAgIEluamVjdG9yLFxuICAgIElucHV0LFxuICAgIE9uRGVzdHJveSxcbiAgICBPcHRpb25hbCxcbiAgICBUZW1wbGF0ZVJlZixcbiAgICBWaWV3Q29udGFpbmVyUmVmXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyR3YXRjaCwgQXBwLCBmaW5kUGFyZW50fSBmcm9tICdAd20vY29yZSc7XG5pbXBvcnQge2V4dGVuZH0gZnJvbSBcImxvZGFzaC1lc1wiO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tsYXp5TG9hZF0nXG59KVxuZXhwb3J0IGNsYXNzIExhenlMb2FkRGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHZpZXdQYXJlbnQ6IGFueTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRleHQgPSB7fTtcbiAgICBwcml2YXRlIGVtYmVkZGVkVmlldztcbiAgICBwcml2YXRlIHVuU3Vic2NyaWJlRm46IEZ1bmN0aW9uO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIGluajogSW5qZWN0b3IsXG4gICAgICAgIHByaXZhdGUgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT4sXG4gICAgICAgIHByaXZhdGUgdmlld0NvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICAgQEluamVjdCgnRVhQTElDSVRfQ09OVEVYVCcpIEBPcHRpb25hbCgpIGV4cGxpY2l0Q29udGV4dDogYW55ID0ge31cbiAgICApIHtcbiAgICAgICAgbGV0IHZpZXdQYXJlbnRBcHAgPSBpbmogPyBpbmouZ2V0KEFwcCkgOiBpbmplY3QoQXBwKTtcbiAgICAgICAgbGV0IGxWaWV3ID0gKGluaiBhcyBhbnkpLl9sVmlldztcbiAgICAgICAgdGhpcy52aWV3UGFyZW50ID0gZmluZFBhcmVudChsVmlldywgdmlld1BhcmVudEFwcClcbiAgICAgICAgLy90aGlzLmNvbnRleHQgPSAoaW5qIGFzIGFueSkudmlldy5jb250ZXh0O1xuICAgICAgICBleHRlbmQodGhpcy5jb250ZXh0LCAoaW5qIGFzIGFueSkuX2xWaWV3WzhdLCBleHBsaWNpdENvbnRleHQpO1xuICAgIH1cblxuICAgIEBJbnB1dCgpXG4gICAgc2V0IGxhenlMb2FkKGV4cHIpIHtcbiAgICAgICAgdGhpcy51blN1YnNjcmliZUZuID0gJHdhdGNoKFxuICAgICAgICAgICAgZXhwcixcbiAgICAgICAgICAgIHRoaXMudmlld1BhcmVudCxcbiAgICAgICAgICAgIHRoaXMuY29udGV4dCxcbiAgICAgICAgICAgICh2YWwpID0+IHtcbiAgICAgICAgICAgICAgICBpZiAoIXRoaXMuZW1iZWRkZWRWaWV3ICYmIHZhbCkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmVtYmVkZGVkVmlldyAgPSB0aGlzLnZpZXdDb250YWluZXIuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMudGVtcGxhdGVSZWYsIHRoaXMuY29udGV4dCk7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMudW5TdWJzY3JpYmVGbigpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpIHtcbiAgICAgICAgdGhpcy51blN1YnNjcmliZUZuKCk7XG4gICAgfVxufVxuIl19
@@ -1735,14 +1735,15 @@ class RepeatTemplateDirective extends StylableComponent {
1735
1735
  }] }], null); })();
1736
1736
 
1737
1737
  class LazyLoadDirective {
1738
- constructor(inj, templateRef, viewContainer) {
1738
+ constructor(inj, templateRef, viewContainer, explicitContext = {}) {
1739
1739
  this.templateRef = templateRef;
1740
1740
  this.viewContainer = viewContainer;
1741
+ this.context = {};
1741
1742
  let viewParentApp = inj ? inj.get(App) : inject(App);
1742
1743
  let lView = inj._lView;
1743
1744
  this.viewParent = findParent(lView, viewParentApp);
1744
1745
  //this.context = (inj as any).view.context;
1745
- this.context = inj._lView[8];
1746
+ extend(this.context, inj._lView[8], explicitContext);
1746
1747
  }
1747
1748
  set lazyLoad(expr) {
1748
1749
  this.unSubscribeFn = $watch(expr, this.viewParent, this.context, (val) => {
@@ -1755,7 +1756,7 @@ class LazyLoadDirective {
1755
1756
  ngOnDestroy() {
1756
1757
  this.unSubscribeFn();
1757
1758
  }
1758
- static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef)); }; }
1759
+ static { this.ɵfac = function LazyLoadDirective_Factory(t) { return new (t || LazyLoadDirective)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
1759
1760
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: LazyLoadDirective, selectors: [["", "lazyLoad", ""]], inputs: { lazyLoad: "lazyLoad" } }); }
1760
1761
  }
1761
1762
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LazyLoadDirective, [{
@@ -1763,7 +1764,12 @@ class LazyLoadDirective {
1763
1764
  args: [{
1764
1765
  selector: '[lazyLoad]'
1765
1766
  }]
1766
- }], () => [{ type: i0.Injector }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }], { lazyLoad: [{
1767
+ }], () => [{ type: i0.Injector }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
1768
+ type: Inject,
1769
+ args: ['EXPLICIT_CONTEXT']
1770
+ }, {
1771
+ type: Optional
1772
+ }] }], { lazyLoad: [{
1767
1773
  type: Input
1768
1774
  }] }); })();
1769
1775
 
@@ -2077,13 +2083,11 @@ class PartialContainerDirective {
2077
2083
  }] }, { type: i0.ComponentFactoryResolver }, { type: i1.PartialRefProvider }], null); })();
2078
2084
 
2079
2085
  class ShowInDeviceDirective {
2080
- constructor(elRef, widget, viewContainerRef, inj, templateRef) {
2081
- this.elRef = elRef;
2082
- this.widget = widget;
2086
+ constructor(viewContainerRef, inj, templateRef, explicitContext) {
2083
2087
  this.viewContainerRef = viewContainerRef;
2084
2088
  this.templateRef = templateRef;
2085
- //this.context = (inj as any).view.context;
2086
- this.context = inj._lView[8];
2089
+ this.context = {};
2090
+ extend(this.context, inj._lView[8], explicitContext);
2087
2091
  window.addEventListener('resize', this.onResize.bind(this));
2088
2092
  }
2089
2093
  set wmShowInDevice(devices) {
@@ -2128,7 +2132,7 @@ class ShowInDeviceDirective {
2128
2132
  ngOnDestroy() {
2129
2133
  window.removeEventListener('resize', this.onResize);
2130
2134
  }
2131
- static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(WidgetRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef)); }; }
2135
+ static { this.ɵfac = function ShowInDeviceDirective_Factory(t) { return new (t || ShowInDeviceDirective)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
2132
2136
  static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ShowInDeviceDirective, selectors: [["", "wmShowInDevice", ""]], inputs: { wmShowInDevice: "wmShowInDevice" } }); }
2133
2137
  }
2134
2138
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ShowInDeviceDirective, [{
@@ -2136,10 +2140,12 @@ class ShowInDeviceDirective {
2136
2140
  args: [{
2137
2141
  selector: '[wmShowInDevice]'
2138
2142
  }]
2139
- }], () => [{ type: i0.ElementRef }, { type: BaseComponent, decorators: [{
2143
+ }], () => [{ type: i0.ViewContainerRef }, { type: i0.Injector }, { type: i0.TemplateRef }, { type: undefined, decorators: [{
2140
2144
  type: Inject,
2141
- args: [WidgetRef]
2142
- }] }, { type: i0.ViewContainerRef }, { type: i0.Injector }, { type: i0.TemplateRef }], { wmShowInDevice: [{
2145
+ args: ['EXPLICIT_CONTEXT']
2146
+ }, {
2147
+ type: Optional
2148
+ }] }], { wmShowInDevice: [{
2143
2149
  type: Input
2144
2150
  }] }); })();
2145
2151