survey-angular-ui 2.3.12 → 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.
@@ -10,6 +10,10 @@ 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();
@@ -22,17 +26,17 @@ export class BaseAngular extends EmbeddedViewContentComponent {
22
26
  this.onModelChanged();
23
27
  this.previousModel = this.getModel();
24
28
  }
25
- this.setIsRendering(true);
29
+ this.setIsModelRendering(true);
26
30
  }
27
31
  onModelChanged() { }
28
- setIsRendering(val) {
32
+ setIsModelRendering(val) {
29
33
  const model = this.getModel();
30
34
  if (!!model) {
31
35
  model.isRendering = val;
32
36
  }
33
37
  }
34
- getIsRendering() {
35
- const model = this.getModel();
38
+ getIsModelRendering(stateElement) {
39
+ const model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel();
36
40
  return !!model && !!model.isRendering;
37
41
  }
38
42
  ngOnDestroy() {
@@ -41,80 +45,45 @@ export class BaseAngular extends EmbeddedViewContentComponent {
41
45
  this.previousModel = undefined;
42
46
  }
43
47
  isBaseElementSubsribed(stateElement) {
44
- return !!stateElement.__ngImplemented;
45
- }
46
- getBaseElementCallbacks(stateElement) {
47
48
  var _a;
48
- stateElement.__ngSubscribers = (_a = stateElement.__ngSubscribers) !== null && _a !== void 0 ? _a : [];
49
- return (stateElement.__ngSubscribers);
49
+ return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
50
50
  }
51
51
  makeBaseElementAngular(stateElement) {
52
- this.makeBaseElementAngularCallback = () => {
52
+ var _a;
53
+ if (!!stateElement && !this.getIsModelRendering(stateElement)) {
53
54
  this.isModelSubsribed = true;
54
- stateElement.__ngImplemented = true;
55
- stateElement.iteratePropertiesHash((hash, key) => {
56
- var val = hash[key];
57
- if (Array.isArray(val)) {
58
- var val = val;
59
- stateElement.addOnArrayChangedCallback(val, this.onArrayChangedCallback);
60
- }
61
- });
62
- stateElement.setPropertyValueCoreHandler = (hash, key, val) => {
63
- if (hash[key] !== val) {
64
- hash[key] = val;
65
- this.update(key);
66
- }
67
- };
55
+ stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);
56
+ stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
68
57
  stateElement.enableOnElementRerenderedEvent();
69
- };
70
- if (!!stateElement) {
71
- if (!stateElement.__ngImplemented) {
72
- this.makeBaseElementAngularCallback();
73
- }
74
- else {
75
- this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);
76
- }
58
+ stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1;
77
59
  }
78
60
  }
79
61
  unMakeBaseElementAngular(stateElement) {
80
- if (!!stateElement) {
81
- if (this.isModelSubsribed) {
82
- this.isModelSubsribed = false;
83
- stateElement.__ngImplemented = false;
84
- stateElement.setPropertyValueCoreHandler = undefined;
85
- stateElement.iteratePropertiesHash((hash, key) => {
86
- var val = hash[key];
87
- if (Array.isArray(val)) {
88
- var val = val;
89
- stateElement.removeOnArrayChangedCallback(val, this.onArrayChangedCallback);
90
- }
91
- });
92
- stateElement.disableOnElementRerenderedEvent();
93
- const callbacks = this.getBaseElementCallbacks(stateElement);
94
- const callback = callbacks.shift();
95
- callback && callback();
96
- }
97
- else if (this.makeBaseElementAngularCallback) {
98
- const callbacks = this.getBaseElementCallbacks(stateElement);
99
- const index = callbacks.indexOf(this.makeBaseElementAngularCallback);
100
- if (index > -1) {
101
- callbacks.splice(index, 1);
102
- }
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;
103
70
  }
104
71
  }
105
72
  }
106
73
  update(key) {
107
- if (this.getIsRendering())
74
+ if (this.getIsModelRendering() || this.isUpdatesBlocked)
108
75
  return;
109
- this.beforeUpdate();
110
76
  if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {
77
+ this.beforeUpdate();
111
78
  this.detectChanges();
112
79
  this.afterUpdate(true);
113
80
  }
114
81
  else {
82
+ this.isUpdatesBlocked = true;
115
83
  queueMicrotask(() => {
116
84
  if (!this.isDestroyed) {
117
- this.setIsRendering(true);
85
+ this.isUpdatesBlocked = false;
86
+ this.beforeUpdate();
118
87
  this.detectChanges();
119
88
  this.afterUpdate();
120
89
  }
@@ -134,10 +103,10 @@ export class BaseAngular extends EmbeddedViewContentComponent {
134
103
  return true;
135
104
  }
136
105
  beforeUpdate() {
137
- this.setIsRendering(true);
106
+ this.setIsModelRendering(true);
138
107
  }
139
108
  afterUpdate(isSync = false) {
140
- this.setIsRendering(false);
109
+ this.setIsModelRendering(false);
141
110
  const model = this.getModel();
142
111
  if (model && !this.isDestroyed) {
143
112
  model.afterRerender();
@@ -145,7 +114,7 @@ export class BaseAngular extends EmbeddedViewContentComponent {
145
114
  }
146
115
  ngAfterViewChecked() {
147
116
  super.ngAfterViewChecked();
148
- this.setIsRendering(false);
117
+ this.setIsModelRendering(false);
149
118
  }
150
119
  }
151
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 });
@@ -156,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
156
125
  template: ""
157
126
  }]
158
127
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }]; } });
159
- //# 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 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.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  override ngAfterViewChecked(): void {\n    super.ngAfterViewChecked();\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=
@@ -51,6 +51,10 @@ class BaseAngular extends EmbeddedViewContentComponent {
51
51
  this.onArrayChangedCallback = (stateElement, options) => {
52
52
  this.update(options.name);
53
53
  };
54
+ this.onPropertyChangedCallback = (stateElement, options) => {
55
+ this.update(options.name);
56
+ };
57
+ this.isUpdatesBlocked = false;
54
58
  }
55
59
  get surveyModel() {
56
60
  return this.getModel().getSurvey();
@@ -63,17 +67,17 @@ class BaseAngular extends EmbeddedViewContentComponent {
63
67
  this.onModelChanged();
64
68
  this.previousModel = this.getModel();
65
69
  }
66
- this.setIsRendering(true);
70
+ this.setIsModelRendering(true);
67
71
  }
68
72
  onModelChanged() { }
69
- setIsRendering(val) {
73
+ setIsModelRendering(val) {
70
74
  const model = this.getModel();
71
75
  if (!!model) {
72
76
  model.isRendering = val;
73
77
  }
74
78
  }
75
- getIsRendering() {
76
- const model = this.getModel();
79
+ getIsModelRendering(stateElement) {
80
+ const model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel();
77
81
  return !!model && !!model.isRendering;
78
82
  }
79
83
  ngOnDestroy() {
@@ -82,80 +86,45 @@ class BaseAngular extends EmbeddedViewContentComponent {
82
86
  this.previousModel = undefined;
83
87
  }
84
88
  isBaseElementSubsribed(stateElement) {
85
- return !!stateElement.__ngImplemented;
86
- }
87
- getBaseElementCallbacks(stateElement) {
88
89
  var _a;
89
- stateElement.__ngSubscribers = (_a = stateElement.__ngSubscribers) !== null && _a !== void 0 ? _a : [];
90
- return (stateElement.__ngSubscribers);
90
+ return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
91
91
  }
92
92
  makeBaseElementAngular(stateElement) {
93
- this.makeBaseElementAngularCallback = () => {
93
+ var _a;
94
+ if (!!stateElement && !this.getIsModelRendering(stateElement)) {
94
95
  this.isModelSubsribed = true;
95
- stateElement.__ngImplemented = true;
96
- stateElement.iteratePropertiesHash((hash, key) => {
97
- var val = hash[key];
98
- if (Array.isArray(val)) {
99
- var val = val;
100
- stateElement.addOnArrayChangedCallback(val, this.onArrayChangedCallback);
101
- }
102
- });
103
- stateElement.setPropertyValueCoreHandler = (hash, key, val) => {
104
- if (hash[key] !== val) {
105
- hash[key] = val;
106
- this.update(key);
107
- }
108
- };
96
+ stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);
97
+ stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
109
98
  stateElement.enableOnElementRerenderedEvent();
110
- };
111
- if (!!stateElement) {
112
- if (!stateElement.__ngImplemented) {
113
- this.makeBaseElementAngularCallback();
114
- }
115
- else {
116
- this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);
117
- }
99
+ stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1;
118
100
  }
119
101
  }
120
102
  unMakeBaseElementAngular(stateElement) {
121
- if (!!stateElement) {
122
- if (this.isModelSubsribed) {
123
- this.isModelSubsribed = false;
124
- stateElement.__ngImplemented = false;
125
- stateElement.setPropertyValueCoreHandler = undefined;
126
- stateElement.iteratePropertiesHash((hash, key) => {
127
- var val = hash[key];
128
- if (Array.isArray(val)) {
129
- var val = val;
130
- stateElement.removeOnArrayChangedCallback(val, this.onArrayChangedCallback);
131
- }
132
- });
133
- stateElement.disableOnElementRerenderedEvent();
134
- const callbacks = this.getBaseElementCallbacks(stateElement);
135
- const callback = callbacks.shift();
136
- callback && callback();
137
- }
138
- else if (this.makeBaseElementAngularCallback) {
139
- const callbacks = this.getBaseElementCallbacks(stateElement);
140
- const index = callbacks.indexOf(this.makeBaseElementAngularCallback);
141
- if (index > -1) {
142
- callbacks.splice(index, 1);
143
- }
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;
144
111
  }
145
112
  }
146
113
  }
147
114
  update(key) {
148
- if (this.getIsRendering())
115
+ if (this.getIsModelRendering() || this.isUpdatesBlocked)
149
116
  return;
150
- this.beforeUpdate();
151
117
  if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {
118
+ this.beforeUpdate();
152
119
  this.detectChanges();
153
120
  this.afterUpdate(true);
154
121
  }
155
122
  else {
123
+ this.isUpdatesBlocked = true;
156
124
  queueMicrotask(() => {
157
125
  if (!this.isDestroyed) {
158
- this.setIsRendering(true);
126
+ this.isUpdatesBlocked = false;
127
+ this.beforeUpdate();
159
128
  this.detectChanges();
160
129
  this.afterUpdate();
161
130
  }
@@ -175,10 +144,10 @@ class BaseAngular extends EmbeddedViewContentComponent {
175
144
  return true;
176
145
  }
177
146
  beforeUpdate() {
178
- this.setIsRendering(true);
147
+ this.setIsModelRendering(true);
179
148
  }
180
149
  afterUpdate(isSync = false) {
181
- this.setIsRendering(false);
150
+ this.setIsModelRendering(false);
182
151
  const model = this.getModel();
183
152
  if (model && !this.isDestroyed) {
184
153
  model.afterRerender();
@@ -186,7 +155,7 @@ class BaseAngular extends EmbeddedViewContentComponent {
186
155
  }
187
156
  ngAfterViewChecked() {
188
157
  super.ngAfterViewChecked();
189
- this.setIsRendering(false);
158
+ this.setIsModelRendering(false);
190
159
  }
191
160
  }
192
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 });
@@ -3426,7 +3395,7 @@ class PanelDynamicPrevBtn extends PaneldynamicAction {
3426
3395
  }
3427
3396
  }
3428
3397
  PanelDynamicPrevBtn.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, deps: null, target: i0.ɵɵFactoryTarget.Component });
3429
- 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"] }] });
3430
3399
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PanelDynamicPrevBtn, decorators: [{
3431
3400
  type: Component,
3432
3401
  args: [{