UNPKG

survey-angular-ui

Version:

A free MIT-licensed Angular UI component that renders dynamic, interactive JSON-based forms and surveys. You can use it to collect responses from users and send them to your own database.

128 lines 16.3 kB
import { Component } from "@angular/core"; import { EmbeddedViewContentComponent } from "./embedded-view-content.component"; import * as i0 from "@angular/core"; export class BaseAngular extends EmbeddedViewContentComponent { constructor(changeDetectorRef, viewContainerRef) { super(viewContainerRef); this.changeDetectorRef = changeDetectorRef; this.isModelSubsribed = false; this.isDestroyed = false; this.onArrayChangedCallback = (stateElement, options) => { this.update(options.name); }; this.onPropertyChangedCallback = (stateElement, options) => { this.update(options.name); }; this.isUpdatesBlocked = false; } get surveyModel() { return this.getModel().getSurvey(); } ngDoCheck() { super.ngDoCheck(); if (this.previousModel !== this.getModel()) { this.unMakeBaseElementAngular(this.previousModel); this.makeBaseElementAngular(this.getModel()); this.onModelChanged(); this.previousModel = this.getModel(); } this.setIsModelRendering(true); } onModelChanged() { } setIsModelRendering(val) { const model = this.getModel(); if (!!model) { model.isRendering = val; } } getIsModelRendering(stateElement) { const model = stateElement !== null && stateElement !== void 0 ? stateElement : this.getModel(); return !!model && !!model.isRendering; } ngOnDestroy() { this.isDestroyed = true; this.unMakeBaseElementAngular(this.getModel()); this.previousModel = undefined; } isBaseElementSubsribed(stateElement) { var _a; return ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) > 0; } makeBaseElementAngular(stateElement) { var _a; if (!!stateElement && !this.getIsModelRendering(stateElement)) { this.isModelSubsribed = true; stateElement.addOnArrayChangedCallback(this.onArrayChangedCallback); stateElement.addOnPropertyValueChangedCallback(this.onPropertyChangedCallback); stateElement.enableOnElementRerenderedEvent(); stateElement.__ngImplementedCount = ((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) + 1; } } unMakeBaseElementAngular(stateElement) { var _a; if (!!stateElement && this.isModelSubsribed) { this.isModelSubsribed = false; stateElement.removeOnPropertyValueChangedCallback(this.onPropertyChangedCallback); stateElement.removeOnArrayChangedCallback(this.onArrayChangedCallback); stateElement.disableOnElementRerenderedEvent(); if (((_a = stateElement.__ngImplementedCount) !== null && _a !== void 0 ? _a : 0) - 1 <= 0) { delete stateElement.__ngImplementedCount; } } } update(key) { if (this.getIsModelRendering() || this.isUpdatesBlocked) return; if (key && this.getPropertiesToUpdateSync().indexOf(key) > -1) { this.beforeUpdate(); this.detectChanges(); this.afterUpdate(true); } else { this.isUpdatesBlocked = true; queueMicrotask(() => { if (!this.isDestroyed) { this.isUpdatesBlocked = false; this.beforeUpdate(); this.detectChanges(); this.afterUpdate(); } }); } } getChangeDetectorRef() { return this.embeddedView ? this.embeddedView : this.changeDetectorRef; } getPropertiesToUpdateSync() { return []; } detectChanges() { this.getChangeDetectorRef().detectChanges(); } getShouldReattachChangeDetector() { return true; } beforeUpdate() { this.setIsModelRendering(true); } afterUpdate(isSync = false) { this.setIsModelRendering(false); const model = this.getModel(); if (model && !this.isDestroyed) { model.afterRerender(); } } ngAfterViewChecked() { super.ngAfterViewChecked(); this.setIsModelRendering(false); } } 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 }); BaseAngular.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: BaseAngular, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "", isInline: true }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseAngular, decorators: [{ type: Component, args: [{ template: "" }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }]; } }); //# 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}"]}