UNPKG

survey-creator-angular

Version:

Use SurveyJS Creator to create or edit JSON for SurveyJS Form Library.

123 lines 20.1 kB
import { Component, Input, ViewChild } from "@angular/core"; import { StringEditorViewModelBase, editableStringRendererName } from "survey-creator-core"; import { CreatorModelComponent } from "./creator-model.component"; import { AngularComponentFactory } from "survey-angular-ui"; import * as i0 from "@angular/core"; import * as i1 from "survey-angular-ui"; import * as i2 from "@angular/common"; export class StringEditorComponent extends CreatorModelComponent { constructor(cdr, vcr, ngZone) { super(cdr, vcr); this.ngZone = ngZone; this.justFocused = false; this.onChangeHandler = () => { this.detectChanges(); }; } createModel() { this.baseModel = new StringEditorViewModelBase(this.locString, this.creator); this.baseModel.setLocString(this.locString); this.baseModel.blurEditor = () => { this.container.nativeElement.blur(); this.container.nativeElement.spellcheck = false; }; this.baseModel.getEditorElement = () => this.container.nativeElement; this.ngZone.runOutsideAngular(() => { setTimeout(() => this.baseModel.afterRender()); }); } get locString() { return this.model.locStr; } get creator() { return this.model.creator; } getModel() { return this.baseModel; } getPropertiesToTrack() { return ["creator", "locString"]; } get placeholder() { return this.baseModel.placeholder; } get contentEditable() { return this.baseModel.contentEditable; } get characterCounter() { return this.baseModel.characterCounter; } get showCharacterCounter() { return this.baseModel.showCharacterCounter; } get getCharacterCounterClass() { return this.baseModel.getCharacterCounterClass; } get className() { return this.baseModel.className(this.locString.renderedHtml); } get errorText() { return this.baseModel.errorText; } onBlur(event) { this.container.nativeElement.spellcheck = false; this.locString.__isEditing = false; this.justFocused = false; this.baseModel.onBlur(event); return this.baseModel.errorText; } onFocus(event) { this.baseModel.onFocus(event); this.justFocused = true; } onPaste(event) { this.baseModel.onPaste(event); } done(event) { this.baseModel.done(event); this.locString.__isEditing = false; } edit(event) { this.container.nativeElement.focus(); this.locString.__isEditing = true; this.baseModel.onClick(event); } ngOnInit() { var _a; super.ngOnInit(); (_a = this.locString) === null || _a === void 0 ? void 0 : _a.onStringChanged.add(this.onChangeHandler); } ngAfterViewInit() { if (this.locString.__isEditing) { this.container.nativeElement.focus(); } } ngOnDestroy() { var _a; this.baseModel.blurEditor = undefined; this.baseModel.getEditorElement = undefined; this.baseModel.dispose(); (_a = this.locString) === null || _a === void 0 ? void 0 : _a.onStringChanged.remove(this.onChangeHandler); super.ngOnDestroy(); } get ariaLabel() { return this.placeholder || "content editable"; } } StringEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: StringEditorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); StringEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: StringEditorComponent, selector: "svc-string-edtior", inputs: { model: "model" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <span [class]=\"className\">\n <span class=\"svc-string-editor__content\">\n <div class=\"svc-string-editor__border svc-string-editor__border--hover\"></div>\n <div class=\"svc-string-editor__border svc-string-editor__border--focus\"></div>\n <span class=\"svc-string-editor__input\">\n <span role=\"textbox\" *ngIf=\"!locString.hasHtml\" class=\"sv-string-editor\" spellcheck=\"false\"\n (focus)=\"onFocus($event)\" (paste)=\"onPaste($event)\" (blur)=\"onBlur($event)\" (input)=\"baseModel.onInput($event)\" (keydown)=\"baseModel.onKeyDown($event)\" (keyup)=\"baseModel.onKeyUp($event)\" (compositionstart)=\"baseModel.onCompositionStart($event)\" (compositionend)=\"baseModel.onCompositionEnd($event)\" (mouseup)=\"baseModel.onMouseUp($event)\" (click)=\"edit($event)\" [textContent]=\"locString.renderedHtml\" [attr.aria-placeholder]=\"placeholder\" [attr.aria-label]=\"ariaLabel\" [attr.contenteditable]=\"contentEditable\" #container></span>\n <span role=\"textbox\" *ngIf=\"locString.hasHtml\" class=\"sv-string-editor sv-string-editor--html\" spellcheck=\"false\"\n (focus)=\"onFocus($event)\" (blur)=\"onBlur($event)\" (keydown)=\"baseModel.onKeyDown($event)\" (keyup)=\"baseModel.onKeyUp($event)\" (compositionstart)=\"baseModel.onCompositionStart($event)\" (compositionend)=\"baseModel.onCompositionEnd($event)\" (mouseup)=\"baseModel.onMouseUp($event)\"\n (click)=\"edit($event)\" [attr.aria-placeholder]=\"placeholder\" [attr.aria-label]=\"ariaLabel\" [attr.contenteditable]=\"contentEditable\" [innerHtml]=\"locString.renderedHtml | safeHtml\" #container></span>\n <sv-ng-character-counter *ngIf=\"showCharacterCounter\" [counter]=\"characterCounter\" [remainingCharacterCounter]=\"getCharacterCounterClass\"></sv-ng-character-counter>\n </span>\n </span>\n <span *ngIf=\"errorText\" class=\"svc-string-editor__error\">{{errorText}}</span>\n </span>\n</ng-template>", styles: [":host { display: none; }"], components: [{ type: i1.CharacterCounterComponent, selector: "sv-ng-character-counter", inputs: ["counter", "remainingCharacterCounter"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "safeHtml": i1.SafeHtmlPipe } }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: StringEditorComponent, decorators: [{ type: Component, args: [{ selector: "svc-string-edtior", templateUrl: "./string-editor.component.html", styles: [":host { display: none; }"] }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }]; }, propDecorators: { model: [{ type: Input }], container: [{ type: ViewChild, args: ["container"] }] } }); AngularComponentFactory.Instance.registerComponent(editableStringRendererName, StringEditorComponent); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"string-editor.component.js","sourceRoot":"","sources":["../../src/string-editor.component.ts","../../src/string-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, Input, NgZone, ViewChild, ViewContainerRef } from \"@angular/core\";\nimport { LocalizableString, CharacterCounter } from \"survey-core\";\nimport { StringEditorViewModelBase, SurveyCreatorModel, editableStringRendererName } from \"survey-creator-core\";\nimport { CreatorModelComponent } from \"./creator-model.component\";\nimport { AngularComponentFactory } from \"survey-angular-ui\";\n\n@Component({\n  selector: \"svc-string-edtior\",\n  templateUrl: \"./string-editor.component.html\",\n  styles: [\":host { display: none; }\"]\n})\nexport class StringEditorComponent extends CreatorModelComponent<StringEditorViewModelBase> implements AfterViewInit {\n  public baseModel!: StringEditorViewModelBase;\n  private justFocused: boolean = false;\n  @Input() model!: any;\n  @ViewChild(\"container\") container!: ElementRef<HTMLElement>;\n  constructor(cdr: ChangeDetectorRef, vcr: ViewContainerRef, private ngZone: NgZone) {\n    super(cdr, vcr);\n  }\n  public createModel(): void {\n    this.baseModel = new StringEditorViewModelBase(this.locString, this.creator);\n    this.baseModel.setLocString(this.locString);\n    this.baseModel.blurEditor = () => {\n      this.container.nativeElement.blur();\n      this.container.nativeElement.spellcheck = false;\n    };\n    this.baseModel.getEditorElement = () => this.container.nativeElement;\n    this.ngZone.runOutsideAngular(() => {\n      setTimeout(() => this.baseModel.afterRender());\n    });\n  }\n  public get locString(): LocalizableString {\n    return this.model.locStr;\n  }\n  public get creator(): SurveyCreatorModel {\n    return this.model.creator;\n  }\n  protected getModel(): StringEditorViewModelBase {\n    return this.baseModel;\n  }\n  protected getPropertiesToTrack(): string[] {\n    return [\"creator\", \"locString\"];\n  }\n  public get placeholder(): string {\n    return this.baseModel.placeholder;\n  }\n  public get contentEditable(): boolean {\n    return this.baseModel.contentEditable;\n  }\n  public get characterCounter(): CharacterCounter {\n    return this.baseModel.characterCounter;\n  }\n  public get showCharacterCounter(): boolean {\n    return this.baseModel.showCharacterCounter;\n  }\n  public get getCharacterCounterClass(): string {\n    return this.baseModel.getCharacterCounterClass;\n  }\n\n  public get className(): string {\n    return this.baseModel.className(this.locString.renderedHtml);\n  }\n  public get errorText(): string {\n    return this.baseModel.errorText;\n  }\n  onChangeHandler = (): void => {\n    this.detectChanges();\n  };\n  public onBlur(event: any): string {\n    this.container.nativeElement.spellcheck = false;\n    (<any>this.locString).__isEditing = false;\n    this.justFocused = false;\n    this.baseModel.onBlur(event);\n    return this.baseModel.errorText;\n  }\n  public onFocus(event: any): void {\n    this.baseModel.onFocus(event);\n    this.justFocused = true;\n  }\n  public onPaste(event: any): void {\n    this.baseModel.onPaste(event);\n  }\n  public done(event: any): void {\n    this.baseModel.done(event);\n    (<any>this.locString).__isEditing = false;\n  }\n  public edit(event: any): void {\n    this.container.nativeElement.focus();\n    (<any>this.locString).__isEditing = true;\n    this.baseModel.onClick(event);\n  }\n  override ngOnInit(): void {\n    super.ngOnInit();\n    this.locString?.onStringChanged.add(this.onChangeHandler);\n  }\n  ngAfterViewInit(): void {\n    if ((<any>this.locString).__isEditing) {\n      this.container.nativeElement.focus();\n    }\n  }\n  override ngOnDestroy(): void {\n    this.baseModel.blurEditor = undefined as any;\n    this.baseModel.getEditorElement = undefined as any;\n    this.baseModel.dispose();\n    this.locString?.onStringChanged.remove(this.onChangeHandler);\n    super.ngOnDestroy();\n  }\n  get ariaLabel(): string {\n    return this.placeholder || \"content editable\";\n  }\n}\n\nAngularComponentFactory.Instance.registerComponent(editableStringRendererName, StringEditorComponent);","<ng-template #template>\n  <span [class]=\"className\">\n    <span class=\"svc-string-editor__content\">\n      <div class=\"svc-string-editor__border svc-string-editor__border--hover\"></div>\n        <div class=\"svc-string-editor__border svc-string-editor__border--focus\"></div>\n        <span class=\"svc-string-editor__input\">\n          <span role=\"textbox\" *ngIf=\"!locString.hasHtml\" class=\"sv-string-editor\" spellcheck=\"false\"\n              (focus)=\"onFocus($event)\" (paste)=\"onPaste($event)\" (blur)=\"onBlur($event)\"  (input)=\"baseModel.onInput($event)\" (keydown)=\"baseModel.onKeyDown($event)\" (keyup)=\"baseModel.onKeyUp($event)\" (compositionstart)=\"baseModel.onCompositionStart($event)\" (compositionend)=\"baseModel.onCompositionEnd($event)\" (mouseup)=\"baseModel.onMouseUp($event)\" (click)=\"edit($event)\" [textContent]=\"locString.renderedHtml\" [attr.aria-placeholder]=\"placeholder\" [attr.aria-label]=\"ariaLabel\" [attr.contenteditable]=\"contentEditable\" #container></span>\n          <span role=\"textbox\" *ngIf=\"locString.hasHtml\" class=\"sv-string-editor sv-string-editor--html\" spellcheck=\"false\"\n          (focus)=\"onFocus($event)\" (blur)=\"onBlur($event)\" (keydown)=\"baseModel.onKeyDown($event)\" (keyup)=\"baseModel.onKeyUp($event)\" (compositionstart)=\"baseModel.onCompositionStart($event)\" (compositionend)=\"baseModel.onCompositionEnd($event)\" (mouseup)=\"baseModel.onMouseUp($event)\"\n          (click)=\"edit($event)\" [attr.aria-placeholder]=\"placeholder\" [attr.aria-label]=\"ariaLabel\" [attr.contenteditable]=\"contentEditable\" [innerHtml]=\"locString.renderedHtml | safeHtml\" #container></span>\n          <sv-ng-character-counter *ngIf=\"showCharacterCounter\" [counter]=\"characterCounter\" [remainingCharacterCounter]=\"getCharacterCounterClass\"></sv-ng-character-counter>\n        </span>\n    </span>\n    <span *ngIf=\"errorText\" class=\"svc-string-editor__error\">{{errorText}}</span>\n  </span>\n</ng-template>"]}