survey-angular-ui 2.3.12 → 2.3.14

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 CHANGED
@@ -11,16 +11,16 @@ export declare abstract class BaseAngular<T extends Base = Base> extends Embedde
11
11
  private isModelSubsribed;
12
12
  ngDoCheck(): void;
13
13
  protected onModelChanged(): void;
14
- private setIsRendering;
15
- private getIsRendering;
14
+ private setIsModelRendering;
15
+ private getIsModelRendering;
16
16
  private isDestroyed;
17
17
  ngOnDestroy(): void;
18
- private makeBaseElementAngularCallback?;
19
18
  protected isBaseElementSubsribed(stateElement: Base): boolean;
20
- private getBaseElementCallbacks;
21
19
  private onArrayChangedCallback;
20
+ private onPropertyChangedCallback;
22
21
  private makeBaseElementAngular;
23
22
  private unMakeBaseElementAngular;
23
+ private isUpdatesBlocked;
24
24
  protected update(key?: string): void;
25
25
  private getChangeDetectorRef;
26
26
  protected getPropertiesToUpdateSync(): Array<string>;
@@ -578,6 +578,10 @@
578
578
  _this.onArrayChangedCallback = function (stateElement, options) {
579
579
  _this.update(options.name);
580
580
  };
581
+ _this.onPropertyChangedCallback = function (stateElement, options) {
582
+ _this.update(options.name);
583
+ };
584
+ _this.isUpdatesBlocked = false;
581
585
  return _this;
582
586
  }
583
587
  Object.defineProperty(BaseAngular.prototype, "surveyModel", {
@@ -595,17 +599,17 @@
595
599
  this.onModelChanged();
596
600
  this.previousModel = this.getModel();
597
601
  }
598
- this.setIsRendering(true);
602
+ this.setIsModelRendering(true);
599
603
  };
600
604
  BaseAngular.prototype.onModelChanged = function () { };
601
- BaseAngular.prototype.setIsRendering = function (val) {
605
+ BaseAngular.prototype.setIsModelRendering = function (val) {
602
606
  var model = this.getModel();
603
607
  if (!!model) {
604
608
  model.isRendering = val;
605
609
  }
606
610
  };
607
- BaseAngular.prototype.getIsRendering = function () {
608
- var model = this.getModel();
611
+ BaseAngular.prototype.getIsModelRendering = function (stateElement) {
612
+ var model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel();
609
613
  return !!model && !!model.isRendering;
610
614
  };
611
615
  BaseAngular.prototype.ngOnDestroy = function () {
@@ -614,83 +618,46 @@
614
618
  this.previousModel = undefined;
615
619
  };
616
620
  BaseAngular.prototype.isBaseElementSubsribed = function (stateElement) {
617
- return !!stateElement.__ngImplemented;
618
- };
619
- BaseAngular.prototype.getBaseElementCallbacks = function (stateElement) {
620
621
  var _a;
621
- stateElement.__ngSubscribers = (_a = stateElement.__ngSubscribers) !== null && _a !== void 0 ? _a : [];
622
- return (stateElement.__ngSubscribers);
622
+ return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0;
623
623
  };
624
624
  BaseAngular.prototype.makeBaseElementAngular = function (stateElement) {
625
- var _this = this;
626
- this.makeBaseElementAngularCallback = function () {
627
- _this.isModelSubsribed = true;
628
- stateElement.__ngImplemented = true;
629
- stateElement.iteratePropertiesHash(function (hash, key) {
630
- var val = hash[key];
631
- if (Array.isArray(val)) {
632
- var val = val;
633
- stateElement.addOnArrayChangedCallback(val, _this.onArrayChangedCallback);
634
- }
635
- });
636
- stateElement.setPropertyValueCoreHandler = function (hash, key, val) {
637
- if (hash[key] !== val) {
638
- hash[key] = val;
639
- _this.update(key);
640
- }
641
- };
625
+ var _a;
626
+ if (!!stateElement && !this.getIsModelRendering(stateElement)) {
627
+ this.isModelSubsribed = true;
628
+ stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback);
629
+ stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
642
630
  stateElement.enableOnElementRerenderedEvent();
643
- };
644
- if (!!stateElement) {
645
- if (!stateElement.__ngImplemented) {
646
- this.makeBaseElementAngularCallback();
647
- }
648
- else {
649
- this.getBaseElementCallbacks(stateElement).push(this.makeBaseElementAngularCallback);
650
- }
631
+ stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1;
651
632
  }
652
633
  };
653
634
  BaseAngular.prototype.unMakeBaseElementAngular = function (stateElement) {
654
- var _this = this;
655
- if (!!stateElement) {
656
- if (this.isModelSubsribed) {
657
- this.isModelSubsribed = false;
658
- stateElement.__ngImplemented = false;
659
- stateElement.setPropertyValueCoreHandler = undefined;
660
- stateElement.iteratePropertiesHash(function (hash, key) {
661
- var val = hash[key];
662
- if (Array.isArray(val)) {
663
- var val = val;
664
- stateElement.removeOnArrayChangedCallback(val, _this.onArrayChangedCallback);
665
- }
666
- });
667
- stateElement.disableOnElementRerenderedEvent();
668
- var callbacks = this.getBaseElementCallbacks(stateElement);
669
- var callback = callbacks.shift();
670
- callback && callback();
671
- }
672
- else if (this.makeBaseElementAngularCallback) {
673
- var callbacks = this.getBaseElementCallbacks(stateElement);
674
- var index = callbacks.indexOf(this.makeBaseElementAngularCallback);
675
- if (index > -1) {
676
- callbacks.splice(index, 1);
677
- }
635
+ var _a;
636
+ if (!!stateElement && this.isModelSubsribed) {
637
+ this.isModelSubsribed = false;
638
+ stateElement.removeOnPropertyValueChangedCallback(this.onPropertyChangedCallback);
639
+ stateElement.removeOnArrayChangedCallback(this.onArrayChangedCallback);
640
+ stateElement.disableOnElementRerenderedEvent();
641
+ if (((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) - 1 <= 0) {
642
+ delete stateElement.__ngImplementedCount;
678
643
  }
679
644
  }
680
645
  };
681
646
  BaseAngular.prototype.update = function (key) {
682
647
  var _this = this;
683
- if (this.getIsRendering())
648
+ if (this.getIsModelRendering() || this.isUpdatesBlocked)
684
649
  return;
685
- this.beforeUpdate();
686
650
  if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) {
651
+ this.beforeUpdate();
687
652
  this.detectChanges();
688
653
  this.afterUpdate(true);
689
654
  }
690
655
  else {
656
+ this.isUpdatesBlocked = true;
691
657
  queueMicrotask(function () {
692
658
  if (!_this.isDestroyed) {
693
- _this.setIsRendering(true);
659
+ _this.isUpdatesBlocked = false;
660
+ _this.beforeUpdate();
694
661
  _this.detectChanges();
695
662
  _this.afterUpdate();
696
663
  }
@@ -710,11 +677,11 @@
710
677
  return true;
711
678
  };
712
679
  BaseAngular.prototype.beforeUpdate = function () {
713
- this.setIsRendering(true);
680
+ this.setIsModelRendering(true);
714
681
  };
715
682
  BaseAngular.prototype.afterUpdate = function (isSync) {
716
683
  if (isSync === void 0) { isSync = false; }
717
- this.setIsRendering(false);
684
+ this.setIsModelRendering(false);
718
685
  var model = this.getModel();
719
686
  if (model && !this.isDestroyed) {
720
687
  model.afterRerender();
@@ -722,7 +689,7 @@
722
689
  };
723
690
  BaseAngular.prototype.ngAfterViewChecked = function () {
724
691
  _super.prototype.ngAfterViewChecked.call(this);
725
- this.setIsRendering(false);
692
+ this.setIsModelRendering(false);
726
693
  };
727
694
  return BaseAngular;
728
695
  }(EmbeddedViewContentComponent));
@@ -2061,7 +2028,7 @@
2061
2028
  return QuestionComponent;
2062
2029
  }(EmbeddedViewContentComponent));
2063
2030
  QuestionComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: QuestionComponent, deps: null, target: i0__namespace.ɵɵFactoryTarget.Component });
2064
- QuestionComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: QuestionComponent, selector: "sv-ng-question", inputs: { model: "model", css: "css", survey: "survey" }, viewQueries: [{ propertyName: "rootEl", first: true, predicate: ["elementContainer"], descendants: true }], usesInheritance: true, ngImport: i0__namespace, template: "<ng-template #template>\n <div *ngIf=\"!!model\" #elementContainer [class]=\"model.getRootCss()\" [style]=\"model.getRootStyle()\" [id]=\"model.id\"\n [attr.data-name]=\"model.name\" [attr.role]=\"model.ariaRole\" [attr.aria-required]=\"model.ariaRequired\"\n [attr.aria-invalid]=\"model.ariaInvalid\" [attr.aria-label]=\"model.ariaLabel\"\n [attr.aria-labelledby]=\"model.ariaLabelledBy\" [attr.aria-describedby]=\"model.ariaDescribedBy\"\n [attr.aria-expanded]=\"model.ariaExpanded\">\n <sv-breadcrumbs\n *ngIf=\"model.singleInputHasActions\"\n [model]=\"model.singleInputActions\"\n [css]=\"model.cssClasses\"\n ></sv-breadcrumbs>\n <div *ngIf=\"model.showErrorsAboveQuestion && model.hasVisibleErrors\" [element]=\"model\" sv-ng-errors></div>\n <div [element]=\"model\" *ngIf=\"!model.singleInputHideHeader && model.hasTitleOnLeftTop\" sv-ng-element-header></div>\n <sv-single-input-summary\n *ngIf=\"!!model.singleInputSummary\"\n [model]=\"model.singleInputSummary\"\n [css]=\"model.cssClasses\"\n ></sv-single-input-summary>\n <sv-ng-element\n *ngIf=\"!model.singleInputSummary && !!singleQuestion\"\n [model]=\"singleQuestion\"\n ></sv-ng-element>\n <ng-template\n *ngIf=\"!model.singleInputSummary && !singleQuestion\"\n [component]=\"{ name: getQuestionContentWrapperComponentName(), data: getQuestionContentWrapperComponentData() }\">\n <div [class]=\"model.cssContent\" role=\"presentation\" [visible]=\"model.renderedIsExpanded\" [attr.aria-hidden]=\"model.contentAriaHidden\" [attr.data-sv-drop-target-matrix-row]=\"model.dragDropMatrixAttribute\" [attr.data-sv-drop-target-matrix]=\"model.dragDropMatrixAttribute\">\n <ng-template\n [component]=\"{ name: getComponentName(), data: { model: model }, default: 'skeleton-question' }\"></ng-template>\n <div *ngIf=\"model.hasComment\" [class]=\"model.getCommentAreaCss(false)\">\n <div [model]=\"model.locCommentText\" sv-ng-string></div>\n <sv-ng-comment [question]=\"model\"></sv-ng-comment>\n </div>\n <div *ngIf=\"model.hasDescriptionUnderInput\" [class]=\"model.cssDescription\" [attr.id]=\"model.ariaDescriptionId\"\n [model]=\"model.locDescription\" sv-ng-string></div>\n </div>\n </ng-template>\n <div [element]=\"model\" *ngIf=\"model.hasTitleOnBottom\" sv-ng-element-header></div>\n <div *ngIf=\"model.showErrorsBelowQuestion && model.hasVisibleErrors\" [element]=\"model\" sv-ng-errors></div>\n </div>\n</ng-template>", components: [{ type: BreadcrumbsComponent, selector: "sv-breadcrumbs", inputs: ["model", "css"] }, { type: ErrorsComponent, selector: "'[sv-ng-errors]'", inputs: ["element", "location"] }, { type: ElementHeaderComponent, selector: "'[sv-ng-element-header]'", inputs: ["element"] }, { type: SingleInputSummaryComponent, selector: "sv-single-input-summary", inputs: ["model", "css"] }, { type: ElementComponent, selector: "sv-ng-element", inputs: ["model"] }, { type: SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }, { type: SurveyCommentComponent, selector: "sv-ng-comment, '[sv-ng-comment]'", inputs: ["question"] }], directives: [{ type: i2__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: DynamicComponentDirective, selector: "[component]", inputs: ["component"] }, { type: VisibleDirective, selector: "[visible]", inputs: ["visible"] }] });
2031
+ QuestionComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: QuestionComponent, selector: "sv-ng-question", inputs: { model: "model", css: "css", survey: "survey" }, viewQueries: [{ propertyName: "rootEl", first: true, predicate: ["elementContainer"], descendants: true }], usesInheritance: true, ngImport: i0__namespace, template: "<ng-template #template>\n <div *ngIf=\"!!model\" #elementContainer [class]=\"model.getRootCss()\" [style]=\"model.getRootStyle()\" [id]=\"model.id\"\n [attr.data-name]=\"model.name\" [attr.role]=\"model.ariaRole\" [attr.aria-required]=\"model.ariaRequired\"\n [attr.aria-invalid]=\"model.ariaInvalid\" [attr.aria-label]=\"model.ariaLabel\"\n [attr.aria-labelledby]=\"model.ariaLabelledBy\" [attr.aria-describedby]=\"model.ariaDescribedBy\"\n [attr.aria-expanded]=\"model.ariaExpanded\">\n <sv-breadcrumbs\n *ngIf=\"model.singleInputHasActions\"\n [model]=\"model.singleInputActions\"\n [css]=\"model.cssClasses\"\n ></sv-breadcrumbs>\n <div *ngIf=\"model.showErrorsAboveQuestion && model.hasVisibleErrors\" [element]=\"model\" sv-ng-errors></div>\n <div [element]=\"model\" *ngIf=\"model.hasTitleOnLeftTop\" sv-ng-element-header></div>\n <sv-single-input-summary\n *ngIf=\"!!model.singleInputSummary\"\n [model]=\"model.singleInputSummary\"\n [css]=\"model.cssClasses\"\n ></sv-single-input-summary>\n <sv-ng-element\n *ngIf=\"!model.singleInputSummary && !!singleQuestion\"\n [model]=\"singleQuestion\"\n ></sv-ng-element>\n <ng-template\n *ngIf=\"!model.singleInputSummary && !singleQuestion\"\n [component]=\"{ name: getQuestionContentWrapperComponentName(), data: getQuestionContentWrapperComponentData() }\">\n <div [class]=\"model.cssContent\" role=\"presentation\" [visible]=\"model.renderedIsExpanded\" [attr.aria-hidden]=\"model.contentAriaHidden\" [attr.data-sv-drop-target-matrix-row]=\"model.dragDropMatrixAttribute\" [attr.data-sv-drop-target-matrix]=\"model.dragDropMatrixAttribute\">\n <ng-template\n [component]=\"{ name: getComponentName(), data: { model: model }, default: 'skeleton-question' }\"></ng-template>\n <div *ngIf=\"model.hasComment\" [class]=\"model.getCommentAreaCss(false)\">\n <div [model]=\"model.locCommentText\" sv-ng-string></div>\n <sv-ng-comment [question]=\"model\"></sv-ng-comment>\n </div>\n <div *ngIf=\"model.hasDescriptionUnderInput\" [class]=\"model.cssDescription\" [attr.id]=\"model.ariaDescriptionId\"\n [model]=\"model.locDescription\" sv-ng-string></div>\n </div>\n </ng-template>\n <div [element]=\"model\" *ngIf=\"model.hasTitleOnBottom\" sv-ng-element-header></div>\n <div *ngIf=\"model.showErrorsBelowQuestion && model.hasVisibleErrors\" [element]=\"model\" sv-ng-errors></div>\n </div>\n</ng-template>", components: [{ type: BreadcrumbsComponent, selector: "sv-breadcrumbs", inputs: ["model", "css"] }, { type: ErrorsComponent, selector: "'[sv-ng-errors]'", inputs: ["element", "location"] }, { type: ElementHeaderComponent, selector: "'[sv-ng-element-header]'", inputs: ["element"] }, { type: SingleInputSummaryComponent, selector: "sv-single-input-summary", inputs: ["model", "css"] }, { type: ElementComponent, selector: "sv-ng-element", inputs: ["model"] }, { type: SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }, { type: SurveyCommentComponent, selector: "sv-ng-comment, '[sv-ng-comment]'", inputs: ["question"] }], directives: [{ type: i2__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: DynamicComponentDirective, selector: "[component]", inputs: ["component"] }, { type: VisibleDirective, selector: "[visible]", inputs: ["visible"] }] });
2065
2032
  i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: QuestionComponent, decorators: [{
2066
2033
  type: i0.Component,
2067
2034
  args: [{
@@ -4115,7 +4082,7 @@
4115
4082
  return FileItemComponent;
4116
4083
  }(EmbeddedViewContentComponent));
4117
4084
  FileItemComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: FileItemComponent, deps: null, target: i0__namespace.ɵɵFactoryTarget.Component });
4118
- FileItemComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FileItemComponent, selector: "sv-ng-file-item", inputs: { item: "item", question: "question" }, usesInheritance: true, ngImport: i0__namespace, template: "<ng-template #template>\n <span [class]=\"question.cssClasses.previewItem\" (click)=\"question.doDownloadFileFromContainer($event)\">\n <div *ngIf=\"item.name && question.cssClasses.fileSign\" [class]=\"question.cssClasses.fileSign\">\n <a (click)=\"question.doDownloadFile($event, item)\" [attr.href]=\"item.content | safeUrl\"\n [attr.title]=\"item.name\" [attr.download]=\"item.name\" [style.width]=\"question.imageWidth\">{{\n item.name\n }}</a>\n </div>\n <div [class]=\"question.getImageWrapperCss(item)\">\n <img *ngIf=\"question.canPreviewImage(item)\" [attr.src]=\"item.content | safeUrl\"\n [style.height]=\"question.imageHeight\" [style.width]=\"question.imageWidth\" alt=\"File preview\" />\n <svg *ngIf=\"question.defaultImage(item)\" [iconName]=\"question.cssClasses.defaultImageIconId\"\n [partCss]=\"question.cssClasses.defaultImage\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n <div *ngIf=\"item.name && !question.isReadOnly\" [class]=\"question.getRemoveButtonCss()\"\n (click)=\"question.doRemoveFile(item, $event)\">\n <span [class]=\"question.cssClasses.removeFile\">{{ question.removeFileCaption }}</span>\n <svg *ngIf=\"question.cssClasses.removeFileSvgIconId\" [title]=\"question.removeFileCaption\"\n [partCss]=\"question.cssClasses.removeFileSvg\" [iconName]=\"question.cssClasses.removeFileSvgIconId\"\n [size]=\"'auto'\" sv-ng-svg-icon></svg>\n </div>\n </div>\n <div *ngIf=\"item.name && question.cssClasses.fileSignBottom\" [class]=\"question.cssClasses.fileSignBottom\">\n <a (click)=\"question.doDownloadFile($event, item)\" [attr.href]=\"item.content | safeUrl\"\n [attr.title]=\"item.name\" [attr.download]=\"item.name\" [style.width]=\"question.imageWidth\">{{\n item.name\n }}</a>\n </div>\n </span>\n</ng-template>", styles: [":host{display:none}\n"], components: [{ type: SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }], directives: [{ type: i2__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "safeUrl": SafeUrlPipe } });
4085
+ FileItemComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FileItemComponent, selector: "sv-ng-file-item", inputs: { item: "item", question: "question" }, usesInheritance: true, ngImport: i0__namespace, template: "<ng-template #template>\n <span [class]=\"question.cssClasses.previewItem\" (click)=\"question.doDownloadFileFromContainer($event)\">\n <div *ngIf=\"item.name && question.cssClasses.fileSign\" [class]=\"question.cssClasses.fileSign\">\n <a (click)=\"question.doDownloadFile($event, item)\" [attr.href]=\"item.content | safeUrl\"\n [attr.title]=\"item.name\" [attr.download]=\"item.name\" target=\"_blank\" rel=\"noreferrer\" [style.width]=\"question.imageWidth\">{{\n item.name\n }}</a>\n </div>\n <div [class]=\"question.getImageWrapperCss(item)\">\n <img *ngIf=\"question.canPreviewImage(item)\" [attr.src]=\"item.content | safeUrl\"\n [style.height]=\"question.imageHeight\" [style.width]=\"question.imageWidth\" alt=\"File preview\" />\n <svg *ngIf=\"question.defaultImage(item)\" [iconName]=\"question.cssClasses.defaultImageIconId\"\n [partCss]=\"question.cssClasses.defaultImage\" [size]=\"'auto'\" sv-ng-svg-icon></svg>\n <div *ngIf=\"item.name && !question.isReadOnly\" [class]=\"question.getRemoveButtonCss()\"\n (click)=\"question.doRemoveFile(item, $event)\">\n <span [class]=\"question.cssClasses.removeFile\">{{ question.removeFileCaption }}</span>\n <svg *ngIf=\"question.cssClasses.removeFileSvgIconId\" [title]=\"question.removeFileCaption\"\n [partCss]=\"question.cssClasses.removeFileSvg\" [iconName]=\"question.cssClasses.removeFileSvgIconId\"\n [size]=\"'auto'\" sv-ng-svg-icon></svg>\n </div>\n </div>\n <div *ngIf=\"item.name && question.cssClasses.fileSignBottom\" [class]=\"question.cssClasses.fileSignBottom\">\n <a (click)=\"question.doDownloadFile($event, item)\" [attr.href]=\"item.content | safeUrl\"\n [attr.title]=\"item.name\" [attr.download]=\"item.name\" target=\"_blank\" rel=\"noreferrer\" [style.width]=\"question.imageWidth\">{{\n item.name\n }}</a>\n </div>\n </span>\n</ng-template>", styles: [":host{display:none}\n"], components: [{ type: SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }], directives: [{ type: i2__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "safeUrl": SafeUrlPipe } });
4119
4086
  i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: FileItemComponent, decorators: [{
4120
4087
  type: i0.Component,
4121
4088
  args: [{
@@ -4571,7 +4538,7 @@
4571
4538
  return PanelDynamicPrevBtn;
4572
4539
  }(PaneldynamicAction));
4573
4540
  PanelDynamicPrevBtn.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: PanelDynamicPrevBtn, deps: null, target: i0__namespace.ɵɵFactoryTarget.Component });
4574
- PanelDynamicPrevBtn.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0__namespace, 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"] }] });
4541
+ PanelDynamicPrevBtn.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PanelDynamicPrevBtn, selector: "sv-ng-paneldynamic-prev-btn", usesInheritance: true, ngImport: i0__namespace, 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"] }] });
4575
4542
  i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0__namespace, type: PanelDynamicPrevBtn, decorators: [{
4576
4543
  type: i0.Component,
4577
4544
  args: [{