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.
- package/base-angular.d.ts +4 -4
- package/bundles/survey-angular-ui.umd.js +42 -65
- package/bundles/survey-angular-ui.umd.js.map +1 -1
- package/embedded-view-content.component.d.ts +4 -2
- package/esm2015/base-angular.js +33 -62
- package/esm2015/components/paneldynamic-actions/paneldynamic-prev-btn.component.js +2 -2
- package/esm2015/embedded-view-content.component.js +9 -1
- package/fesm2015/survey-angular-ui.js +41 -62
- package/fesm2015/survey-angular-ui.js.map +1 -1
- package/package.json +2 -2
|
@@ -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
|
}
|
package/esm2015/base-angular.js
CHANGED
|
@@ -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.
|
|
29
|
+
this.setIsModelRendering(true);
|
|
25
30
|
}
|
|
26
31
|
onModelChanged() { }
|
|
27
|
-
|
|
32
|
+
setIsModelRendering(val) {
|
|
28
33
|
const model = this.getModel();
|
|
29
34
|
if (!!model) {
|
|
30
35
|
model.isRendering = val;
|
|
31
36
|
}
|
|
32
37
|
}
|
|
33
|
-
|
|
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
|
-
|
|
48
|
-
return (stateElement.__ngSubscribers);
|
|
49
|
+
return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
|
|
49
50
|
}
|
|
50
51
|
makeBaseElementAngular(stateElement) {
|
|
51
|
-
|
|
52
|
+
var _a;
|
|
53
|
+
if (!!stateElement && !this.getIsModelRendering(stateElement)) {
|
|
52
54
|
this.isModelSubsribed = true;
|
|
53
|
-
stateElement.
|
|
54
|
-
stateElement.
|
|
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
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
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.
|
|
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.
|
|
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.
|
|
106
|
+
this.setIsModelRendering(true);
|
|
137
107
|
}
|
|
138
108
|
afterUpdate(isSync = false) {
|
|
139
|
-
this.
|
|
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
|
-
|
|
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.
|
|
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,
|
|
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,
|
|
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.
|
|
70
|
+
this.setIsModelRendering(true);
|
|
58
71
|
}
|
|
59
72
|
onModelChanged() { }
|
|
60
|
-
|
|
73
|
+
setIsModelRendering(val) {
|
|
61
74
|
const model = this.getModel();
|
|
62
75
|
if (!!model) {
|
|
63
76
|
model.isRendering = val;
|
|
64
77
|
}
|
|
65
78
|
}
|
|
66
|
-
|
|
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
|
-
|
|
81
|
-
return (stateElement.__ngSubscribers);
|
|
90
|
+
return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
|
|
82
91
|
}
|
|
83
92
|
makeBaseElementAngular(stateElement) {
|
|
84
|
-
|
|
93
|
+
var _a;
|
|
94
|
+
if (!!stateElement && !this.getIsModelRendering(stateElement)) {
|
|
85
95
|
this.isModelSubsribed = true;
|
|
86
|
-
stateElement.
|
|
87
|
-
stateElement.
|
|
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
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
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.
|
|
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.
|
|
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.
|
|
147
|
+
this.setIsModelRendering(true);
|
|
170
148
|
}
|
|
171
149
|
afterUpdate(isSync = false) {
|
|
172
|
-
this.
|
|
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
|
-
|
|
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.
|
|
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: [{
|