survey-angular-ui 2.3.0 → 2.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,6 +7,10 @@ export declare class HeaderComponent extends BaseAngular<Cover> {
7
7
  survey: SurveyModel;
8
8
  container: ElementRef<HTMLDivElement>;
9
9
  getModel(): Cover;
10
+ private shouldProcessResponsiveness;
11
+ protected onModelChanged(): void;
12
+ ngAfterViewInit(): void;
13
+ ngAfterViewChecked(): void;
10
14
  static ɵfac: i0.ɵɵFactoryDeclaration<HeaderComponent, never>;
11
15
  static ɵcmp: i0.ɵɵComponentDeclaration<HeaderComponent, "sv-header, sv-ng-header", never, { "model": "model"; "survey": "survey"; }, {}, never, never>;
12
16
  }
@@ -6,10 +6,28 @@ import * as i1 from "./header-cell.component";
6
6
  import * as i2 from "./header-mobile.component";
7
7
  import * as i3 from "@angular/common";
8
8
  export class HeaderComponent extends BaseAngular {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.shouldProcessResponsiveness = false;
12
+ }
9
13
  getModel() {
10
14
  this.model.survey = this.survey;
11
15
  return this.model;
12
16
  }
17
+ onModelChanged() {
18
+ super.onModelChanged();
19
+ this.shouldProcessResponsiveness = true;
20
+ }
21
+ ngAfterViewInit() {
22
+ this.shouldProcessResponsiveness = true;
23
+ }
24
+ ngAfterViewChecked() {
25
+ super.ngAfterViewChecked();
26
+ if (this.shouldProcessResponsiveness) {
27
+ this.model.processResponsiveness();
28
+ this.shouldProcessResponsiveness = false;
29
+ }
30
+ }
13
31
  }
14
32
  HeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: HeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
15
33
  HeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: HeaderComponent, selector: "sv-header, sv-ng-header", inputs: { model: "model", survey: "survey" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <div *ngIf=\"(survey.headerView === 'advanced') && !model.isEmpty\" [class]=\"model.headerClasses\" [style]=\"{ height: model.renderedHeight }\">\n <div *ngIf=\"!!model.backgroundImage\" [style]=\"model.backgroundImageStyle\" [class]=\"model.backgroundImageClasses\"></div>\n <div *ngIf=\"!survey.isMobile\" [class]=\"model.contentClasses\" [style.maxWidth]=\"model.maxWidth\">\n <ng-container *ngFor=\"let cell of model.cells\">\n <sv-ng-header-cell [model]=\"cell\"></sv-ng-header-cell>\n </ng-container>\n </div>\n <div *ngIf=\"survey.isMobile\">\n <sv-ng-header-mobile [model]=\"model\"></sv-ng-header-mobile>\n </div>\n </div>\n</ng-template>", styles: [":host { display: none }"], components: [{ type: i1.HeaderCellComponent, selector: "sv-ng-header-cell", inputs: ["model"] }, { type: i2.HeaderMobileComponent, selector: "sv-ng-header-mobile", inputs: ["model"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
@@ -29,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
29
47
  args: ["container"]
30
48
  }] } });
31
49
  AngularComponentFactory.Instance.registerComponent("sv-header", HeaderComponent);
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvaGVhZGVyL2hlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7OztBQVFqRCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxXQUFrQjtJQUlyRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNoQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQzs7NkdBUFUsZUFBZTtpR0FBZixlQUFlLDRPQ1Y1Qiwwc0JBWWM7NEZERkQsZUFBZTtrQkFMM0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxXQUFXLEVBQUUseUJBQXlCO29CQUN0QyxNQUFNLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztpQkFDcEM7OEJBRVUsS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDa0IsU0FBUztzQkFBaEMsU0FBUzt1QkFBQyxXQUFXOztBQU94Qix1QkFBdUIsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsV0FBVyxFQUFFLGVBQWUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0NoaWxkIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEFuZ3VsYXJDb21wb25lbnRGYWN0b3J5IH0gZnJvbSBcIi4uLy4uL2NvbXBvbmVudC1mYWN0b3J5XCI7XG5pbXBvcnQgeyBCYXNlQW5ndWxhciB9IGZyb20gXCIuLi8uLi9iYXNlLWFuZ3VsYXJcIjtcbmltcG9ydCB7IENvdmVyLCBDb3ZlckNlbGwsIFN1cnZleU1vZGVsIH0gZnJvbSBcInN1cnZleS1jb3JlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJzdi1oZWFkZXIsIHN2LW5nLWhlYWRlclwiLFxuICB0ZW1wbGF0ZVVybDogXCIuL2hlYWRlci5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZXM6IFtcIjpob3N0IHsgZGlzcGxheTogbm9uZSB9XCJdXG59KVxuZXhwb3J0IGNsYXNzIEhlYWRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VBbmd1bGFyPENvdmVyPiB7XG4gIEBJbnB1dCgpIG1vZGVsITogQ292ZXI7XG4gIEBJbnB1dCgpIHN1cnZleSE6IFN1cnZleU1vZGVsO1xuICBAVmlld0NoaWxkKFwiY29udGFpbmVyXCIpIGNvbnRhaW5lciE6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuICBnZXRNb2RlbCgpOiBDb3ZlciB7XG4gICAgdGhpcy5tb2RlbC5zdXJ2ZXkgPSB0aGlzLnN1cnZleTtcbiAgICByZXR1cm4gdGhpcy5tb2RlbDtcbiAgfVxufVxuXG5Bbmd1bGFyQ29tcG9uZW50RmFjdG9yeS5JbnN0YW5jZS5yZWdpc3RlckNvbXBvbmVudChcInN2LWhlYWRlclwiLCBIZWFkZXJDb21wb25lbnQpOyIsIjxuZy10ZW1wbGF0ZSAjdGVtcGxhdGU+XG4gIDxkaXYgKm5nSWY9XCIoc3VydmV5LmhlYWRlclZpZXcgPT09ICdhZHZhbmNlZCcpICYmICFtb2RlbC5pc0VtcHR5XCIgW2NsYXNzXT1cIm1vZGVsLmhlYWRlckNsYXNzZXNcIiBbc3R5bGVdPVwieyBoZWlnaHQ6IG1vZGVsLnJlbmRlcmVkSGVpZ2h0IH1cIj5cbiAgICA8ZGl2ICpuZ0lmPVwiISFtb2RlbC5iYWNrZ3JvdW5kSW1hZ2VcIiBbc3R5bGVdPVwibW9kZWwuYmFja2dyb3VuZEltYWdlU3R5bGVcIiBbY2xhc3NdPVwibW9kZWwuYmFja2dyb3VuZEltYWdlQ2xhc3Nlc1wiPjwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhc3VydmV5LmlzTW9iaWxlXCIgW2NsYXNzXT1cIm1vZGVsLmNvbnRlbnRDbGFzc2VzXCIgW3N0eWxlLm1heFdpZHRoXT1cIm1vZGVsLm1heFdpZHRoXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjZWxsIG9mIG1vZGVsLmNlbGxzXCI+XG4gICAgICAgIDxzdi1uZy1oZWFkZXItY2VsbCBbbW9kZWxdPVwiY2VsbFwiPjwvc3YtbmctaGVhZGVyLWNlbGw+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwic3VydmV5LmlzTW9iaWxlXCI+XG4gICAgICA8c3YtbmctaGVhZGVyLW1vYmlsZSBbbW9kZWxdPVwibW9kZWxcIj48L3N2LW5nLWhlYWRlci1tb2JpbGU+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT4iXX0=
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvaGVhZGVyL2hlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7OztBQVFqRCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxXQUFrQjtJQUx2RDs7UUFhVSxnQ0FBMkIsR0FBWSxLQUFLLENBQUM7S0FldEQ7SUFuQkMsUUFBUTtRQUNOLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDaEMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFFa0IsY0FBYztRQUMvQixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsSUFBSSxDQUFDLDJCQUEyQixHQUFHLElBQUksQ0FBQztJQUMxQyxDQUFDO0lBQ0QsZUFBZTtRQUNiLElBQUksQ0FBQywyQkFBMkIsR0FBRyxJQUFJLENBQUM7SUFDMUMsQ0FBQztJQUNRLGtCQUFrQjtRQUN6QixLQUFLLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztRQUMzQixJQUFJLElBQUksQ0FBQywyQkFBMkIsRUFBRTtZQUNwQyxJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixFQUFFLENBQUM7WUFDbkMsSUFBSSxDQUFDLDJCQUEyQixHQUFHLEtBQUssQ0FBQztTQUMxQztJQUNILENBQUM7OzZHQXRCVSxlQUFlO2lHQUFmLGVBQWUsNE9DVjVCLDBzQkFZYzs0RkRGRCxlQUFlO2tCQUwzQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFdBQVcsRUFBRSx5QkFBeUI7b0JBQ3RDLE1BQU0sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUNwQzs4QkFFVSxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNrQixTQUFTO3NCQUFoQyxTQUFTO3VCQUFDLFdBQVc7O0FBc0J4Qix1QkFBdUIsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsV0FBVyxFQUFFLGVBQWUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0NoaWxkIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEFuZ3VsYXJDb21wb25lbnRGYWN0b3J5IH0gZnJvbSBcIi4uLy4uL2NvbXBvbmVudC1mYWN0b3J5XCI7XG5pbXBvcnQgeyBCYXNlQW5ndWxhciB9IGZyb20gXCIuLi8uLi9iYXNlLWFuZ3VsYXJcIjtcbmltcG9ydCB7IENvdmVyLCBDb3ZlckNlbGwsIFN1cnZleU1vZGVsIH0gZnJvbSBcInN1cnZleS1jb3JlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJzdi1oZWFkZXIsIHN2LW5nLWhlYWRlclwiLFxuICB0ZW1wbGF0ZVVybDogXCIuL2hlYWRlci5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZXM6IFtcIjpob3N0IHsgZGlzcGxheTogbm9uZSB9XCJdXG59KVxuZXhwb3J0IGNsYXNzIEhlYWRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VBbmd1bGFyPENvdmVyPiB7XG4gIEBJbnB1dCgpIG1vZGVsITogQ292ZXI7XG4gIEBJbnB1dCgpIHN1cnZleSE6IFN1cnZleU1vZGVsO1xuICBAVmlld0NoaWxkKFwiY29udGFpbmVyXCIpIGNvbnRhaW5lciE6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuICBnZXRNb2RlbCgpOiBDb3ZlciB7XG4gICAgdGhpcy5tb2RlbC5zdXJ2ZXkgPSB0aGlzLnN1cnZleTtcbiAgICByZXR1cm4gdGhpcy5tb2RlbDtcbiAgfVxuICBwcml2YXRlIHNob3VsZFByb2Nlc3NSZXNwb25zaXZlbmVzczogYm9vbGVhbiA9IGZhbHNlO1xuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgb25Nb2RlbENoYW5nZWQoKTogdm9pZCB7XG4gICAgc3VwZXIub25Nb2RlbENoYW5nZWQoKTtcbiAgICB0aGlzLnNob3VsZFByb2Nlc3NSZXNwb25zaXZlbmVzcyA9IHRydWU7XG4gIH1cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuc2hvdWxkUHJvY2Vzc1Jlc3BvbnNpdmVuZXNzID0gdHJ1ZTtcbiAgfVxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0NoZWNrZWQoKTogdm9pZCB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdDaGVja2VkKCk7XG4gICAgaWYgKHRoaXMuc2hvdWxkUHJvY2Vzc1Jlc3BvbnNpdmVuZXNzKSB7XG4gICAgICB0aGlzLm1vZGVsLnByb2Nlc3NSZXNwb25zaXZlbmVzcygpO1xuICAgICAgdGhpcy5zaG91bGRQcm9jZXNzUmVzcG9uc2l2ZW5lc3MgPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cblxuQW5ndWxhckNvbXBvbmVudEZhY3RvcnkuSW5zdGFuY2UucmVnaXN0ZXJDb21wb25lbnQoXCJzdi1oZWFkZXJcIiwgSGVhZGVyQ29tcG9uZW50KTsiLCI8bmctdGVtcGxhdGUgI3RlbXBsYXRlPlxuICA8ZGl2ICpuZ0lmPVwiKHN1cnZleS5oZWFkZXJWaWV3ID09PSAnYWR2YW5jZWQnKSAmJiAhbW9kZWwuaXNFbXB0eVwiIFtjbGFzc109XCJtb2RlbC5oZWFkZXJDbGFzc2VzXCIgW3N0eWxlXT1cInsgaGVpZ2h0OiBtb2RlbC5yZW5kZXJlZEhlaWdodCB9XCI+XG4gICAgPGRpdiAqbmdJZj1cIiEhbW9kZWwuYmFja2dyb3VuZEltYWdlXCIgW3N0eWxlXT1cIm1vZGVsLmJhY2tncm91bmRJbWFnZVN0eWxlXCIgW2NsYXNzXT1cIm1vZGVsLmJhY2tncm91bmRJbWFnZUNsYXNzZXNcIj48L2Rpdj5cbiAgICA8ZGl2ICpuZ0lmPVwiIXN1cnZleS5pc01vYmlsZVwiIFtjbGFzc109XCJtb2RlbC5jb250ZW50Q2xhc3Nlc1wiIFtzdHlsZS5tYXhXaWR0aF09XCJtb2RlbC5tYXhXaWR0aFwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgY2VsbCBvZiBtb2RlbC5jZWxsc1wiPlxuICAgICAgICA8c3YtbmctaGVhZGVyLWNlbGwgW21vZGVsXT1cImNlbGxcIj48L3N2LW5nLWhlYWRlci1jZWxsPlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG4gICAgPGRpdiAqbmdJZj1cInN1cnZleS5pc01vYmlsZVwiPlxuICAgICAgPHN2LW5nLWhlYWRlci1tb2JpbGUgW21vZGVsXT1cIm1vZGVsXCI+PC9zdi1uZy1oZWFkZXItbW9iaWxlPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvbmctdGVtcGxhdGU+Il19
@@ -45,6 +45,7 @@ export class SurveyContentComponent extends BaseAngular {
45
45
  }
46
46
  ngAfterViewChecked() {
47
47
  if (!!this.model && this.isSurveyUpdated) {
48
+ this.isSurveyUpdated = false;
48
49
  this.model.afterRenderSurvey(this.rootEl.nativeElement);
49
50
  this.model.startTimerFromUI();
50
51
  }
@@ -66,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
66
67
  args: ["surveyContainer", { static: false }]
67
68
  }] } });
68
69
  AngularComponentFactory.Instance.registerComponent("survey", SurveyContentComponent);
69
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"survey-content.component.js","sourceRoot":"","sources":["../../src/survey-content.component.ts","../../src/survey-content.component.html"],"names":[],"mappings":"AACA,OAAO,EAAiB,SAAS,EAAc,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAE/F,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;;;AAK9D,MAAM,OAAO,sBAAuB,SAAQ,WAAwB;IAJpE;;QAOU,oBAAe,GAAY,KAAK,CAAC;KAkC1C;IAjCW,QAAQ;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACkB,cAAc;QAC/B,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,cAAc,GAAQ,SAAS,CAAC;SACpD;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YAChB,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,GAAG,EAAE;gBAC/B,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,CAAC,CAAC;SACH;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IACQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YAChB,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,SAAgB,CAAC;YAC1C,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,cAAc,GAAQ,SAAS,CAAC;SAC5C;IACH,CAAC;IACD,eAAe;QACb,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IACQ,kBAAkB;QACzB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE;YACxC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YACxD,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC;SAC/B;QACD,KAAK,CAAC,kBAAkB,EAAE,CAAC;IAC7B,CAAC;;oHApCU,sBAAsB;wGAAtB,sBAAsB,oNCTnC,84HAgDc;4FDvCD,sBAAsB;kBAJlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,iCAAiC;iBAC/C;8BAEU,KAAK;sBAAb,KAAK;gBAC2C,MAAM;sBAAtD,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;;AAqCjD,uBAAuB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,EAAE,sBAAsB,CAAC,CAAC","sourcesContent":["\nimport { AfterViewInit, Component, ElementRef, Input, OnInit, ViewChild } from \"@angular/core\";\nimport { SurveyModel, SvgRegistry } from \"survey-core\";\nimport { BaseAngular } from \"./base-angular\";\nimport { AngularComponentFactory } from \"./component-factory\";\n@Component({\n  selector: \"survey-content\",\n  templateUrl: \"./survey-content.component.html\"\n})\nexport class SurveyContentComponent extends BaseAngular<SurveyModel> implements OnInit, AfterViewInit {\n  @Input() model!: SurveyModel;\n  @ViewChild(\"surveyContainer\", { static: false }) rootEl!: ElementRef<HTMLDivElement>;\n  private isSurveyUpdated: boolean = false;\n  protected getModel(): SurveyModel {\n    return this.model;\n  }\n  protected override onModelChanged(): void {\n    if (!!this.previousModel) {\n      this.previousModel.destroyResizeObserver();\n      this.previousModel.renderCallback = <any>undefined;\n    }\n    if (!!this.model) {\n      this.model.renderCallback = () => {\n        this.detectChanges();\n      };\n    }\n    this.isSurveyUpdated = true;\n  }\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    if (!!this.model) {\n      this.model.rootElement = undefined as any;\n      this.model.destroyResizeObserver();\n      this.model.renderCallback = <any>undefined;\n    }\n  }\n  ngAfterViewInit(): void {\n    this.isSurveyUpdated = true;\n  }\n  override ngAfterViewChecked(): void {\n    if (!!this.model && this.isSurveyUpdated) {\n      this.model.afterRenderSurvey(this.rootEl.nativeElement);\n      this.model.startTimerFromUI();\n    }\n    super.ngAfterViewChecked();\n  }\n}\n\nAngularComponentFactory.Instance.registerComponent(\"survey\", SurveyContentComponent);","<ng-template #template>\n  <div #surveyContainer *ngIf=\"!!model\" [class]=\"model.getRootCss()\" [style]=\"model.themeVariables\" [lang]=\"model.locale || 'en'\" [dir]=\"model.localeDir\">\n    <sv-scroll [disabled]=\"model.rootScrollDisabled\">\n      <sv-svg-bundle *ngIf=\"model.needRenderIcons\"></sv-svg-bundle>\n      <div [class]=\"model.wrapperFormCss\">\n        <div *ngIf=\"!!model.renderBackgroundImage\" [class]=\"model.css.rootBackgroundImage\" [style]=\"model.backgroundImageStyle\"></div>\n        <form onsubmit=\"return false;\">\n          <sv-scroll [disabled]=\"model.formScrollDisabled\">\n          <div class=\"sv_custom_header\" [hidden]=\"model.hasLogo\"></div>\n          <div [class]=\"model.css.container\">\n            <div *ngIf=\"model.headerView === 'basic' && model.renderedHasHeader\" [class]=\"model.css.header\" [survey]=\"model\" sv-ng-survey-header></div>\n            <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'header', needRenderWrapper: false } }\"></ng-template>\n            <div *ngIf=\"model.isShowingPage\" [class]=\"model.bodyContainerCss\">\n              <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'left' } }\"></ng-template>\n              <div class=\"sv-components-column sv-components-column--expandable\">\n                <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'center' } }\"></ng-template>\n                <div [class]=\"model.bodyCss\" [style.maxWidth]=\"model.renderedWidth\" [id]=\"model.activePage ? model.activePage.id : ''\">\n                  <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'contentTop' } }\"></ng-template>\n                  <!-- ko if: activePage -->\n                    <ng-container *ngIf=\"model.activePage\">\n                        <sv-ng-page [model]=\"model.activePage\" [survey]=\"model\"></sv-ng-page>\n                    </ng-container>\n                    <!-- ko if: activePage.rows.length == 0 && $data.emptyPageTemplate -->\n                    <!-- ko template: { name: emptyPageTemplate, data: $data.emptyPageTemplateData || $data } -->\n                    <!-- /ko -->\n                    <!-- /ko -->\n                  <!-- /ko -->\n                  <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'contentBottom' } }\"></ng-template>\n                  <sv-brand-info *ngIf=\"model.showBrandInfo\"></sv-brand-info>\n                </div>\n              </div>\n              <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'right' } }\"></ng-template>\n            </div>\n            <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'footer', needRenderWrapper: false } }\"></ng-template>\n            <div *ngIf=\"model.state === 'completed' && model.showCompletedPage\" [class]=\"model.completedCss\"\n              [innerHtml]=\"model.processedCompletedHtml | safeHtml\"></div>\n            <ng-template *ngIf=\"model.state === 'completed' && model.showCompletedPage\" [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'completePage' } }\"></ng-template>\n            <div *ngIf=\"model.state === 'completedbefore'\" [class]=\"model.completedBeforeCss\"\n              [innerHtml]=\"model.processedCompletedBeforeHtml | safeHtml\"></div>\n            <div *ngIf=\"model.state === 'loading'\" [class]=\"model.loadingBodyCss\" [innerHtml]=\"model.processedLoadingHtml\"></div>\n            <div *ngIf=\"model.state === 'empty'\" [class]=\"model.css.bodyEmpty\">{{model.emptySurveyText}}</div>\n          </div>\n        </sv-scroll>\n        </form>\n        <sv-notifier [notifier]=\"model.notifier\"></sv-notifier>\n      </div>\n    </sv-scroll>\n  </div>\n</ng-template>"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"survey-content.component.js","sourceRoot":"","sources":["../../src/survey-content.component.ts","../../src/survey-content.component.html"],"names":[],"mappings":"AACA,OAAO,EAAiB,SAAS,EAAc,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAE/F,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;;;AAK9D,MAAM,OAAO,sBAAuB,SAAQ,WAAwB;IAJpE;;QAOU,oBAAe,GAAY,KAAK,CAAC;KAmC1C;IAlCW,QAAQ;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACkB,cAAc;QAC/B,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,cAAc,GAAQ,SAAS,CAAC;SACpD;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YAChB,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,GAAG,EAAE;gBAC/B,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,CAAC,CAAC;SACH;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IACQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YAChB,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,SAAgB,CAAC;YAC1C,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,cAAc,GAAQ,SAAS,CAAC;SAC5C;IACH,CAAC;IACD,eAAe;QACb,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IACQ,kBAAkB;QACzB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE;YACxC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YACxD,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC;SAC/B;QACD,KAAK,CAAC,kBAAkB,EAAE,CAAC;IAC7B,CAAC;;oHArCU,sBAAsB;wGAAtB,sBAAsB,oNCTnC,84HAgDc;4FDvCD,sBAAsB;kBAJlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,iCAAiC;iBAC/C;8BAEU,KAAK;sBAAb,KAAK;gBAC2C,MAAM;sBAAtD,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;;AAsCjD,uBAAuB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,EAAE,sBAAsB,CAAC,CAAC","sourcesContent":["\nimport { AfterViewInit, Component, ElementRef, Input, OnInit, ViewChild } from \"@angular/core\";\nimport { SurveyModel, SvgRegistry } from \"survey-core\";\nimport { BaseAngular } from \"./base-angular\";\nimport { AngularComponentFactory } from \"./component-factory\";\n@Component({\n  selector: \"survey-content\",\n  templateUrl: \"./survey-content.component.html\"\n})\nexport class SurveyContentComponent extends BaseAngular<SurveyModel> implements OnInit, AfterViewInit {\n  @Input() model!: SurveyModel;\n  @ViewChild(\"surveyContainer\", { static: false }) rootEl!: ElementRef<HTMLDivElement>;\n  private isSurveyUpdated: boolean = false;\n  protected getModel(): SurveyModel {\n    return this.model;\n  }\n  protected override onModelChanged(): void {\n    if (!!this.previousModel) {\n      this.previousModel.destroyResizeObserver();\n      this.previousModel.renderCallback = <any>undefined;\n    }\n    if (!!this.model) {\n      this.model.renderCallback = () => {\n        this.detectChanges();\n      };\n    }\n    this.isSurveyUpdated = true;\n  }\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    if (!!this.model) {\n      this.model.rootElement = undefined as any;\n      this.model.destroyResizeObserver();\n      this.model.renderCallback = <any>undefined;\n    }\n  }\n  ngAfterViewInit(): void {\n    this.isSurveyUpdated = true;\n  }\n  override ngAfterViewChecked(): void {\n    if (!!this.model && this.isSurveyUpdated) {\n      this.isSurveyUpdated = false;\n      this.model.afterRenderSurvey(this.rootEl.nativeElement);\n      this.model.startTimerFromUI();\n    }\n    super.ngAfterViewChecked();\n  }\n}\n\nAngularComponentFactory.Instance.registerComponent(\"survey\", SurveyContentComponent);","<ng-template #template>\n  <div #surveyContainer *ngIf=\"!!model\" [class]=\"model.getRootCss()\" [style]=\"model.themeVariables\" [lang]=\"model.locale || 'en'\" [dir]=\"model.localeDir\">\n    <sv-scroll [disabled]=\"model.rootScrollDisabled\">\n      <sv-svg-bundle *ngIf=\"model.needRenderIcons\"></sv-svg-bundle>\n      <div [class]=\"model.wrapperFormCss\">\n        <div *ngIf=\"!!model.renderBackgroundImage\" [class]=\"model.css.rootBackgroundImage\" [style]=\"model.backgroundImageStyle\"></div>\n        <form onsubmit=\"return false;\">\n          <sv-scroll [disabled]=\"model.formScrollDisabled\">\n          <div class=\"sv_custom_header\" [hidden]=\"model.hasLogo\"></div>\n          <div [class]=\"model.css.container\">\n            <div *ngIf=\"model.headerView === 'basic' && model.renderedHasHeader\" [class]=\"model.css.header\" [survey]=\"model\" sv-ng-survey-header></div>\n            <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'header', needRenderWrapper: false } }\"></ng-template>\n            <div *ngIf=\"model.isShowingPage\" [class]=\"model.bodyContainerCss\">\n              <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'left' } }\"></ng-template>\n              <div class=\"sv-components-column sv-components-column--expandable\">\n                <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'center' } }\"></ng-template>\n                <div [class]=\"model.bodyCss\" [style.maxWidth]=\"model.renderedWidth\" [id]=\"model.activePage ? model.activePage.id : ''\">\n                  <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'contentTop' } }\"></ng-template>\n                  <!-- ko if: activePage -->\n                    <ng-container *ngIf=\"model.activePage\">\n                        <sv-ng-page [model]=\"model.activePage\" [survey]=\"model\"></sv-ng-page>\n                    </ng-container>\n                    <!-- ko if: activePage.rows.length == 0 && $data.emptyPageTemplate -->\n                    <!-- ko template: { name: emptyPageTemplate, data: $data.emptyPageTemplateData || $data } -->\n                    <!-- /ko -->\n                    <!-- /ko -->\n                  <!-- /ko -->\n                  <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'contentBottom' } }\"></ng-template>\n                  <sv-brand-info *ngIf=\"model.showBrandInfo\"></sv-brand-info>\n                </div>\n              </div>\n              <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'right' } }\"></ng-template>\n            </div>\n            <ng-template [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'footer', needRenderWrapper: false } }\"></ng-template>\n            <div *ngIf=\"model.state === 'completed' && model.showCompletedPage\" [class]=\"model.completedCss\"\n              [innerHtml]=\"model.processedCompletedHtml | safeHtml\"></div>\n            <ng-template *ngIf=\"model.state === 'completed' && model.showCompletedPage\" [component]=\"{ name: 'sv-components-container', data: { survey: model, container: 'completePage' } }\"></ng-template>\n            <div *ngIf=\"model.state === 'completedbefore'\" [class]=\"model.completedBeforeCss\"\n              [innerHtml]=\"model.processedCompletedBeforeHtml | safeHtml\"></div>\n            <div *ngIf=\"model.state === 'loading'\" [class]=\"model.loadingBodyCss\" [innerHtml]=\"model.processedLoadingHtml\"></div>\n            <div *ngIf=\"model.state === 'empty'\" [class]=\"model.css.bodyEmpty\">{{model.emptySurveyText}}</div>\n          </div>\n        </sv-scroll>\n        </form>\n        <sv-notifier [notifier]=\"model.notifier\"></sv-notifier>\n      </div>\n    </sv-scroll>\n  </div>\n</ng-template>"]}
@@ -1031,6 +1031,7 @@ class SurveyContentComponent extends BaseAngular {
1031
1031
  }
1032
1032
  ngAfterViewChecked() {
1033
1033
  if (!!this.model && this.isSurveyUpdated) {
1034
+ this.isSurveyUpdated = false;
1034
1035
  this.model.afterRenderSurvey(this.rootEl.nativeElement);
1035
1036
  this.model.startTimerFromUI();
1036
1037
  }
@@ -4047,10 +4048,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
4047
4048
  AngularComponentFactory.Instance.registerComponent("sv-header-cell", HeaderMobileComponent);
4048
4049
 
4049
4050
  class HeaderComponent extends BaseAngular {
4051
+ constructor() {
4052
+ super(...arguments);
4053
+ this.shouldProcessResponsiveness = false;
4054
+ }
4050
4055
  getModel() {
4051
4056
  this.model.survey = this.survey;
4052
4057
  return this.model;
4053
4058
  }
4059
+ onModelChanged() {
4060
+ super.onModelChanged();
4061
+ this.shouldProcessResponsiveness = true;
4062
+ }
4063
+ ngAfterViewInit() {
4064
+ this.shouldProcessResponsiveness = true;
4065
+ }
4066
+ ngAfterViewChecked() {
4067
+ super.ngAfterViewChecked();
4068
+ if (this.shouldProcessResponsiveness) {
4069
+ this.model.processResponsiveness();
4070
+ this.shouldProcessResponsiveness = false;
4071
+ }
4072
+ }
4054
4073
  }
4055
4074
  HeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: HeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
4056
4075
  HeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: HeaderComponent, selector: "sv-header, sv-ng-header", inputs: { model: "model", survey: "survey" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <div *ngIf=\"(survey.headerView === 'advanced') && !model.isEmpty\" [class]=\"model.headerClasses\" [style]=\"{ height: model.renderedHeight }\">\n <div *ngIf=\"!!model.backgroundImage\" [style]=\"model.backgroundImageStyle\" [class]=\"model.backgroundImageClasses\"></div>\n <div *ngIf=\"!survey.isMobile\" [class]=\"model.contentClasses\" [style.maxWidth]=\"model.maxWidth\">\n <ng-container *ngFor=\"let cell of model.cells\">\n <sv-ng-header-cell [model]=\"cell\"></sv-ng-header-cell>\n </ng-container>\n </div>\n <div *ngIf=\"survey.isMobile\">\n <sv-ng-header-mobile [model]=\"model\"></sv-ng-header-mobile>\n </div>\n </div>\n</ng-template>", styles: [":host { display: none }"], components: [{ type: HeaderCellComponent, selector: "sv-ng-header-cell", inputs: ["model"] }, { type: HeaderMobileComponent, selector: "sv-ng-header-mobile", inputs: ["model"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });