UNPKG

survey-creator-angular

Version:

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

75 lines 14 kB
import { Component, ElementRef, Input, ViewChild } from "@angular/core"; import { AngularComponentFactory } from "survey-angular-ui"; import { ItemValueWrapperViewModel } from "survey-creator-core"; import { CreatorModelComponent } from "../creator-model.component"; import * as i0 from "@angular/core"; import * as i1 from "survey-angular-ui"; import * as i2 from "@angular/common"; export class ItemValueDesignerComponent extends CreatorModelComponent { get creator() { return this.componentData.data.creator; } get question() { return this.componentData.question; } get item() { return this.componentData.model; } onBlur(event) { this.adorner.onFocusOut(event); } setupContainer() { var _a; if (this.item && ((_a = this.container) === null || _a === void 0 ? void 0 : _a.nativeElement)) { this.item.setRootElement(this.container.nativeElement); } } cleanContainer(item) { if (!!item) { item.setRootElement(undefined); } } createModel() { if (this.componentData) { this.adorner = new ItemValueWrapperViewModel(this.creator, this.question, this.item); if (this.prevItem !== this.item) { this.setupContainer(); this.cleanContainer(this.prevItem); this.prevItem = this.item; } } } getPropertiesToTrack() { return ["creator", "question", "item"]; } getModel() { return this.adorner; } ngOnDestroy() { super.ngOnDestroy(); this.adorner.dispose(); this.cleanContainer(this.item); } ngAfterViewInit() { this.setupContainer(); } } ItemValueDesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ItemValueDesignerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); ItemValueDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ItemValueDesignerComponent, selector: "svc-item-value", inputs: { componentName: "componentName", componentData: "componentData" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <div class=\"svc-item-value-wrapper\" (pointerdown)=\"adorner.onPointerDown($event)\"\n [attr.data-sv-drop-target-item-value]=\"adorner.isDraggable ? item.value : null\"\n [ngClass]=\"{'svc-item-value--new': adorner.isNew, 'svc-item-value--dragging': adorner.isDragging, 'svc-item-value--ghost': adorner.isDragDropGhost, 'svc-item-value--movedown': adorner.isDragDropMoveDown, 'svc-item-value--moveup': adorner.isDragDropMoveUp}\"\n #container>\n <div class=\"svc-item-value__ghost\"></div>\n <div class=\"svc-item-value-controls\">\n <span *ngIf=\"adorner.isDraggable\" class=\"svc-item-value-controls__button svc-item-value-controls__drag\">\n <svg class=\"svc-item-value-controls__drag-icon\" [iconName]=\"'icon-drag-24x24'\" [size]=\"'auto'\"\n [attr.title]=\"adorner.dragTooltip\" sv-ng-svg-icon></svg>\n </span>\n <span *ngIf=\"adorner.allowAdd\" class=\"svc-item-value-controls__button svc-item-value-controls__add\" [key2click]\n (click)=\"adorner.add(adorner)\" [attr.aria-label]=\"undefined\"><svg [iconName]=\"'icon-add_16x16'\" [size]=\"'auto'\"\n [attr.title]=\"undefined\" sv-ng-svg-icon></svg></span>\n <span *ngIf=\"adorner.allowRemove\" class=\"svc-item-value-controls__button svc-item-value-controls__remove\"\n [key2click] (click)=\"adorner.remove(adorner)\" (blur)=\"onBlur($event)\" [attr.aria-label]=\"undefined\"><svg\n [iconName]=\"'icon-remove_16x16'\" [size]=\"'auto'\" [attr.title]=\"undefined\" sv-ng-svg-icon></svg></span>\n </div>\n\n <div class=\"svc-item-value__item\" (click)=\"adorner.select(adorner, $event)\">\n <ng-template [component]=\"{ name: componentName, data: componentData }\"></ng-template>\n </div>\n </div>\n</ng-template>", styles: [":host { display: none; }"], components: [{ type: i1.SvgIconComponent, selector: "'[sv-ng-svg-icon]'", inputs: ["size", "width", "height", "iconName", "partCss", "css", "title"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.Key2ClickDirective, selector: "[key2click]", inputs: ["key2click"] }, { type: i1.DynamicComponentDirective, selector: "[component]", inputs: ["component"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ItemValueDesignerComponent, decorators: [{ type: Component, args: [{ selector: "svc-item-value", templateUrl: "./item-value.component.html", styles: [":host { display: none; }"] }] }], propDecorators: { componentName: [{ type: Input }], componentData: [{ type: Input }], container: [{ type: ViewChild, args: ["container", { read: ElementRef }] }] } }); AngularComponentFactory.Instance.registerComponent("svc-item-value", ItemValueDesignerComponent); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-value.component.js","sourceRoot":"","sources":["../../../src/adorners/item-value.component.ts","../../../src/adorners/item-value.component.html"],"names":[],"mappings":"AACA,OAAO,EAAoC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC5H,OAAO,EAAE,uBAAuB,EAA6C,MAAM,mBAAmB,CAAC;AAEvG,OAAO,EAAsB,yBAAyB,EAA4B,MAAM,qBAAqB,CAAC;AAC9G,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;;;;AAOnE,MAAM,OAAO,0BAA2B,SAAQ,qBAAgD;IAM9F,IAAY,OAAO;QACjB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC;IACzC,CAAC;IACD,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC;IACrC,CAAC;IACD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAClC,CAAC;IACM,MAAM,CAAC,KAAU;QACtB,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAEO,cAAc;;QACpB,IAAI,IAAI,CAAC,IAAI,KAAI,MAAA,IAAI,CAAC,SAAS,0CAAE,aAAa,CAAA,EAAE;YAC9C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;SACxD;IACH,CAAC;IACO,cAAc,CAAC,IAAe;QACpC,IAAG,CAAC,CAAC,IAAI,EAAE;YACT,IAAI,CAAC,cAAc,CAAC,SAAgB,CAAC,CAAC;SACvC;IACH,CAAC;IAES,WAAW;QACnB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,yBAAyB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACrF,IAAG,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,EAAE;gBAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACnC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;aAC3B;SACF;IACH,CAAC;IACS,oBAAoB;QAC5B,OAAO,CAAC,SAAS,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IACzC,CAAC;IACS,QAAQ;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IACQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IACD,eAAe;QACb,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;wHArDU,0BAA0B;4GAA1B,0BAA0B,qNAGL,UAAU,oDCf5C,qwDAuBc;4FDXD,0BAA0B;kBALtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,6BAA6B;oBAC1C,MAAM,EAAE,CAAC,0BAA0B,CAAC;iBACrC;8BAEU,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACwC,SAAS;sBAAtD,SAAS;uBAAC,WAAW,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;;AAqD9C,uBAAuB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,0BAA0B,CAAC,CAAC","sourcesContent":["\nimport { AfterViewInit, ChangeDetectorRef, Component, ElementRef, Input, ViewChild, ViewContainerRef } from \"@angular/core\";\nimport { AngularComponentFactory, BaseAngular, EmbeddedViewContentComponent } from \"survey-angular-ui\";\nimport { ItemValue, PageModel, PanelModel, Question, QuestionSelectBase, SurveyModel } from \"survey-core\";\nimport { SurveyCreatorModel, ItemValueWrapperViewModel, QuestionAdornerViewModel } from \"survey-creator-core\";\nimport { CreatorModelComponent } from \"../creator-model.component\";\n\n@Component({\n  selector: \"svc-item-value\",\n  templateUrl: \"./item-value.component.html\",\n  styles: [\":host { display: none; }\"]\n})\nexport class ItemValueDesignerComponent extends CreatorModelComponent<ItemValueWrapperViewModel> implements AfterViewInit {\n  @Input() componentName!: string;\n  @Input() componentData!: any;\n  @ViewChild(\"container\", { read: ElementRef }) container!: ElementRef<HTMLDivElement>\n  public adorner!: ItemValueWrapperViewModel;\n  private prevItem!: ItemValue;\n  private get creator(): SurveyCreatorModel {\n    return this.componentData.data.creator;\n  }\n  public get question(): QuestionSelectBase {\n    return this.componentData.question;\n  }\n  public get item(): ItemValue {\n    return this.componentData.model;\n  }\n  public onBlur(event: any) {\n    this.adorner.onFocusOut(event);\n  }\n\n  private setupContainer() {\n    if (this.item && this.container?.nativeElement) {\n      this.item.setRootElement(this.container.nativeElement);\n    }\n  }\n  private cleanContainer(item: ItemValue) {\n    if(!!item) {\n      item.setRootElement(undefined as any);\n    }\n  }\n\n  protected createModel(): void {\n    if (this.componentData) {\n      this.adorner = new ItemValueWrapperViewModel(this.creator, this.question, this.item);\n      if(this.prevItem !== this.item) {\n        this.setupContainer();\n        this.cleanContainer(this.prevItem);\n        this.prevItem = this.item;\n      }\n    }\n  }\n  protected getPropertiesToTrack(): string[] {\n    return [\"creator\", \"question\", \"item\"];\n  }\n  protected getModel(): ItemValueWrapperViewModel {\n    return this.adorner;\n  }\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this.adorner.dispose();\n    this.cleanContainer(this.item);\n  }\n  ngAfterViewInit() {\n    this.setupContainer();\n  }\n}\n\nAngularComponentFactory.Instance.registerComponent(\"svc-item-value\", ItemValueDesignerComponent);\n","<ng-template #template>\n  <div class=\"svc-item-value-wrapper\" (pointerdown)=\"adorner.onPointerDown($event)\"\n    [attr.data-sv-drop-target-item-value]=\"adorner.isDraggable ? item.value : null\"\n    [ngClass]=\"{'svc-item-value--new': adorner.isNew, 'svc-item-value--dragging': adorner.isDragging, 'svc-item-value--ghost': adorner.isDragDropGhost, 'svc-item-value--movedown': adorner.isDragDropMoveDown, 'svc-item-value--moveup': adorner.isDragDropMoveUp}\"\n    #container>\n    <div class=\"svc-item-value__ghost\"></div>\n    <div class=\"svc-item-value-controls\">\n      <span *ngIf=\"adorner.isDraggable\" class=\"svc-item-value-controls__button svc-item-value-controls__drag\">\n        <svg class=\"svc-item-value-controls__drag-icon\" [iconName]=\"'icon-drag-24x24'\" [size]=\"'auto'\"\n          [attr.title]=\"adorner.dragTooltip\" sv-ng-svg-icon></svg>\n      </span>\n      <span *ngIf=\"adorner.allowAdd\" class=\"svc-item-value-controls__button svc-item-value-controls__add\" [key2click]\n        (click)=\"adorner.add(adorner)\" [attr.aria-label]=\"undefined\"><svg [iconName]=\"'icon-add_16x16'\" [size]=\"'auto'\"\n          [attr.title]=\"undefined\" sv-ng-svg-icon></svg></span>\n      <span *ngIf=\"adorner.allowRemove\" class=\"svc-item-value-controls__button svc-item-value-controls__remove\"\n        [key2click] (click)=\"adorner.remove(adorner)\" (blur)=\"onBlur($event)\" [attr.aria-label]=\"undefined\"><svg\n          [iconName]=\"'icon-remove_16x16'\" [size]=\"'auto'\" [attr.title]=\"undefined\" sv-ng-svg-icon></svg></span>\n    </div>\n\n    <div class=\"svc-item-value__item\" (click)=\"adorner.select(adorner, $event)\">\n      <ng-template [component]=\"{ name: componentName, data: componentData }\"></ng-template>\n    </div>\n  </div>\n</ng-template>"]}