survey-angular-ui 2.3.11 → 2.3.13

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.
@@ -1,11 +1,13 @@
1
- import { EmbeddedViewRef, OnInit, TemplateRef, ViewContainerRef } from "@angular/core";
1
+ import { AfterViewChecked, DoCheck, EmbeddedViewRef, OnInit, TemplateRef, ViewContainerRef } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
- export declare class EmbeddedViewContentComponent implements OnInit {
3
+ export declare class EmbeddedViewContentComponent implements OnInit, AfterViewChecked, DoCheck {
4
4
  protected viewContainerRef?: ViewContainerRef | undefined;
5
5
  templateRef: TemplateRef<HTMLElement>;
6
6
  protected embeddedView?: EmbeddedViewRef<HTMLElement>;
7
7
  constructor(viewContainerRef?: ViewContainerRef | undefined);
8
8
  ngOnInit(): void;
9
+ ngDoCheck(): void;
10
+ ngAfterViewChecked(): void;
9
11
  static ɵfac: i0.ɵɵFactoryDeclaration<EmbeddedViewContentComponent, never>;
10
12
  static ɵcmp: i0.ɵɵComponentDeclaration<EmbeddedViewContentComponent, "ng-component", never, {}, {}, never, never>;
11
13
  }
@@ -10,28 +10,33 @@ export class BaseAngular extends EmbeddedViewContentComponent {
10
10
  this.onArrayChangedCallback = (stateElement, options) => {
11
11
  this.update(options.name);
12
12
  };
13
+ this.onPropertyChangedCallback = (stateElement, options) => {
14
+ this.update(options.name);
15
+ };
16
+ this.isUpdatesBlocked = false;
13
17
  }
14
18
  get surveyModel() {
15
19
  return this.getModel().getSurvey();
16
20
  }
17
21
  ngDoCheck() {
22
+ super.ngDoCheck();
18
23
  if (this.previousModel !== this.getModel()) {
19
24
  this.unMakeBaseElementAngular(this.previousModel);
20
25
  this.makeBaseElementAngular(this.getModel());
21
26
  this.onModelChanged();
22
27
  this.previousModel = this.getModel();
23
28
  }
24
- this.setIsRendering(true);
29
+ this.setIsModelRendering(true);
25
30
  }
26
31
  onModelChanged() { }
27
- setIsRendering(val) {
32
+ setIsModelRendering(val) {
28
33
  const model = this.getModel();
29
34
  if (!!model) {
30
35
  model.isRendering = val;
31
36
  }
32
37
  }
33
- getIsRendering() {
34
- const model = this.getModel();
38
+ getIsModelRendering(stateElement) {
39
+ const model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel();
35
40
  return !!model && !!model.isRendering;
36
41
  }
37
42
  ngOnDestroy() {
@@ -40,80 +45,45 @@ export class BaseAngular extends EmbeddedViewContentComponent {
40
45
  this.previousModel = undefined;
41
46
  }
42
47
  isBaseElementSubsribed(stateElement) {
43
- return !!stateElement.__ngImplemented;
44
- }
45
- getBaseElementCallbacks(stateElement) {
46
48
  var _a;
47
- stateElement.__ngSubscribers = (_a = stateElement.__ngSubscribers) !== null && _a !== void 0 ? _a : [];
48
- return (stateElement.__ngSubscribers);
49
+ return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
49
50
  }
50
51
  makeBaseElementAngular(stateElement) {
51
- this.makeBaseElementAngularCallback = () => {
52
+ var _a;
53
+ if (!!stateElement && !this.getIsModelRendering(stateElement)) {
52
54
  this.isModelSubsribed = true;
53
- stateElement.__ngImplemented = true;
54
- stateElement.iteratePropertiesHash((hash, key) => {
55
- var val = hash[key];
56
- if (Array.isArray(val)) {
57
- var val = val;
58
- stateElement.addOnArrayChangedCallback(val, this.onArrayChangedCallback);
59
- }
60
- });
61
- stateElement.setPropertyValueCoreHandler = (hash, key, val) => {
62
- if (hash[key] !== val) {
63
- hash[key] = val;
64
- this.update(key);
65
- }
66
- };
55
+ stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);
56
+ stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
67
57
  stateElement.enableOnElementRerenderedEvent();
68
- };
69
- if (!!stateElement) {
70
- if (!stateElement.__ngImplemented) {
71
- this.makeBaseElementAngularCallback();
72
- }
73
- else {
74
- this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);
75
- }
58
+ stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1;
76
59
  }
77
60
  }
78
61
  unMakeBaseElementAngular(stateElement) {
79
- if (!!stateElement) {
80
- if (this.isModelSubsribed) {
81
- this.isModelSubsribed = false;
82
- stateElement.__ngImplemented = false;
83
- stateElement.setPropertyValueCoreHandler = undefined;
84
- stateElement.iteratePropertiesHash((hash, key) => {
85
- var val = hash[key];
86
- if (Array.isArray(val)) {
87
- var val = val;
88
- stateElement.removeOnArrayChangedCallback(val, this.onArrayChangedCallback);
89
- }
90
- });
91
- stateElement.disableOnElementRerenderedEvent();
92
- const callbacks = this.getBaseElementCallbacks(stateElement);
93
- const callback = callbacks.shift();
94
- callback && callback();
95
- }
96
- else if (this.makeBaseElementAngularCallback) {
97
- const callbacks = this.getBaseElementCallbacks(stateElement);
98
- const index = callbacks.indexOf(this.makeBaseElementAngularCallback);
99
- if (index > -1) {
100
- callbacks.splice(index, 1);
101
- }
62
+ var _a;
63
+ if (!!stateElement && this.isModelSubsribed) {
64
+ this.isModelSubsribed = false;
65
+ stateElement.removeOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
66
+ stateElement.removeOnArrayChangedCallback(this.onArrayChangedCallback);
67
+ stateElement.disableOnElementRerenderedEvent();
68
+ if (((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) - 1 <= 0) {
69
+ delete stateElement.__ngImplementedCount;
102
70
  }
103
71
  }
104
72
  }
105
73
  update(key) {
106
- if (this.getIsRendering())
74
+ if (this.getIsModelRendering() || this.isUpdatesBlocked)
107
75
  return;
108
- this.beforeUpdate();
109
76
  if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {
77
+ this.beforeUpdate();
110
78
  this.detectChanges();
111
79
  this.afterUpdate(true);
112
80
  }
113
81
  else {
82
+ this.isUpdatesBlocked = true;
114
83
  queueMicrotask(() => {
115
84
  if (!this.isDestroyed) {
116
- this.setIsRendering(true);
85
+ this.isUpdatesBlocked = false;
86
+ this.beforeUpdate();
117
87
  this.detectChanges();
118
88
  this.afterUpdate();
119
89
  }
@@ -133,17 +103,18 @@ export class BaseAngular extends EmbeddedViewContentComponent {
133
103
  return true;
134
104
  }
135
105
  beforeUpdate() {
136
- this.setIsRendering(true);
106
+ this.setIsModelRendering(true);
137
107
  }
138
108
  afterUpdate(isSync = false) {
139
- this.setIsRendering(false);
109
+ this.setIsModelRendering(false);
140
110
  const model = this.getModel();
141
111
  if (model && !this.isDestroyed) {
142
112
  model.afterRerender();
143
113
  }
144
114
  }
145
115
  ngAfterViewChecked() {
146
- this.setIsRendering(false);
116
+ super.ngAfterViewChecked();
117
+ this.setIsModelRendering(false);
147
118
  }
148
119
  }
149
120
  BaseAngular.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseAngular, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
@@ -154,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
154
125
  template: ""
155
126
  }]
156
127
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }]; } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-angular.js","sourceRoot":"","sources":["../../src/base-angular.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, DoCheck, OnChanges, OnDestroy, SimpleChange, ViewContainerRef } from \"@angular/core\";\nimport { ArrayChanges, Base, IOnArrayChangedEvent, ISurvey, SurveyModel } from \"survey-core\";\nimport { EmbeddedViewContentComponent } from \"./embedded-view-content.component\";\n\n@Component({\n  template: \"\"\n})\nexport abstract class BaseAngular<T extends Base = Base> extends EmbeddedViewContentComponent implements DoCheck, OnDestroy {\n  constructor(protected changeDetectorRef: ChangeDetectorRef, viewContainerRef?: ViewContainerRef) {\n    super(viewContainerRef);\n  }\n  protected get surveyModel(): ISurvey {\n    return this.getModel().getSurvey();\n  }\n  protected abstract getModel(): T;\n  protected previousModel?: T;\n  private isModelSubsribed: boolean = false;\n\n  public ngDoCheck(): void {\n    if (this.previousModel !== this.getModel()) {\n      this.unMakeBaseElementAngular(this.previousModel);\n      this.makeBaseElementAngular(this.getModel());\n      this.onModelChanged();\n      this.previousModel = this.getModel();\n    }\n    this.setIsRendering(true);\n  }\n\n  protected onModelChanged() { }\n\n  private setIsRendering(val: boolean) {\n    const model = this.getModel();\n    if (!!model) {\n      (<any>model).isRendering = val;\n    }\n  }\n  private getIsRendering() {\n    const model = this.getModel();\n    return !!model && !!(<any>model).isRendering;\n  }\n  private isDestroyed: boolean = false;\n  ngOnDestroy() {\n    this.isDestroyed = true;\n    this.unMakeBaseElementAngular(this.getModel());\n    this.previousModel = undefined;\n  }\n  private makeBaseElementAngularCallback?: () => void;\n  protected isBaseElementSubsribed(stateElement: Base) {\n    return !!(<any>stateElement).__ngImplemented;\n  }\n  private getBaseElementCallbacks(stateElement: Base): Array<() => void> {\n    (<any>stateElement).__ngSubscribers = (<any>stateElement).__ngSubscribers ?? [];\n    return ((<any>stateElement).__ngSubscribers);\n  }\n  private onArrayChangedCallback = (stateElement: Base, options: IOnArrayChangedEvent) => {\n    this.update(options.name);\n  };\n  private makeBaseElementAngular(stateElement: T) {\n    this.makeBaseElementAngularCallback = () => {\n      this.isModelSubsribed = true;\n      (<any>stateElement).__ngImplemented = true;\n      stateElement.iteratePropertiesHash((hash, key) => {\n        var val: any = hash[key];\n        if (Array.isArray(val)) {\n          var val: any = val;\n          stateElement.addOnArrayChangedCallback(val, this.onArrayChangedCallback);\n        }\n      });\n      stateElement.setPropertyValueCoreHandler = (\n        hash: any,\n        key: string,\n        val: any\n      ) => {\n        if (hash[key] !== val) {\n          hash[key] = val;\n          this.update(key);\n        }\n      };\n      stateElement.enableOnElementRerenderedEvent();\n    };\n    if (!!stateElement) {\n      if (!(<any>stateElement).__ngImplemented) {\n        this.makeBaseElementAngularCallback();\n      } else {\n        this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);\n      }\n    }\n  }\n  private unMakeBaseElementAngular(stateElement?: Base) {\n    if (!!stateElement) {\n      if (this.isModelSubsribed) {\n        this.isModelSubsribed = false;\n        (<any>stateElement).__ngImplemented = false;\n        stateElement.setPropertyValueCoreHandler = <any>undefined;\n        stateElement.iteratePropertiesHash((hash, key) => {\n          var val: any = hash[key];\n          if (Array.isArray(val)) {\n            var val: any = val;\n            stateElement.removeOnArrayChangedCallback(val, this.onArrayChangedCallback);\n          }\n        });\n        stateElement.disableOnElementRerenderedEvent();\n        const callbacks = this.getBaseElementCallbacks(stateElement);\n        const callback = callbacks.shift();\n        callback && callback();\n      } else if (this.makeBaseElementAngularCallback) {\n        const callbacks = this.getBaseElementCallbacks(stateElement);\n        const index = callbacks.indexOf(this.makeBaseElementAngularCallback);\n        if (index > -1) {\n          callbacks.splice(index, 1);\n        }\n      }\n    }\n  }\n\n  protected update(key?: string): void {\n    if (this.getIsRendering()) return;\n    this.beforeUpdate();\n    if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {\n      this.detectChanges();\n      this.afterUpdate(true);\n    } else {\n      queueMicrotask(() => {\n        if (!this.isDestroyed) {\n          this.setIsRendering(true);\n          this.detectChanges();\n          this.afterUpdate();\n        }\n      });\n    }\n  }\n  private getChangeDetectorRef() {\n    return this.embeddedView ? this.embeddedView : this.changeDetectorRef;\n  }\n  protected getPropertiesToUpdateSync(): Array<string> {\n    return [];\n  }\n  protected detectChanges() {\n    this.getChangeDetectorRef().detectChanges();\n  }\n\n  protected getShouldReattachChangeDetector(): boolean {\n    return true;\n  }\n\n  protected beforeUpdate(): void {\n    this.setIsRendering(true);\n  }\n  protected afterUpdate(isSync: boolean = false): void {\n    this.setIsRendering(false);\n    const model = this.getModel();\n    if (model && !this.isDestroyed) {\n      model.afterRerender();\n    }\n  }\n  ngAfterViewChecked(): void {\n    this.setIsRendering(false);\n  }\n}"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-angular.js","sourceRoot":"","sources":["../../src/base-angular.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, DoCheck, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Base, IPropertyArrayValueChangedEvent, ISurvey } from \"survey-core\";\nimport { EmbeddedViewContentComponent } from \"./embedded-view-content.component\";\nimport { IPropertyValueChangedEvent } from \"survey-core/typings/src/base\";\n\n@Component({\n  template: \"\"\n})\nexport abstract class BaseAngular<T extends Base = Base> extends EmbeddedViewContentComponent implements DoCheck, OnDestroy {\n  constructor(protected changeDetectorRef: ChangeDetectorRef, viewContainerRef?: ViewContainerRef) {\n    super(viewContainerRef);\n  }\n  protected get surveyModel(): ISurvey {\n    return this.getModel().getSurvey();\n  }\n  protected abstract getModel(): T;\n  protected previousModel?: T;\n  private isModelSubsribed: boolean = false;\n\n  public override ngDoCheck(): void {\n    super.ngDoCheck();\n    if (this.previousModel !== this.getModel()) {\n      this.unMakeBaseElementAngular(this.previousModel);\n      this.makeBaseElementAngular(this.getModel());\n      this.onModelChanged();\n      this.previousModel = this.getModel();\n    }\n    this.setIsModelRendering(true);\n  }\n\n  protected onModelChanged() { }\n\n  private setIsModelRendering(val: boolean) {\n    const model = this.getModel();\n    if (!!model) {\n      (<any>model).isRendering = val;\n    }\n  }\n  private getIsModelRendering(stateElement?: Base) {\n    const model = stateElement ?? this.getModel();\n    return !!model && !!(<any>model).isRendering;\n  }\n  private isDestroyed: boolean = false;\n  ngOnDestroy() {\n    this.isDestroyed = true;\n    this.unMakeBaseElementAngular(this.getModel());\n    this.previousModel = undefined;\n  }\n  protected isBaseElementSubsribed(stateElement: Base) {\n    return ((<any>stateElement).__ngImplementedCount ?? 0) > 0;\n  }\n  private onArrayChangedCallback = (stateElement: Base, options: IPropertyArrayValueChangedEvent) => {\n    this.update(options.name);\n  };\n  private onPropertyChangedCallback = (stateElement: Base, options: IPropertyValueChangedEvent) => {\n    this.update(options.name);\n  };\n  private makeBaseElementAngular(stateElement: T) {\n    if (!!stateElement && !this.getIsModelRendering(stateElement)) {\n      this.isModelSubsribed = true;\n      stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);\n      stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);\n      stateElement.enableOnElementRerenderedEvent();\n      (<any>stateElement).__ngImplementedCount = ((<any>stateElement).__ngImplementedCount ?? 0) + 1;\n    }\n  }\n  private unMakeBaseElementAngular(stateElement?: Base) {\n    if (!!stateElement && this.isModelSubsribed) {\n      this.isModelSubsribed = false;\n      stateElement.removeOnPropertyValueChangedCallback(this.onPropertyChangedCallback);\n      stateElement.removeOnArrayChangedCallback(this.onArrayChangedCallback);\n      stateElement.disableOnElementRerenderedEvent();\n      if (((<any>stateElement).__ngImplementedCount ?? 0) - 1 <= 0) {\n        delete (<any>stateElement).__ngImplementedCount;\n      }\n    }\n  }\n  private isUpdatesBlocked: boolean = false;\n\n  protected update(key?: string): void {\n    if (this.getIsModelRendering() || this.isUpdatesBlocked) return;\n    if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {\n      this.beforeUpdate();\n      this.detectChanges();\n      this.afterUpdate(true);\n    } else {\n      this.isUpdatesBlocked = true;\n      queueMicrotask(() => {\n        if (!this.isDestroyed) {\n          this.isUpdatesBlocked = false;\n          this.beforeUpdate();\n          this.detectChanges();\n          this.afterUpdate();\n        }\n      });\n    }\n  }\n  private getChangeDetectorRef() {\n    return this.embeddedView ? this.embeddedView : this.changeDetectorRef;\n  }\n  protected getPropertiesToUpdateSync(): Array<string> {\n    return [];\n  }\n  protected detectChanges() {\n    this.getChangeDetectorRef().detectChanges();\n  }\n\n  protected getShouldReattachChangeDetector(): boolean {\n    return true;\n  }\n\n  protected beforeUpdate(): void {\n    this.setIsModelRendering(true);\n  }\n  protected afterUpdate(isSync: boolean = false): void {\n    this.setIsModelRendering(false);\n    const model = this.getModel();\n    if (model && !this.isDestroyed) {\n      model.afterRerender();\n    }\n  }\n  override ngAfterViewChecked(): void {\n    super.ngAfterViewChecked();\n    this.setIsModelRendering(false);\n  }\n}"]}
@@ -9,7 +9,7 @@ export class PanelDynamicPrevBtn extends PaneldynamicAction {
9
9
  }
10
10
  }
11
11
  PanelDynamicPrevBtn.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, deps: null, target: i0.ɵɵFactoryTarget.Component });
12
- PanelDynamicPrevBtn.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0, template: "<div [attr.title]=\"question.panelPrevText\" (click)=\"prevPanelClick()\" [class]=\"question.getPrevButtonCss()\">\n <svg [iconName]=\"question.cssClasses.progressBtnIcon\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n</div>\n", components: [{ type: i1.SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }] });
12
+ PanelDynamicPrevBtn.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0, template: "<div [attr.title]=\"question.prevPanelText\" (click)=\"prevPanelClick()\" [class]=\"question.getPrevButtonCss()\">\n <svg [iconName]=\"question.cssClasses.progressBtnIcon\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n</div>\n", components: [{ type: i1.SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }] });
13
13
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, decorators: [{
14
14
  type: Component,
15
15
  args: [{
@@ -18,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
18
18
  }]
19
19
  }] });
20
20
  AngularComponentFactory.Instance.registerComponent("sv-paneldynamic-prev-btn", PanelDynamicPrevBtn);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFuZWxkeW5hbWljLXByZXYtYnRuLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3BhbmVsZHluYW1pYy1hY3Rpb25zL3BhbmVsZHluYW1pYy1wcmV2LWJ0bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wYW5lbGR5bmFtaWMtYWN0aW9ucy9wYW5lbGR5bmFtaWMtcHJldi1idG4uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7O0FBTXRFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxrQkFBa0I7SUFDekQsY0FBYztRQUNaLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDaEMsQ0FBQzs7aUhBSFUsbUJBQW1CO3FHQUFuQixtQkFBbUIsMEZDUmhDLGlPQUdBOzRGREthLG1CQUFtQjtrQkFKL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxXQUFXLEVBQUUsd0NBQXdDO2lCQUN0RDs7QUFNRCx1QkFBdUIsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsMEJBQTBCLEVBQUUsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBBbmd1bGFyQ29tcG9uZW50RmFjdG9yeSB9IGZyb20gXCIuLi8uLi9jb21wb25lbnQtZmFjdG9yeVwiO1xuaW1wb3J0IHsgUGFuZWxkeW5hbWljQWN0aW9uIH0gZnJvbSBcIi4vcGFuZWxkeW5hbWljLWFkZC1idG4uY29tcG9uZW50XCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJzdi1uZy1wYW5lbGR5bmFtaWMtcHJldi1idG5cIixcbiAgdGVtcGxhdGVVcmw6IFwiLi9wYW5lbGR5bmFtaWMtcHJldi1idG4uY29tcG9uZW50Lmh0bWxcIlxufSlcbmV4cG9ydCBjbGFzcyBQYW5lbER5bmFtaWNQcmV2QnRuIGV4dGVuZHMgUGFuZWxkeW5hbWljQWN0aW9uIHtcbiAgcHJldlBhbmVsQ2xpY2soKSB7XG4gICAgdGhpcy5xdWVzdGlvbi5nb1RvUHJldlBhbmVsKCk7XG4gIH1cbn1cbkFuZ3VsYXJDb21wb25lbnRGYWN0b3J5Lkluc3RhbmNlLnJlZ2lzdGVyQ29tcG9uZW50KFwic3YtcGFuZWxkeW5hbWljLXByZXYtYnRuXCIsIFBhbmVsRHluYW1pY1ByZXZCdG4pOyIsIjxkaXYgW2F0dHIudGl0bGVdPVwicXVlc3Rpb24ucGFuZWxQcmV2VGV4dFwiIChjbGljayk9XCJwcmV2UGFuZWxDbGljaygpXCIgW2NsYXNzXT1cInF1ZXN0aW9uLmdldFByZXZCdXR0b25Dc3MoKVwiPlxuICA8c3ZnIFtpY29uTmFtZV09XCJxdWVzdGlvbi5jc3NDbGFzc2VzLnByb2dyZXNzQnRuSWNvblwiIFtzaXplXT1cIidhdXRvJ1wiIHN2LW5nLXN2Zy1pY29uPjwvc3ZnPlxuPC9kaXY+XG4iXX0=
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFuZWxkeW5hbWljLXByZXYtYnRuLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3BhbmVsZHluYW1pYy1hY3Rpb25zL3BhbmVsZHluYW1pYy1wcmV2LWJ0bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wYW5lbGR5bmFtaWMtYWN0aW9ucy9wYW5lbGR5bmFtaWMtcHJldi1idG4uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7O0FBTXRFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxrQkFBa0I7SUFDekQsY0FBYztRQUNaLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDaEMsQ0FBQzs7aUhBSFUsbUJBQW1CO3FHQUFuQixtQkFBbUIsMEZDUmhDLGlPQUdBOzRGREthLG1CQUFtQjtrQkFKL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxXQUFXLEVBQUUsd0NBQXdDO2lCQUN0RDs7QUFNRCx1QkFBdUIsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsMEJBQTBCLEVBQUUsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBBbmd1bGFyQ29tcG9uZW50RmFjdG9yeSB9IGZyb20gXCIuLi8uLi9jb21wb25lbnQtZmFjdG9yeVwiO1xuaW1wb3J0IHsgUGFuZWxkeW5hbWljQWN0aW9uIH0gZnJvbSBcIi4vcGFuZWxkeW5hbWljLWFkZC1idG4uY29tcG9uZW50XCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJzdi1uZy1wYW5lbGR5bmFtaWMtcHJldi1idG5cIixcbiAgdGVtcGxhdGVVcmw6IFwiLi9wYW5lbGR5bmFtaWMtcHJldi1idG4uY29tcG9uZW50Lmh0bWxcIlxufSlcbmV4cG9ydCBjbGFzcyBQYW5lbER5bmFtaWNQcmV2QnRuIGV4dGVuZHMgUGFuZWxkeW5hbWljQWN0aW9uIHtcbiAgcHJldlBhbmVsQ2xpY2soKSB7XG4gICAgdGhpcy5xdWVzdGlvbi5nb1RvUHJldlBhbmVsKCk7XG4gIH1cbn1cbkFuZ3VsYXJDb21wb25lbnRGYWN0b3J5Lkluc3RhbmNlLnJlZ2lzdGVyQ29tcG9uZW50KFwic3YtcGFuZWxkeW5hbWljLXByZXYtYnRuXCIsIFBhbmVsRHluYW1pY1ByZXZCdG4pOyIsIjxkaXYgW2F0dHIudGl0bGVdPVwicXVlc3Rpb24ucHJldlBhbmVsVGV4dFwiIChjbGljayk9XCJwcmV2UGFuZWxDbGljaygpXCIgW2NsYXNzXT1cInF1ZXN0aW9uLmdldFByZXZCdXR0b25Dc3MoKVwiPlxuICA8c3ZnIFtpY29uTmFtZV09XCJxdWVzdGlvbi5jc3NDbGFzc2VzLnByb2dyZXNzQnRuSWNvblwiIFtzaXplXT1cIidhdXRvJ1wiIHN2LW5nLXN2Zy1pY29uPjwvc3ZnPlxuPC9kaXY+XG4iXX0=
@@ -10,6 +10,14 @@ export class EmbeddedViewContentComponent {
10
10
  this.embeddedView = (_a = this.viewContainerRef) === null || _a === void 0 ? void 0 : _a.createEmbeddedView(this.templateRef);
11
11
  }
12
12
  }
13
+ ngDoCheck() {
14
+ var _a;
15
+ (_a = this.embeddedView) === null || _a === void 0 ? void 0 : _a.reattach();
16
+ }
17
+ ngAfterViewChecked() {
18
+ var _a;
19
+ (_a = this.embeddedView) === null || _a === void 0 ? void 0 : _a.detach();
20
+ }
13
21
  }
14
22
  EmbeddedViewContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EmbeddedViewContentComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
15
23
  EmbeddedViewContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EmbeddedViewContentComponent, selector: "ng-component", viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["template"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "", isInline: true });
@@ -22,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
22
30
  type: ViewChild,
23
31
  args: ["template", { read: TemplateRef, static: true }]
24
32
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1iZWRkZWQtdmlldy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbWJlZGRlZC12aWV3LWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQTJCLFdBQVcsRUFBRSxTQUFTLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQU03RyxNQUFNLE9BQU8sNEJBQTRCO0lBR3ZDLFlBQXNCLGdCQUFtQztRQUFuQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQW1CO0lBQUcsQ0FBQztJQUU3RCxRQUFROztRQUNOLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFBLElBQUksQ0FBQyxnQkFBZ0IsMENBQUUsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1NBQ2pGO0lBQ0gsQ0FBQzs7MEhBVFUsNEJBQTRCOzhHQUE1Qiw0QkFBNEIsd0lBQ1IsV0FBVywyQ0FKaEMsRUFBRTs0RkFHRCw0QkFBNEI7a0JBSnhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLEVBQUU7aUJBQ2I7dUdBRzZELFdBQVc7c0JBQXRFLFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbWJlZGRlZFZpZXdSZWYsIE9uSW5pdCwgVGVtcGxhdGVSZWYsIFZpZXdDaGlsZCwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogXCJcIixcbn0pXG5cbmV4cG9ydCBjbGFzcyBFbWJlZGRlZFZpZXdDb250ZW50Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQFZpZXdDaGlsZChcInRlbXBsYXRlXCIsIHsgcmVhZDogVGVtcGxhdGVSZWYsIHN0YXRpYzogdHJ1ZSB9KSB0ZW1wbGF0ZVJlZiE6IFRlbXBsYXRlUmVmPEhUTUxFbGVtZW50PjtcbiAgcHJvdGVjdGVkIGVtYmVkZGVkVmlldz86IEVtYmVkZGVkVmlld1JlZjxIVE1MRWxlbWVudD47XG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCB2aWV3Q29udGFpbmVyUmVmPzogVmlld0NvbnRhaW5lclJlZikge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoISF0aGlzLnRlbXBsYXRlUmVmKSB7XG4gICAgICB0aGlzLmVtYmVkZGVkVmlldyA9IHRoaXMudmlld0NvbnRhaW5lclJlZj8uY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMudGVtcGxhdGVSZWYpO1xuICAgIH1cbiAgfVxufSJdfQ==
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1iZWRkZWQtdmlldy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbWJlZGRlZC12aWV3LWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBb0IsU0FBUyxFQUFvQyxXQUFXLEVBQUUsU0FBUyxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFNeEksTUFBTSxPQUFPLDRCQUE0QjtJQUd2QyxZQUFzQixnQkFBbUM7UUFBbkMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFtQjtJQUFHLENBQUM7SUFFN0QsUUFBUTs7UUFDTixJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3RCLElBQUksQ0FBQyxZQUFZLEdBQUcsTUFBQSxJQUFJLENBQUMsZ0JBQWdCLDBDQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUNqRjtJQUNILENBQUM7SUFDRCxTQUFTOztRQUNQLE1BQUEsSUFBSSxDQUFDLFlBQVksMENBQUUsUUFBUSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUNELGtCQUFrQjs7UUFDaEIsTUFBQSxJQUFJLENBQUMsWUFBWSwwQ0FBRSxNQUFNLEVBQUUsQ0FBQztJQUM5QixDQUFDOzswSEFmVSw0QkFBNEI7OEdBQTVCLDRCQUE0Qix3SUFDUixXQUFXLDJDQUpoQyxFQUFFOzRGQUdELDRCQUE0QjtrQkFKeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsRUFBRTtpQkFDYjt1R0FHNkQsV0FBVztzQkFBdEUsU0FBUzt1QkFBQyxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdDaGVja2VkLCBDb21wb25lbnQsIERvQ2hlY2ssIEVtYmVkZGVkVmlld1JlZiwgT25Jbml0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBcIlwiLFxufSlcblxuZXhwb3J0IGNsYXNzIEVtYmVkZGVkVmlld0NvbnRlbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0NoZWNrZWQsIERvQ2hlY2sge1xuICBAVmlld0NoaWxkKFwidGVtcGxhdGVcIiwgeyByZWFkOiBUZW1wbGF0ZVJlZiwgc3RhdGljOiB0cnVlIH0pIHRlbXBsYXRlUmVmITogVGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+O1xuICBwcm90ZWN0ZWQgZW1iZWRkZWRWaWV3PzogRW1iZWRkZWRWaWV3UmVmPEhUTUxFbGVtZW50PjtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIHZpZXdDb250YWluZXJSZWY/OiBWaWV3Q29udGFpbmVyUmVmKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghIXRoaXMudGVtcGxhdGVSZWYpIHtcbiAgICAgIHRoaXMuZW1iZWRkZWRWaWV3ID0gdGhpcy52aWV3Q29udGFpbmVyUmVmPy5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XG4gICAgfVxuICB9XG4gIG5nRG9DaGVjaygpOiB2b2lkIHtcbiAgICB0aGlzLmVtYmVkZGVkVmlldz8ucmVhdHRhY2goKTtcbiAgfVxuICBuZ0FmdGVyVmlld0NoZWNrZWQoKTogdm9pZCB7XG4gICAgdGhpcy5lbWJlZGRlZFZpZXc/LmRldGFjaCgpO1xuICB9XG59Il19
@@ -21,6 +21,14 @@ class EmbeddedViewContentComponent {
21
21
  this.embeddedView = (_a = this.viewContainerRef) === null || _a === void 0 ? void 0 : _a.createEmbeddedView(this.templateRef);
22
22
  }
23
23
  }
24
+ ngDoCheck() {
25
+ var _a;
26
+ (_a = this.embeddedView) === null || _a === void 0 ? void 0 : _a.reattach();
27
+ }
28
+ ngAfterViewChecked() {
29
+ var _a;
30
+ (_a = this.embeddedView) === null || _a === void 0 ? void 0 : _a.detach();
31
+ }
24
32
  }
25
33
  EmbeddedViewContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EmbeddedViewContentComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
26
34
  EmbeddedViewContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EmbeddedViewContentComponent, selector: "ng-component", viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["template"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "", isInline: true });
@@ -43,28 +51,33 @@ class BaseAngular extends EmbeddedViewContentComponent {
43
51
  this.onArrayChangedCallback = (stateElement, options) => {
44
52
  this.update(options.name);
45
53
  };
54
+ this.onPropertyChangedCallback = (stateElement, options) => {
55
+ this.update(options.name);
56
+ };
57
+ this.isUpdatesBlocked = false;
46
58
  }
47
59
  get surveyModel() {
48
60
  return this.getModel().getSurvey();
49
61
  }
50
62
  ngDoCheck() {
63
+ super.ngDoCheck();
51
64
  if (this.previousModel !== this.getModel()) {
52
65
  this.unMakeBaseElementAngular(this.previousModel);
53
66
  this.makeBaseElementAngular(this.getModel());
54
67
  this.onModelChanged();
55
68
  this.previousModel = this.getModel();
56
69
  }
57
- this.setIsRendering(true);
70
+ this.setIsModelRendering(true);
58
71
  }
59
72
  onModelChanged() { }
60
- setIsRendering(val) {
73
+ setIsModelRendering(val) {
61
74
  const model = this.getModel();
62
75
  if (!!model) {
63
76
  model.isRendering = val;
64
77
  }
65
78
  }
66
- getIsRendering() {
67
- const model = this.getModel();
79
+ getIsModelRendering(stateElement) {
80
+ const model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel();
68
81
  return !!model && !!model.isRendering;
69
82
  }
70
83
  ngOnDestroy() {
@@ -73,80 +86,45 @@ class BaseAngular extends EmbeddedViewContentComponent {
73
86
  this.previousModel = undefined;
74
87
  }
75
88
  isBaseElementSubsribed(stateElement) {
76
- return !!stateElement.__ngImplemented;
77
- }
78
- getBaseElementCallbacks(stateElement) {
79
89
  var _a;
80
- stateElement.__ngSubscribers = (_a = stateElement.__ngSubscribers) !== null && _a !== void 0 ? _a : [];
81
- return (stateElement.__ngSubscribers);
90
+ return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
82
91
  }
83
92
  makeBaseElementAngular(stateElement) {
84
- this.makeBaseElementAngularCallback = () => {
93
+ var _a;
94
+ if (!!stateElement && !this.getIsModelRendering(stateElement)) {
85
95
  this.isModelSubsribed = true;
86
- stateElement.__ngImplemented = true;
87
- stateElement.iteratePropertiesHash((hash, key) => {
88
- var val = hash[key];
89
- if (Array.isArray(val)) {
90
- var val = val;
91
- stateElement.addOnArrayChangedCallback(val, this.onArrayChangedCallback);
92
- }
93
- });
94
- stateElement.setPropertyValueCoreHandler = (hash, key, val) => {
95
- if (hash[key] !== val) {
96
- hash[key] = val;
97
- this.update(key);
98
- }
99
- };
96
+ stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);
97
+ stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
100
98
  stateElement.enableOnElementRerenderedEvent();
101
- };
102
- if (!!stateElement) {
103
- if (!stateElement.__ngImplemented) {
104
- this.makeBaseElementAngularCallback();
105
- }
106
- else {
107
- this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);
108
- }
99
+ stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1;
109
100
  }
110
101
  }
111
102
  unMakeBaseElementAngular(stateElement) {
112
- if (!!stateElement) {
113
- if (this.isModelSubsribed) {
114
- this.isModelSubsribed = false;
115
- stateElement.__ngImplemented = false;
116
- stateElement.setPropertyValueCoreHandler = undefined;
117
- stateElement.iteratePropertiesHash((hash, key) => {
118
- var val = hash[key];
119
- if (Array.isArray(val)) {
120
- var val = val;
121
- stateElement.removeOnArrayChangedCallback(val, this.onArrayChangedCallback);
122
- }
123
- });
124
- stateElement.disableOnElementRerenderedEvent();
125
- const callbacks = this.getBaseElementCallbacks(stateElement);
126
- const callback = callbacks.shift();
127
- callback && callback();
128
- }
129
- else if (this.makeBaseElementAngularCallback) {
130
- const callbacks = this.getBaseElementCallbacks(stateElement);
131
- const index = callbacks.indexOf(this.makeBaseElementAngularCallback);
132
- if (index > -1) {
133
- callbacks.splice(index, 1);
134
- }
103
+ var _a;
104
+ if (!!stateElement && this.isModelSubsribed) {
105
+ this.isModelSubsribed = false;
106
+ stateElement.removeOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
107
+ stateElement.removeOnArrayChangedCallback(this.onArrayChangedCallback);
108
+ stateElement.disableOnElementRerenderedEvent();
109
+ if (((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) - 1 <= 0) {
110
+ delete stateElement.__ngImplementedCount;
135
111
  }
136
112
  }
137
113
  }
138
114
  update(key) {
139
- if (this.getIsRendering())
115
+ if (this.getIsModelRendering() || this.isUpdatesBlocked)
140
116
  return;
141
- this.beforeUpdate();
142
117
  if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {
118
+ this.beforeUpdate();
143
119
  this.detectChanges();
144
120
  this.afterUpdate(true);
145
121
  }
146
122
  else {
123
+ this.isUpdatesBlocked = true;
147
124
  queueMicrotask(() => {
148
125
  if (!this.isDestroyed) {
149
- this.setIsRendering(true);
126
+ this.isUpdatesBlocked = false;
127
+ this.beforeUpdate();
150
128
  this.detectChanges();
151
129
  this.afterUpdate();
152
130
  }
@@ -166,17 +144,18 @@ class BaseAngular extends EmbeddedViewContentComponent {
166
144
  return true;
167
145
  }
168
146
  beforeUpdate() {
169
- this.setIsRendering(true);
147
+ this.setIsModelRendering(true);
170
148
  }
171
149
  afterUpdate(isSync = false) {
172
- this.setIsRendering(false);
150
+ this.setIsModelRendering(false);
173
151
  const model = this.getModel();
174
152
  if (model && !this.isDestroyed) {
175
153
  model.afterRerender();
176
154
  }
177
155
  }
178
156
  ngAfterViewChecked() {
179
- this.setIsRendering(false);
157
+ super.ngAfterViewChecked();
158
+ this.setIsModelRendering(false);
180
159
  }
181
160
  }
182
161
  BaseAngular.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseAngular, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
@@ -3416,7 +3395,7 @@ class PanelDynamicPrevBtn extends PaneldynamicAction {
3416
3395
  }
3417
3396
  }
3418
3397
  PanelDynamicPrevBtn.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, deps: null, target: i0.ɵɵFactoryTarget.Component });
3419
- PanelDynamicPrevBtn.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0, template: "<div [attr.title]=\"question.panelPrevText\" (click)=\"prevPanelClick()\" [class]=\"question.getPrevButtonCss()\">\n <svg [iconName]=\"question.cssClasses.progressBtnIcon\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n</div>\n", components: [{ type: SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }] });
3398
+ PanelDynamicPrevBtn.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0, template: "<div [attr.title]=\"question.prevPanelText\" (click)=\"prevPanelClick()\" [class]=\"question.getPrevButtonCss()\">\n <svg [iconName]=\"question.cssClasses.progressBtnIcon\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n</div>\n", components: [{ type: SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }] });
3420
3399
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, decorators: [{
3421
3400
  type: Component,
3422
3401
  args: [{