survey-angular-ui 1.9.123 → 1.9.124

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.
@@ -1,108 +1,33 @@
1
- import { Component, Input, ViewChild } from "@angular/core";
2
- import { BaseAngular } from "../base-angular";
3
- import { getComponentName } from "../question";
1
+ import { Component, Input } from "@angular/core";
2
+ import { AngularComponentFactory } from "../component-factory";
4
3
  import * as i0 from "@angular/core";
5
- import * as i1 from "../components/matrix-actions/drag-drop-icon/drag-drop-icon";
6
- import * as i2 from "../components/action-bar/action-bar.component";
7
- import * as i3 from "../errors.component";
8
- import * as i4 from "./selectbase-item";
9
- import * as i5 from "../comment-other.component";
10
- import * as i6 from "../survey-string.component";
11
- import * as i7 from "@angular/common";
12
- import * as i8 from "../utils/dynamic.directive";
13
- import * as i9 from "../utils/ng-show.directive";
14
- export class MatrixCellComponent extends BaseAngular {
15
- getModel() {
16
- if (this.cell.hasQuestion) {
17
- return this.cell.question;
18
- }
19
- return null;
4
+ import * as i1 from "../survey-string.component";
5
+ import * as i2 from "@angular/common";
6
+ export class MatrixCellComponent {
7
+ constructor() {
20
8
  }
21
- get row() {
22
- return this.cell.row;
23
- }
24
- ngDoCheck() {
25
- var _a;
26
- super.ngDoCheck();
27
- if (this.cell.isErrorsCell && ((_a = this.cell) === null || _a === void 0 ? void 0 : _a.question)) {
28
- this.cell.question.registerFunctionOnPropertyValueChanged("errors", () => {
29
- this.update();
30
- }, "__ngSubscription");
31
- }
32
- }
33
- get panelComponentName() {
34
- const panel = this.cell.panel;
35
- const survey = panel.survey;
36
- if (!!survey) {
37
- const name = survey.getElementWrapperComponentName(panel);
38
- if (!!name) {
39
- return name;
40
- }
41
- }
42
- return "panel";
43
- }
44
- get panelComponentData() {
45
- const panel = this.cell.panel;
46
- const survey = panel.survey;
47
- let data;
48
- if (!!survey) {
49
- data = survey.getElementWrapperComponentData(panel);
50
- }
51
- return {
52
- componentName: "panel",
53
- componentData: {
54
- model: panel,
55
- data: data
56
- }
57
- };
58
- }
59
- getComponentName(element) { return getComponentName(element); }
60
- getHeaders() {
61
- return this.cell.headers;
62
- }
63
- getCellStyle() {
64
- if (!!this.cell.width || !!this.cell.minWidth)
65
- return { width: this.cell.width, minWidth: this.cell.minWidth };
66
- return null;
67
- }
68
- ngAfterViewInit() {
69
- if (!this.cell.hasQuestion || !this.question || !this.question.survey)
70
- return;
71
- const el = this.cellContainer.nativeElement;
72
- const cellQ = this.cell.question;
73
- var options = {
74
- cell: this.cell.cell,
75
- cellQuestion: cellQ,
76
- htmlElement: el,
77
- row: this.cell.row,
78
- column: this.cell.cell.column,
79
- };
80
- this.question.survey.matrixAfterCellRender(this.question, options);
81
- cellQ.afterRenderCore(el);
82
- }
83
- ngOnDestroy() {
84
- var _a;
85
- super.ngOnDestroy();
86
- if (this.cell.isErrorsCell && ((_a = this.cell) === null || _a === void 0 ? void 0 : _a.question)) {
87
- this.cell.question.unRegisterFunctionOnPropertyValueChanged("errors", "__ngSubscription");
88
- }
9
+ onChange() {
10
+ this.cellChangedOwner.onCellChanged(this.row, this.column);
89
11
  }
90
12
  }
91
- MatrixCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixCellComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
92
- MatrixCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MatrixCellComponent, selector: "sv-ng-matrix-cell", inputs: { question: "question", cell: "cell" }, viewQueries: [{ propertyName: "cellContainer", first: true, predicate: ["cellContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <td [class]=\"cell.className\" [attr.data-responsive-title]=\"getHeaders()\" [title]=\"cell.getTitle()\"\n [style]=\"getCellStyle()\" [attr.colspan]=\"cell.colSpans\" (focusin)=\"cell.focusIn()\" #cellContainer>\n <sv-ng-matrix-drag-drop-icon *ngIf=\"cell.isDragHandlerCell\"\n [model]=\"$any({ data: { row: row, question: question } })\"></sv-ng-matrix-drag-drop-icon>\n <sv-action-bar *ngIf=\"cell.isActionsCell\" [model]=\"cell.item.getData()\" [handleClick]=\"false\"></sv-action-bar>\n <ng-container *ngIf=\"cell.hasPanel\">\n <ng-template [component]=\"{ name: panelComponentName, data: panelComponentData }\"></ng-template>\n </ng-container>\n <div *ngIf=\"cell.isErrorsCell && cell.question?.hasVisibleErrors\" [element]=\"cell.question\" sv-ng-errors></div>\n <div *ngIf=\"cell.hasQuestion\" [class]=\"question.cssClasses.cellQuestionWrapper\"\n [visible]=\"cell.question.isVisible\">\n <ng-container *ngIf=\"!cell.isChoice && cell.question.isDefaultRendering()\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n <ng-template\n [component]=\"{ name: getComponentName(cell.question), data: { model: cell.question } }\"></ng-template>\n </ng-template>\n </ng-container>\n <ng-template *ngIf=\"!cell.isChoice && !cell.question.isDefaultRendering()\"\n [component]=\"{ name: cell.question.getComponentName(), data: { model: cell.question } }\">\n </ng-template>\n <ng-container *ngIf=\"cell.isItemChoice\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n <sv-ng-selebase-item [showLabel]=\"false\" [inputType]=\"cell.isCheckbox ? 'checkbox': 'radio'\"\n [question]=\"cell.question\" [model]=\"cell.item\"></sv-ng-selebase-item>\n </ng-template>\n </ng-container>\n <div *ngIf=\"cell.isOtherChoice\" [class]=\"cell.question.getCommentAreaCss(true)\" [question]=\"cell.question\"\n sv-ng-comment-other></div>\n </div>\n <ng-container *ngIf=\"cell.hasTitle\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName($any(cell)), data: { componentData: question.getCellWrapperComponentData($any(cell))} }\">\n <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n <span *ngIf=\"!!cell.requiredText\" [class]=\"question.cssClasses.cellRequiredText\">{{ cell.requiredText }}</span>\n </ng-template>\n </ng-container>\n </td>\n</ng-template>", styles: [":host { display: none; }"], components: [{ type: i1.MatrixDynamicDragDropIconComponent, selector: "sv-ng-matrix-drag-drop-icon", inputs: ["model"] }, { type: i2.ActionBarComponent, selector: "sv-action-bar, sv-ng-action-bar", inputs: ["model", "handleClick"] }, { type: i3.ErrorsComponent, selector: "'[sv-ng-errors]'", inputs: ["element", "location"] }, { type: i4.SelectBaseItemComponent, selector: "['sv-ng-selectbase-item'], sv-ng-selebase-item", inputs: ["question", "model", "inputType", "showLabel"] }, { type: i5.SurveyCommentOtherComponent, selector: "sv-ng-comment-other, '[sv-ng-comment-other]'", inputs: ["question"] }, { type: i6.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.DynamicComponentDirective, selector: "[component]", inputs: ["component"] }, { type: i9.VisibleDirective, selector: "[visible]", inputs: ["visible"] }] });
13
+ MatrixCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixCellComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
14
+ MatrixCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MatrixCellComponent, selector: "sv-ng-matrix-cell, '[sv-ng-matrix-cell]'", inputs: { question: "question", column: "column", row: "row", columnIndex: "columnIndex", cellChangedOwner: "cellChangedOwner" }, ngImport: i0, template: "<label (mousedown)=\"question.onMouseDown()\" [class]=\"question.getItemClass(row, column)\">\n <input\n type=\"radio\"\n [class]=\"question.cssClasses.itemValue\"\n [name]=\"row.fullName\"\n [value]=\"column.value\"\n [checked]=\"row.value === column.value\"\n [disabled]=\"question.isInputReadOnly\"\n [attr.id]=\"question.inputId + '_' + row.name + '_' + columnIndex\"\n (change)=\"onChange()\"\n [attr.aria-required]=\"question.a11y_input_ariaRequired\"\n [attr.aria-label]=\"question.getCellAriaLabel(row.locText.renderedHtml, column.locText.renderedHtml)\"\n [attr.aria-invalid]=\"question.a11y_input_ariaInvalid\"\n [attr.aria-describedby]=\"question.a11y_input_ariaDescribedBy\"\n />\n <span [class]=\"question.cssClasses.materialDecorator\">\n <svg *ngIf=\"question.itemSvgIcon\" [class]=\"question.cssClasses.itemDecorator\">\n <use [attr.xlink:href]=\"question.itemSvgIcon\"></use>\n </svg> \n </span>\n <span *ngIf=\"question.isMobile\" [class]=\"question.cssClasses.cellResponsiveTitle\" [model]=\"column.locText\" sv-ng-string></span>\n</label>\n<ng-content></ng-content>", components: [{ type: i1.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
93
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixCellComponent, decorators: [{
94
16
  type: Component,
95
17
  args: [{
96
- selector: "sv-ng-matrix-cell",
97
- templateUrl: "./matrixcell.component.html",
98
- styles: [":host { display: none; }"]
18
+ selector: "sv-ng-matrix-cell, '[sv-ng-matrix-cell]'",
19
+ templateUrl: "./matrixcell.component.html"
99
20
  }]
100
- }], propDecorators: { question: [{
21
+ }], ctorParameters: function () { return []; }, propDecorators: { question: [{
22
+ type: Input
23
+ }], column: [{
24
+ type: Input
25
+ }], row: [{
26
+ type: Input
27
+ }], columnIndex: [{
101
28
  type: Input
102
- }], cell: [{
29
+ }], cellChangedOwner: [{
103
30
  type: Input
104
- }], cellContainer: [{
105
- type: ViewChild,
106
- args: ["cellContainer"]
107
31
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrixcell.component.js","sourceRoot":"","sources":["../../../src/questions/matrixcell.component.ts","../../../src/questions/matrixcell.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAQ9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;;;;;;;;;;;AAO/C,MAAM,OAAO,mBAAoB,SAAQ,WAAqB;IAK5D,QAAQ;QACN,IAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACxB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B;QACD,OAAO,IAAW,CAAC;IACrB,CAAC;IACD,IAAW,GAAG;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;IACvB,CAAC;IACe,SAAS;;QACvB,KAAK,CAAC,SAAS,EAAE,CAAC;QAClB,IAAG,IAAI,CAAC,IAAI,CAAC,YAAY,KAAI,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,CAAA,EAAE;YAChD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,sCAAsC,CAAC,QAAQ,EAAE,GAAG,EAAE;gBACvE,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC,EAAE,kBAAkB,CAAC,CAAA;SACvB;IACH,CAAC;IACD,IAAW,kBAAkB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAgB,KAAK,CAAC,MAAM,CAAC;QACzC,IAAG,CAAC,CAAC,MAAM,EAAE;YACX,MAAM,IAAI,GAAG,MAAM,CAAC,8BAA8B,CAAC,KAAK,CAAC,CAAC;YAC1D,IAAG,CAAC,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,IAAW,kBAAkB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAgB,KAAK,CAAC,MAAM,CAAC;QACzC,IAAI,IAAS,CAAC;QACd,IAAG,CAAC,CAAC,MAAM,EAAE;YACX,IAAI,GAAG,MAAM,CAAC,8BAA8B,CAAC,KAAK,CAAC,CAAC;SACrD;QACD,OAAO;YACL,aAAa,EAAE,OAAO;YACtB,aAAa,EAAE;gBACb,KAAK,EAAE,KAAK;gBACZ,IAAI,EAAE,IAAI;aACX;SACF,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,OAAiB,IAAI,OAAO,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACzE,UAAU;QACR,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;IAC3B,CAAC;IACD,YAAY;QACV,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ;YAC3C,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClE,OAAO,IAAI,CAAC;IACd,CAAC;IACD,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,OAAO;QAC9E,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;QACjC,IAAI,OAAO,GAAG;YACZ,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI;YACpB,YAAY,EAAE,KAAK;YACnB,WAAW,EAAE,EAAE;YACf,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG;YAClB,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;SAC9B,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACnE,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IACQ,WAAW;;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAG,IAAI,CAAC,IAAI,CAAC,YAAY,KAAI,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,CAAA,EAAE;YAChD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,wCAAwC,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAA;SAC1F;IACH,CAAC;;iHA7EU,mBAAmB;qGAAnB,mBAAmB,gPChBhC,srFAwCc;4FDxBD,mBAAmB;kBAL/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,mBAAmB;oBAC7B,WAAW,EAAE,6BAA6B;oBAC1C,MAAM,EAAE,CAAC,0BAA0B,CAAC;iBACrC;8BAEU,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEsB,aAAa;sBAAxC,SAAS;uBAAC,eAAe","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from \"@angular/core\";\nimport { BaseAngular } from \"../base-angular\";\nimport {\n  Question,\n  QuestionMatrixDropdownModelBase,\n  QuestionMatrixDropdownRenderedCell,\n  MatrixDropdownRowModelBase,\n  SurveyModel\n} from \"survey-core\";\nimport { getComponentName } from \"../question\";\n\n@Component({\n  selector: \"sv-ng-matrix-cell\",\n  templateUrl: \"./matrixcell.component.html\",\n  styles: [\":host { display: none; }\"]\n})\nexport class MatrixCellComponent extends BaseAngular<Question> {\n  @Input() question!: QuestionMatrixDropdownModelBase;\n  @Input() cell!: QuestionMatrixDropdownRenderedCell;\n\n  @ViewChild(\"cellContainer\") cellContainer!: ElementRef<HTMLElement>;\n  getModel() {\n    if(this.cell.hasQuestion) {\n      return this.cell.question;\n    }\n    return null as any;\n  }\n  public get row(): MatrixDropdownRowModelBase {\n    return this.cell.row;\n  }\n  public override ngDoCheck(): void {\n    super.ngDoCheck();\n    if(this.cell.isErrorsCell && this.cell?.question) {\n      this.cell.question.registerFunctionOnPropertyValueChanged(\"errors\", () => {\n        this.update();\n      }, \"__ngSubscription\")\n    }\n  }\n  public get panelComponentName(): string {\n    const panel = this.cell.panel;\n    const survey = <SurveyModel>panel.survey;\n    if(!!survey) {\n      const name = survey.getElementWrapperComponentName(panel);\n      if(!!name) {\n        return name;\n      }\n    }\n    return \"panel\";\n  }\n  public get panelComponentData(): any {\n    const panel = this.cell.panel;\n    const survey = <SurveyModel>panel.survey;\n    let data: any;\n    if(!!survey) {\n      data = survey.getElementWrapperComponentData(panel);\n    }\n    return {\n      componentName: \"panel\",\n      componentData: {\n        model: panel,\n        data: data\n      }\n    };\n  }\n\n  getComponentName(element: Question) { return getComponentName(element); }\n  getHeaders(): string {\n    return this.cell.headers;\n  }\n  getCellStyle() {\n    if (!!this.cell.width || !!this.cell.minWidth)\n      return { width: this.cell.width, minWidth: this.cell.minWidth };\n    return null;\n  }\n  ngAfterViewInit() {\n    if (!this.cell.hasQuestion || !this.question || !this.question.survey) return;\n    const el = this.cellContainer.nativeElement;\n    const cellQ = this.cell.question;\n    var options = {\n      cell: this.cell.cell,\n      cellQuestion: cellQ,\n      htmlElement: el,\n      row: this.cell.row,\n      column: this.cell.cell.column,\n    };\n    this.question.survey.matrixAfterCellRender(this.question, options);\n    cellQ.afterRenderCore(el);\n  }\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    if(this.cell.isErrorsCell && this.cell?.question) {\n      this.cell.question.unRegisterFunctionOnPropertyValueChanged(\"errors\", \"__ngSubscription\")    \n    }\n  }\n}","<ng-template #template>\n  <td [class]=\"cell.className\" [attr.data-responsive-title]=\"getHeaders()\" [title]=\"cell.getTitle()\"\n    [style]=\"getCellStyle()\" [attr.colspan]=\"cell.colSpans\" (focusin)=\"cell.focusIn()\" #cellContainer>\n    <sv-ng-matrix-drag-drop-icon *ngIf=\"cell.isDragHandlerCell\"\n      [model]=\"$any({ data: { row: row, question: question } })\"></sv-ng-matrix-drag-drop-icon>\n    <sv-action-bar *ngIf=\"cell.isActionsCell\" [model]=\"cell.item.getData()\" [handleClick]=\"false\"></sv-action-bar>\n    <ng-container *ngIf=\"cell.hasPanel\">\n      <ng-template [component]=\"{ name: panelComponentName, data: panelComponentData }\"></ng-template>\n    </ng-container>\n    <div *ngIf=\"cell.isErrorsCell && cell.question?.hasVisibleErrors\" [element]=\"cell.question\" sv-ng-errors></div>\n    <div *ngIf=\"cell.hasQuestion\" [class]=\"question.cssClasses.cellQuestionWrapper\"\n      [visible]=\"cell.question.isVisible\">\n      <ng-container *ngIf=\"!cell.isChoice && cell.question.isDefaultRendering()\">\n        <ng-template\n          [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n          <ng-template\n            [component]=\"{ name: getComponentName(cell.question), data: { model: cell.question } }\"></ng-template>\n        </ng-template>\n      </ng-container>\n      <ng-template *ngIf=\"!cell.isChoice && !cell.question.isDefaultRendering()\"\n        [component]=\"{ name: cell.question.getComponentName(), data: { model: cell.question } }\">\n      </ng-template>\n      <ng-container *ngIf=\"cell.isItemChoice\">\n        <ng-template\n          [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n          <sv-ng-selebase-item [showLabel]=\"false\" [inputType]=\"cell.isCheckbox ? 'checkbox': 'radio'\"\n            [question]=\"cell.question\" [model]=\"cell.item\"></sv-ng-selebase-item>\n        </ng-template>\n      </ng-container>\n      <div *ngIf=\"cell.isOtherChoice\" [class]=\"cell.question.getCommentAreaCss(true)\" [question]=\"cell.question\"\n        sv-ng-comment-other></div>\n    </div>\n    <ng-container *ngIf=\"cell.hasTitle\">\n      <ng-template\n        [component]=\"{ name: question.getCellWrapperComponentName($any(cell)), data: { componentData: question.getCellWrapperComponentData($any(cell))} }\">\n        <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n        <span *ngIf=\"!!cell.requiredText\" [class]=\"question.cssClasses.cellRequiredText\">{{ cell.requiredText }}</span>\n      </ng-template>\n    </ng-container>\n  </td>\n</ng-template>"]}
32
+ AngularComponentFactory.Instance.registerComponent("survey-matrix-cell", MatrixCellComponent);
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0cml4Y2VsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcXVlc3Rpb25zL21hdHJpeGNlbGwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vc3JjL3F1ZXN0aW9ucy9tYXRyaXhjZWxsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7O0FBVS9ELE1BQU0sT0FBTyxtQkFBbUI7SUFNOUI7SUFDQSxDQUFDO0lBQ00sUUFBUTtRQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0QsQ0FBQzs7aUhBVlUsbUJBQW1CO3FHQUFuQixtQkFBbUIsa05DWmhDLG1uQ0FzQnlCOzRGRFZaLG1CQUFtQjtrQkFKL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMENBQTBDO29CQUNwRCxXQUFXLEVBQUUsNkJBQTZCO2lCQUMzQzswRUFFVSxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxHQUFHO3NCQUFYLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7O0FBT1IsdUJBQXVCLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUFDLG9CQUFvQixFQUFFLG1CQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdHJpeFJvd01vZGVsLCBJdGVtVmFsdWUsIFF1ZXN0aW9uTWF0cml4TW9kZWwgfSBmcm9tIFwic3VydmV5LWNvcmVcIjtcbmltcG9ydCB7IEFuZ3VsYXJDb21wb25lbnRGYWN0b3J5IH0gZnJvbSBcIi4uL2NvbXBvbmVudC1mYWN0b3J5XCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5nTWF0cml4Q2VsbENoYW5nZWQge1xuICBvbkNlbGxDaGFuZ2VkKHJvdzogTWF0cml4Um93TW9kZWwsIGNvbHVtbjogSXRlbVZhbHVlKTogdm9pZDtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcInN2LW5nLW1hdHJpeC1jZWxsLCAnW3N2LW5nLW1hdHJpeC1jZWxsXSdcIixcbiAgdGVtcGxhdGVVcmw6IFwiLi9tYXRyaXhjZWxsLmNvbXBvbmVudC5odG1sXCJcbn0pXG5leHBvcnQgY2xhc3MgTWF0cml4Q2VsbENvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHF1ZXN0aW9uITogUXVlc3Rpb25NYXRyaXhNb2RlbDtcbiAgQElucHV0KCkgY29sdW1uITogSXRlbVZhbHVlO1xuICBASW5wdXQoKSByb3chOiBNYXRyaXhSb3dNb2RlbDtcbiAgQElucHV0KCkgY29sdW1uSW5kZXghOiBudW1iZXI7XG4gIEBJbnB1dCgpIGNlbGxDaGFuZ2VkT3duZXIhOiBJTmdNYXRyaXhDZWxsQ2hhbmdlZDtcbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cbiAgcHVibGljIG9uQ2hhbmdlKCk6IHZvaWQge1xuICAgIHRoaXMuY2VsbENoYW5nZWRPd25lci5vbkNlbGxDaGFuZ2VkKHRoaXMucm93LCB0aGlzLmNvbHVtbik7XG4gIH1cbn1cbkFuZ3VsYXJDb21wb25lbnRGYWN0b3J5Lkluc3RhbmNlLnJlZ2lzdGVyQ29tcG9uZW50KFwic3VydmV5LW1hdHJpeC1jZWxsXCIsIE1hdHJpeENlbGxDb21wb25lbnQpOyIsIjxsYWJlbCAobW91c2Vkb3duKT1cInF1ZXN0aW9uLm9uTW91c2VEb3duKClcIiBbY2xhc3NdPVwicXVlc3Rpb24uZ2V0SXRlbUNsYXNzKHJvdywgY29sdW1uKVwiPlxuICA8aW5wdXRcbiAgICB0eXBlPVwicmFkaW9cIlxuICAgIFtjbGFzc109XCJxdWVzdGlvbi5jc3NDbGFzc2VzLml0ZW1WYWx1ZVwiXG4gICAgW25hbWVdPVwicm93LmZ1bGxOYW1lXCJcbiAgICBbdmFsdWVdPVwiY29sdW1uLnZhbHVlXCJcbiAgICBbY2hlY2tlZF09XCJyb3cudmFsdWUgPT09IGNvbHVtbi52YWx1ZVwiXG4gICAgW2Rpc2FibGVkXT1cInF1ZXN0aW9uLmlzSW5wdXRSZWFkT25seVwiXG4gICAgW2F0dHIuaWRdPVwicXVlc3Rpb24uaW5wdXRJZCArICdfJyArIHJvdy5uYW1lICsgJ18nICsgY29sdW1uSW5kZXhcIlxuICAgIChjaGFuZ2UpPVwib25DaGFuZ2UoKVwiXG4gICAgW2F0dHIuYXJpYS1yZXF1aXJlZF09XCJxdWVzdGlvbi5hMTF5X2lucHV0X2FyaWFSZXF1aXJlZFwiXG4gICAgW2F0dHIuYXJpYS1sYWJlbF09XCJxdWVzdGlvbi5nZXRDZWxsQXJpYUxhYmVsKHJvdy5sb2NUZXh0LnJlbmRlcmVkSHRtbCwgY29sdW1uLmxvY1RleHQucmVuZGVyZWRIdG1sKVwiXG4gICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cInF1ZXN0aW9uLmExMXlfaW5wdXRfYXJpYUludmFsaWRcIlxuICAgIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwicXVlc3Rpb24uYTExeV9pbnB1dF9hcmlhRGVzY3JpYmVkQnlcIlxuICAvPlxuICA8c3BhbiBbY2xhc3NdPVwicXVlc3Rpb24uY3NzQ2xhc3Nlcy5tYXRlcmlhbERlY29yYXRvclwiPlxuICAgIDxzdmcgKm5nSWY9XCJxdWVzdGlvbi5pdGVtU3ZnSWNvblwiIFtjbGFzc109XCJxdWVzdGlvbi5jc3NDbGFzc2VzLml0ZW1EZWNvcmF0b3JcIj5cbiAgICAgIDx1c2UgW2F0dHIueGxpbms6aHJlZl09XCJxdWVzdGlvbi5pdGVtU3ZnSWNvblwiPjwvdXNlPlxuICAgIDwvc3ZnPiBcbiAgPC9zcGFuPlxuICA8c3BhbiAqbmdJZj1cInF1ZXN0aW9uLmlzTW9iaWxlXCIgW2NsYXNzXT1cInF1ZXN0aW9uLmNzc0NsYXNzZXMuY2VsbFJlc3BvbnNpdmVUaXRsZVwiIFttb2RlbF09XCJjb2x1bW4ubG9jVGV4dFwiIHN2LW5nLXN0cmluZz48L3NwYW4+XG48L2xhYmVsPlxuPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PiJdfQ==
@@ -0,0 +1,114 @@
1
+ import { Component, Input, ViewChild } from "@angular/core";
2
+ import { BaseAngular } from "../base-angular";
3
+ import { getComponentName } from "../question";
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../components/matrix-actions/drag-drop-icon/drag-drop-icon";
6
+ import * as i2 from "../components/action-bar/action-bar.component";
7
+ import * as i3 from "../errors.component";
8
+ import * as i4 from "./selectbase-item";
9
+ import * as i5 from "../comment-other.component";
10
+ import * as i6 from "../survey-string.component";
11
+ import * as i7 from "@angular/common";
12
+ import * as i8 from "../utils/dynamic.directive";
13
+ import * as i9 from "../utils/ng-show.directive";
14
+ export class MatrixDropdownCellComponent extends BaseAngular {
15
+ getModel() {
16
+ if (this.cell.hasQuestion) {
17
+ return this.cell.question;
18
+ }
19
+ if (!!this.cell.column) {
20
+ return this.cell.column;
21
+ }
22
+ return null;
23
+ }
24
+ get row() {
25
+ return this.cell.row;
26
+ }
27
+ ngDoCheck() {
28
+ var _a;
29
+ super.ngDoCheck();
30
+ if (this.cell.isErrorsCell && ((_a = this.cell) === null || _a === void 0 ? void 0 : _a.question)) {
31
+ this.cell.question.registerFunctionOnPropertyValueChanged("errors", () => {
32
+ this.update();
33
+ }, "__ngSubscription");
34
+ }
35
+ }
36
+ get panelComponentName() {
37
+ const panel = this.cell.panel;
38
+ const survey = panel.survey;
39
+ if (!!survey) {
40
+ const name = survey.getElementWrapperComponentName(panel);
41
+ if (!!name) {
42
+ return name;
43
+ }
44
+ }
45
+ return "panel";
46
+ }
47
+ get panelComponentData() {
48
+ const panel = this.cell.panel;
49
+ const survey = panel.survey;
50
+ let data;
51
+ if (!!survey) {
52
+ data = survey.getElementWrapperComponentData(panel);
53
+ }
54
+ return {
55
+ componentName: "panel",
56
+ componentData: {
57
+ model: panel,
58
+ data: data
59
+ }
60
+ };
61
+ }
62
+ getComponentName(element) { return getComponentName(element); }
63
+ getHeaders() {
64
+ return this.cell.headers;
65
+ }
66
+ getCellStyle() {
67
+ if (!!this.cell.width || !!this.cell.minWidth)
68
+ return { width: this.cell.width, minWidth: this.cell.minWidth };
69
+ return null;
70
+ }
71
+ get isRequiredCell() {
72
+ return !!this.cell.column && this.cell.column.isRenderedRequired;
73
+ }
74
+ ngAfterViewInit() {
75
+ if (!this.cell.hasQuestion || !this.question || !this.question.survey)
76
+ return;
77
+ const el = this.cellContainer.nativeElement;
78
+ const cellQ = this.cell.question;
79
+ var options = {
80
+ cell: this.cell.cell,
81
+ cellQuestion: cellQ,
82
+ htmlElement: el,
83
+ row: this.cell.row,
84
+ column: this.cell.cell.column,
85
+ };
86
+ this.question.survey.matrixAfterCellRender(this.question, options);
87
+ cellQ.afterRenderCore(el);
88
+ }
89
+ ngOnDestroy() {
90
+ var _a;
91
+ super.ngOnDestroy();
92
+ if (this.cell.isErrorsCell && ((_a = this.cell) === null || _a === void 0 ? void 0 : _a.question)) {
93
+ this.cell.question.unRegisterFunctionOnPropertyValueChanged("errors", "__ngSubscription");
94
+ }
95
+ }
96
+ }
97
+ MatrixDropdownCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixDropdownCellComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
98
+ MatrixDropdownCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MatrixDropdownCellComponent, selector: "sv-ng-matrixdropdown-cell", inputs: { question: "question", cell: "cell" }, viewQueries: [{ propertyName: "cellContainer", first: true, predicate: ["cellContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #template>\n <td [class]=\"cell.className\" [attr.data-responsive-title]=\"getHeaders()\" [title]=\"cell.getTitle()\"\n [style]=\"getCellStyle()\" [attr.colspan]=\"cell.colSpans\" (focusin)=\"cell.focusIn()\" #cellContainer>\n <sv-ng-matrix-drag-drop-icon *ngIf=\"cell.isDragHandlerCell\"\n [model]=\"$any({ data: { row: row, question: question } })\"></sv-ng-matrix-drag-drop-icon>\n <sv-action-bar *ngIf=\"cell.isActionsCell\" [model]=\"cell.item.getData()\" [handleClick]=\"false\"></sv-action-bar>\n <ng-container *ngIf=\"cell.hasPanel\">\n <ng-template [component]=\"{ name: panelComponentName, data: panelComponentData }\"></ng-template>\n </ng-container>\n <div *ngIf=\"cell.isErrorsCell && cell.question?.hasVisibleErrors\" [element]=\"cell.question\" sv-ng-errors></div>\n <div *ngIf=\"cell.hasQuestion\" [class]=\"question.cssClasses.cellQuestionWrapper\"\n [visible]=\"cell.question.isVisible\">\n <ng-container *ngIf=\"!cell.isChoice && cell.question.isDefaultRendering()\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n <ng-template\n [component]=\"{ name: getComponentName(cell.question), data: { model: cell.question } }\"></ng-template>\n </ng-template>\n </ng-container>\n <ng-template *ngIf=\"!cell.isChoice && !cell.question.isDefaultRendering()\"\n [component]=\"{ name: cell.question.getComponentName(), data: { model: cell.question } }\">\n </ng-template>\n <ng-container *ngIf=\"cell.isItemChoice\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n <sv-ng-selebase-item [showLabel]=\"false\" [inputType]=\"cell.isCheckbox ? 'checkbox': 'radio'\"\n [question]=\"cell.question\" [model]=\"cell.item\"></sv-ng-selebase-item>\n </ng-template>\n </ng-container>\n <div *ngIf=\"cell.isOtherChoice\" [class]=\"cell.question.getCommentAreaCss(true)\" [question]=\"cell.question\"\n sv-ng-comment-other></div>\n </div>\n <ng-container *ngIf=\"cell.hasTitle\">\n <ng-template\n [component]=\"{ name: question.getCellWrapperComponentName($any(cell)), data: { componentData: question.getCellWrapperComponentData($any(cell))} }\">\n <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n <span *ngIf=\"isRequiredCell\" [class]=\"question.cssClasses.cellRequiredText\">{{ cell.requiredText }}</span>\n </ng-template>\n </ng-container>\n </td>\n</ng-template>", styles: [":host { display: none; }"], components: [{ type: i1.MatrixDynamicDragDropIconComponent, selector: "sv-ng-matrix-drag-drop-icon", inputs: ["model"] }, { type: i2.ActionBarComponent, selector: "sv-action-bar, sv-ng-action-bar", inputs: ["model", "handleClick"] }, { type: i3.ErrorsComponent, selector: "'[sv-ng-errors]'", inputs: ["element", "location"] }, { type: i4.SelectBaseItemComponent, selector: "['sv-ng-selectbase-item'], sv-ng-selebase-item", inputs: ["question", "model", "inputType", "showLabel"] }, { type: i5.SurveyCommentOtherComponent, selector: "sv-ng-comment-other, '[sv-ng-comment-other]'", inputs: ["question"] }, { type: i6.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.DynamicComponentDirective, selector: "[component]", inputs: ["component"] }, { type: i9.VisibleDirective, selector: "[visible]", inputs: ["visible"] }] });
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixDropdownCellComponent, decorators: [{
100
+ type: Component,
101
+ args: [{
102
+ selector: "sv-ng-matrixdropdown-cell",
103
+ templateUrl: "./matrixdropdowncell.component.html",
104
+ styles: [":host { display: none; }"]
105
+ }]
106
+ }], propDecorators: { question: [{
107
+ type: Input
108
+ }], cell: [{
109
+ type: Input
110
+ }], cellContainer: [{
111
+ type: ViewChild,
112
+ args: ["cellContainer"]
113
+ }] } });
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrixdropdowncell.component.js","sourceRoot":"","sources":["../../../src/questions/matrixdropdowncell.component.ts","../../../src/questions/matrixdropdowncell.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAQ9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;;;;;;;;;;;AAO/C,MAAM,OAAO,2BAA4B,SAAQ,WAAqB;IAKpE,QAAQ;QACN,IAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACxB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B;QACD,IAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACrB,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;SACzB;QACD,OAAO,IAAW,CAAC;IACrB,CAAC;IACD,IAAW,GAAG;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;IACvB,CAAC;IACe,SAAS;;QACvB,KAAK,CAAC,SAAS,EAAE,CAAC;QAClB,IAAG,IAAI,CAAC,IAAI,CAAC,YAAY,KAAI,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,CAAA,EAAE;YAChD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,sCAAsC,CAAC,QAAQ,EAAE,GAAG,EAAE;gBACvE,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC,EAAE,kBAAkB,CAAC,CAAA;SACvB;IACH,CAAC;IACD,IAAW,kBAAkB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAgB,KAAK,CAAC,MAAM,CAAC;QACzC,IAAG,CAAC,CAAC,MAAM,EAAE;YACX,MAAM,IAAI,GAAG,MAAM,CAAC,8BAA8B,CAAC,KAAK,CAAC,CAAC;YAC1D,IAAG,CAAC,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,IAAW,kBAAkB;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAC9B,MAAM,MAAM,GAAgB,KAAK,CAAC,MAAM,CAAC;QACzC,IAAI,IAAS,CAAC;QACd,IAAG,CAAC,CAAC,MAAM,EAAE;YACX,IAAI,GAAG,MAAM,CAAC,8BAA8B,CAAC,KAAK,CAAC,CAAC;SACrD;QACD,OAAO;YACL,aAAa,EAAE,OAAO;YACtB,aAAa,EAAE;gBACb,KAAK,EAAE,KAAK;gBACZ,IAAI,EAAE,IAAI;aACX;SACF,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,OAAiB,IAAI,OAAO,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACzE,UAAU;QACR,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;IAC3B,CAAC;IACD,YAAY;QACV,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ;YAC3C,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClE,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAW,cAAc;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC;IACnE,CAAC;IACD,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,OAAO;QAC9E,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;QACjC,IAAI,OAAO,GAAG;YACZ,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI;YACpB,YAAY,EAAE,KAAK;YACnB,WAAW,EAAE,EAAE;YACf,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG;YAClB,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;SAC9B,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACnE,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IACQ,WAAW;;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAG,IAAI,CAAC,IAAI,CAAC,YAAY,KAAI,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,CAAA,EAAE;YAChD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,wCAAwC,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAA;SAC1F;IACH,CAAC;;yHAnFU,2BAA2B;6GAA3B,2BAA2B,wPChBxC,irFAwCc;4FDxBD,2BAA2B;kBALvC,SAAS;mBAAC;oBACT,QAAQ,EAAE,2BAA2B;oBACrC,WAAW,EAAE,qCAAqC;oBAClD,MAAM,EAAE,CAAC,0BAA0B,CAAC;iBACrC;8BAEU,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEsB,aAAa;sBAAxC,SAAS;uBAAC,eAAe","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from \"@angular/core\";\nimport { BaseAngular } from \"../base-angular\";\nimport {\n  Question,\n  QuestionMatrixDropdownModelBase,\n  QuestionMatrixDropdownRenderedCell,\n  MatrixDropdownRowModelBase,\n  SurveyModel\n} from \"survey-core\";\nimport { getComponentName } from \"../question\";\n\n@Component({\n  selector: \"sv-ng-matrixdropdown-cell\",\n  templateUrl: \"./matrixdropdowncell.component.html\",\n  styles: [\":host { display: none; }\"]\n})\nexport class MatrixDropdownCellComponent extends BaseAngular<Question> {\n  @Input() question!: QuestionMatrixDropdownModelBase;\n  @Input() cell!: QuestionMatrixDropdownRenderedCell;\n\n  @ViewChild(\"cellContainer\") cellContainer!: ElementRef<HTMLElement>;\n  getModel() {\n    if(this.cell.hasQuestion) {\n      return this.cell.question;\n    }\n    if(!!this.cell.column) {\n      return this.cell.column;\n    }\n    return null as any;\n  }\n  public get row(): MatrixDropdownRowModelBase {\n    return this.cell.row;\n  }\n  public override ngDoCheck(): void {\n    super.ngDoCheck();\n    if(this.cell.isErrorsCell && this.cell?.question) {\n      this.cell.question.registerFunctionOnPropertyValueChanged(\"errors\", () => {\n        this.update();\n      }, \"__ngSubscription\")\n    }\n  }\n  public get panelComponentName(): string {\n    const panel = this.cell.panel;\n    const survey = <SurveyModel>panel.survey;\n    if(!!survey) {\n      const name = survey.getElementWrapperComponentName(panel);\n      if(!!name) {\n        return name;\n      }\n    }\n    return \"panel\";\n  }\n  public get panelComponentData(): any {\n    const panel = this.cell.panel;\n    const survey = <SurveyModel>panel.survey;\n    let data: any;\n    if(!!survey) {\n      data = survey.getElementWrapperComponentData(panel);\n    }\n    return {\n      componentName: \"panel\",\n      componentData: {\n        model: panel,\n        data: data\n      }\n    };\n  }\n\n  getComponentName(element: Question) { return getComponentName(element); }\n  getHeaders(): string {\n    return this.cell.headers;\n  }\n  getCellStyle() {\n    if (!!this.cell.width || !!this.cell.minWidth)\n      return { width: this.cell.width, minWidth: this.cell.minWidth };\n    return null;\n  }\n  public get isRequiredCell(): boolean {\n    return !!this.cell.column && this.cell.column.isRenderedRequired;\n  }\n  ngAfterViewInit() {\n    if (!this.cell.hasQuestion || !this.question || !this.question.survey) return;\n    const el = this.cellContainer.nativeElement;\n    const cellQ = this.cell.question;\n    var options = {\n      cell: this.cell.cell,\n      cellQuestion: cellQ,\n      htmlElement: el,\n      row: this.cell.row,\n      column: this.cell.cell.column,\n    };\n    this.question.survey.matrixAfterCellRender(this.question, options);\n    cellQ.afterRenderCore(el);\n  }\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    if(this.cell.isErrorsCell && this.cell?.question) {\n      this.cell.question.unRegisterFunctionOnPropertyValueChanged(\"errors\", \"__ngSubscription\")    \n    }\n  }\n}","<ng-template #template>\n  <td [class]=\"cell.className\" [attr.data-responsive-title]=\"getHeaders()\" [title]=\"cell.getTitle()\"\n    [style]=\"getCellStyle()\" [attr.colspan]=\"cell.colSpans\" (focusin)=\"cell.focusIn()\" #cellContainer>\n    <sv-ng-matrix-drag-drop-icon *ngIf=\"cell.isDragHandlerCell\"\n      [model]=\"$any({ data: { row: row, question: question } })\"></sv-ng-matrix-drag-drop-icon>\n    <sv-action-bar *ngIf=\"cell.isActionsCell\" [model]=\"cell.item.getData()\" [handleClick]=\"false\"></sv-action-bar>\n    <ng-container *ngIf=\"cell.hasPanel\">\n      <ng-template [component]=\"{ name: panelComponentName, data: panelComponentData }\"></ng-template>\n    </ng-container>\n    <div *ngIf=\"cell.isErrorsCell && cell.question?.hasVisibleErrors\" [element]=\"cell.question\" sv-ng-errors></div>\n    <div *ngIf=\"cell.hasQuestion\" [class]=\"question.cssClasses.cellQuestionWrapper\"\n      [visible]=\"cell.question.isVisible\">\n      <ng-container *ngIf=\"!cell.isChoice && cell.question.isDefaultRendering()\">\n        <ng-template\n          [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n          <ng-template\n            [component]=\"{ name: getComponentName(cell.question), data: { model: cell.question } }\"></ng-template>\n        </ng-template>\n      </ng-container>\n      <ng-template *ngIf=\"!cell.isChoice && !cell.question.isDefaultRendering()\"\n        [component]=\"{ name: cell.question.getComponentName(), data: { model: cell.question } }\">\n      </ng-template>\n      <ng-container *ngIf=\"cell.isItemChoice\">\n        <ng-template\n          [component]=\"{ name: question.getCellWrapperComponentName(cell.cell), data: { componentData: question.getCellWrapperComponentData(cell.cell)} }\">\n          <sv-ng-selebase-item [showLabel]=\"false\" [inputType]=\"cell.isCheckbox ? 'checkbox': 'radio'\"\n            [question]=\"cell.question\" [model]=\"cell.item\"></sv-ng-selebase-item>\n        </ng-template>\n      </ng-container>\n      <div *ngIf=\"cell.isOtherChoice\" [class]=\"cell.question.getCommentAreaCss(true)\" [question]=\"cell.question\"\n        sv-ng-comment-other></div>\n    </div>\n    <ng-container *ngIf=\"cell.hasTitle\">\n      <ng-template\n        [component]=\"{ name: question.getCellWrapperComponentName($any(cell)), data: { componentData: question.getCellWrapperComponentData($any(cell))} }\">\n        <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n        <span *ngIf=\"isRequiredCell\" [class]=\"question.cssClasses.cellRequiredText\">{{ cell.requiredText }}</span>\n      </ng-template>\n    </ng-container>\n  </td>\n</ng-template>"]}
@@ -4,7 +4,7 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "../survey-string.component";
5
5
  import * as i2 from "./matrixrequiredheader.component";
6
6
  import * as i3 from "./matrix-row.component";
7
- import * as i4 from "./matrixcell.component";
7
+ import * as i4 from "./matrixdropdowncell.component";
8
8
  import * as i5 from "@angular/common";
9
9
  import * as i6 from "../utils/dynamic.directive";
10
10
  export class MatrixTableComponent extends BaseAngular {
@@ -19,7 +19,7 @@ export class MatrixTableComponent extends BaseAngular {
19
19
  }
20
20
  }
21
21
  MatrixTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
22
- MatrixTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MatrixTableComponent, selector: "sv-ng-matrix-table", inputs: { question: "question", table: "table" }, usesInheritance: true, ngImport: i0, template: "<div [style]=\"{ overflowX: question.showHorizontalScroll ? 'scroll' : '' }\" #contentElement [class]=\"question.cssClasses.tableWrapper\">\n <table [class]=\"question.getTableCss()\">\n <thead *ngIf=\"table.showHeader\">\n <tr>\n <ng-container\n *ngFor=\"let cell of table.headerRow.cells; trackBy: trackCellBy\"\n >\n <th *ngIf=\"cell.hasTitle\" [class]=\"cell.className\" [style]=\"{ minWidth: cell.minWidth, width: cell.width }\">\n <ng-template [component]=\"{ name: question.getColumnHeaderWrapperComponentName($any(cell)), data: { componentData: question.getColumnHeaderWrapperComponentData($any(cell)) } }\">\n <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n <sv-ng-matrixheaderrequired *ngIf=\"!!cell.column\" [column]=\"cell.column\" [question]=\"question\">\n </sv-ng-matrixheaderrequired>\n </ng-template>\n </th>\n \n <td *ngIf=\"!cell.hasTitle\" [class]=\"cell.className\" [style]=\"{ minWidth: cell.minWidth, width: cell.width }\"></td>\n </ng-container>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let row of table.rows; trackBy: trackRowBy\">\n <sv-ng-matrix-row [model]=\"row\" [question]=\"question\"></sv-ng-matrix-row>\n </ng-container>\n </tbody>\n <tfoot *ngIf=\"table.showFooter\">\n <tr>\n <sv-ng-matrix-cell [cell]=\"cell\" [question]=\"question\" *ngFor=\"let cell of table.footerRow.cells; trackBy: trackCellBy\">\n </sv-ng-matrix-cell>\n </tr>\n </tfoot>\n </table>\n</div>", components: [{ type: i1.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }, { type: i2.MatrixRequiredHeader, selector: "sv-ng-matrixheaderrequired", inputs: ["column", "question"] }, { type: i3.MatrixRowComponent, selector: "sv-ng-matrix-row", inputs: ["model", "question"] }, { type: i4.MatrixCellComponent, selector: "sv-ng-matrix-cell", inputs: ["question", "cell"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.DynamicComponentDirective, selector: "[component]", inputs: ["component"] }] });
22
+ MatrixTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MatrixTableComponent, selector: "sv-ng-matrix-table", inputs: { question: "question", table: "table" }, usesInheritance: true, ngImport: i0, template: "<div [style]=\"{ overflowX: question.showHorizontalScroll ? 'scroll' : '' }\" #contentElement [class]=\"question.cssClasses.tableWrapper\">\n <table [class]=\"question.getTableCss()\">\n <thead *ngIf=\"table.showHeader\">\n <tr>\n <ng-container\n *ngFor=\"let cell of table.headerRow.cells; trackBy: trackCellBy\"\n >\n <th *ngIf=\"cell.hasTitle\" [class]=\"cell.className\" [style]=\"{ minWidth: cell.minWidth, width: cell.width }\">\n <ng-template [component]=\"{ name: question.getColumnHeaderWrapperComponentName($any(cell)), data: { componentData: question.getColumnHeaderWrapperComponentData($any(cell)) } }\">\n <sv-ng-string [model]=\"cell.locTitle\"></sv-ng-string>\n <sv-ng-matrixheaderrequired *ngIf=\"!!cell.column\" [column]=\"cell.column\" [question]=\"question\">\n </sv-ng-matrixheaderrequired>\n </ng-template>\n </th>\n \n <td *ngIf=\"!cell.hasTitle\" [class]=\"cell.className\" [style]=\"{ minWidth: cell.minWidth, width: cell.width }\"></td>\n </ng-container>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let row of table.rows; trackBy: trackRowBy\">\n <sv-ng-matrix-row [model]=\"row\" [question]=\"question\"></sv-ng-matrix-row>\n </ng-container>\n </tbody>\n <tfoot *ngIf=\"table.showFooter\">\n <tr>\n <sv-ng-matrixdropdown-cell [cell]=\"cell\" [question]=\"question\" *ngFor=\"let cell of table.footerRow.cells; trackBy: trackCellBy\">\n </sv-ng-matrixdropdown-cell>\n </tr>\n </tfoot>\n </table>\n</div>", components: [{ type: i1.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }, { type: i2.MatrixRequiredHeader, selector: "sv-ng-matrixheaderrequired", inputs: ["column", "question"] }, { type: i3.MatrixRowComponent, selector: "sv-ng-matrix-row", inputs: ["model", "question"] }, { type: i4.MatrixDropdownCellComponent, selector: "sv-ng-matrixdropdown-cell", inputs: ["question", "cell"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.DynamicComponentDirective, selector: "[component]", inputs: ["component"] }] });
23
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MatrixTableComponent, decorators: [{
24
24
  type: Component,
25
25
  args: [{
@@ -31,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
31
31
  }], table: [{
32
32
  type: Input
33
33
  }] } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0cml4dGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3F1ZXN0aW9ucy9tYXRyaXh0YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi9zcmMvcXVlc3Rpb25zL21hdHJpeHRhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7QUFPOUMsTUFBTSxPQUFPLG9CQUFxQixTQUFRLFdBQWdEO0lBRzlFLFFBQVE7UUFDaEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFDTSxXQUFXLENBQUMsQ0FBUyxFQUFFLElBQVM7UUFDckMsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFDTSxVQUFVLENBQUMsS0FBYSxFQUFFLEdBQVE7UUFDdkMsT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDO0lBQ2hCLENBQUM7O2tIQVhVLG9CQUFvQjtzR0FBcEIsb0JBQW9CLG1JQ1JqQywwbkRBK0JNOzRGRHZCTyxvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsV0FBVyxFQUFFLDhCQUE4QjtpQkFDNUM7OEJBRVUsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEJhc2VBbmd1bGFyIH0gZnJvbSBcIi4uL2Jhc2UtYW5ndWxhclwiO1xuaW1wb3J0IHsgUXVlc3Rpb25NYXRyaXhEcm9wZG93bk1vZGVsQmFzZSwgUXVlc3Rpb25NYXRyaXhEcm9wZG93blJlbmRlcmVkVGFibGUgfSBmcm9tIFwic3VydmV5LWNvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcInN2LW5nLW1hdHJpeC10YWJsZVwiLFxuICB0ZW1wbGF0ZVVybDogXCIuL21hdHJpeHRhYmxlLmNvbXBvbmVudC5odG1sXCJcbn0pXG5leHBvcnQgY2xhc3MgTWF0cml4VGFibGVDb21wb25lbnQgZXh0ZW5kcyBCYXNlQW5ndWxhcjxRdWVzdGlvbk1hdHJpeERyb3Bkb3duUmVuZGVyZWRUYWJsZT4ge1xuICBASW5wdXQoKSBxdWVzdGlvbiE6IFF1ZXN0aW9uTWF0cml4RHJvcGRvd25Nb2RlbEJhc2U7XG4gIEBJbnB1dCgpIHRhYmxlITogUXVlc3Rpb25NYXRyaXhEcm9wZG93blJlbmRlcmVkVGFibGU7XG4gIHByb3RlY3RlZCBnZXRNb2RlbCgpOiBRdWVzdGlvbk1hdHJpeERyb3Bkb3duUmVuZGVyZWRUYWJsZSB7XG4gICAgcmV0dXJuIHRoaXMudGFibGU7XG4gIH1cbiAgcHVibGljIHRyYWNrQ2VsbEJ5KF86IG51bWJlciwgY2VsbDogYW55KTogc3RyaW5nIHtcbiAgICByZXR1cm4gY2VsbC5pZDtcbiAgfVxuICBwdWJsaWMgdHJhY2tSb3dCeShpbmRleDogbnVtYmVyLCByb3c6IGFueSk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHJvdy5pZDtcbiAgfVxufVxuIiwiPGRpdiBbc3R5bGVdPVwieyBvdmVyZmxvd1g6IHF1ZXN0aW9uLnNob3dIb3Jpem9udGFsU2Nyb2xsID8gJ3Njcm9sbCcgOiAnJyB9XCIgI2NvbnRlbnRFbGVtZW50IFtjbGFzc109XCJxdWVzdGlvbi5jc3NDbGFzc2VzLnRhYmxlV3JhcHBlclwiPlxuICA8dGFibGUgW2NsYXNzXT1cInF1ZXN0aW9uLmdldFRhYmxlQ3NzKClcIj5cbiAgICA8dGhlYWQgKm5nSWY9XCJ0YWJsZS5zaG93SGVhZGVyXCI+XG4gICAgICA8dHI+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAqbmdGb3I9XCJsZXQgY2VsbCBvZiB0YWJsZS5oZWFkZXJSb3cuY2VsbHM7IHRyYWNrQnk6IHRyYWNrQ2VsbEJ5XCJcbiAgICAgICAgPlxuICAgICAgICAgICAgICA8dGggKm5nSWY9XCJjZWxsLmhhc1RpdGxlXCIgW2NsYXNzXT1cImNlbGwuY2xhc3NOYW1lXCIgW3N0eWxlXT1cInsgbWluV2lkdGg6IGNlbGwubWluV2lkdGgsIHdpZHRoOiBjZWxsLndpZHRoIH1cIj5cbiAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgW2NvbXBvbmVudF09XCJ7IG5hbWU6IHF1ZXN0aW9uLmdldENvbHVtbkhlYWRlcldyYXBwZXJDb21wb25lbnROYW1lKCRhbnkoY2VsbCkpLCBkYXRhOiB7IGNvbXBvbmVudERhdGE6IHF1ZXN0aW9uLmdldENvbHVtbkhlYWRlcldyYXBwZXJDb21wb25lbnREYXRhKCRhbnkoY2VsbCkpIH0gfVwiPlxuICAgICAgICAgICAgICAgICAgPHN2LW5nLXN0cmluZyBbbW9kZWxdPVwiY2VsbC5sb2NUaXRsZVwiPjwvc3Ytbmctc3RyaW5nPlxuICAgICAgICAgICAgICAgICAgPHN2LW5nLW1hdHJpeGhlYWRlcnJlcXVpcmVkICpuZ0lmPVwiISFjZWxsLmNvbHVtblwiIFtjb2x1bW5dPVwiY2VsbC5jb2x1bW5cIiBbcXVlc3Rpb25dPVwicXVlc3Rpb25cIj5cbiAgICAgICAgICAgICAgICAgIDwvc3YtbmctbWF0cml4aGVhZGVycmVxdWlyZWQ+XG4gICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgICAgICAgPC90aD5cbiAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgIDx0ZCAqbmdJZj1cIiFjZWxsLmhhc1RpdGxlXCIgW2NsYXNzXT1cImNlbGwuY2xhc3NOYW1lXCIgW3N0eWxlXT1cInsgbWluV2lkdGg6IGNlbGwubWluV2lkdGgsIHdpZHRoOiBjZWxsLndpZHRoIH1cIj48L3RkPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgIDwvdHI+XG4gICAgPC90aGVhZD5cbiAgICA8dGJvZHk+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCByb3cgb2YgdGFibGUucm93czsgdHJhY2tCeTogdHJhY2tSb3dCeVwiPlxuICAgICAgICA8c3YtbmctbWF0cml4LXJvdyBbbW9kZWxdPVwicm93XCIgW3F1ZXN0aW9uXT1cInF1ZXN0aW9uXCI+PC9zdi1uZy1tYXRyaXgtcm93PlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC90Ym9keT5cbiAgICA8dGZvb3QgKm5nSWY9XCJ0YWJsZS5zaG93Rm9vdGVyXCI+XG4gICAgICA8dHI+XG4gICAgICAgIDxzdi1uZy1tYXRyaXgtY2VsbCBbY2VsbF09XCJjZWxsXCIgW3F1ZXN0aW9uXT1cInF1ZXN0aW9uXCIgKm5nRm9yPVwibGV0IGNlbGwgb2YgdGFibGUuZm9vdGVyUm93LmNlbGxzOyB0cmFja0J5OiB0cmFja0NlbGxCeVwiPlxuICAgICAgICA8L3N2LW5nLW1hdHJpeC1jZWxsPlxuICAgICAgPC90cj5cbiAgICA8L3Rmb290PlxuICA8L3RhYmxlPlxuPC9kaXY+Il19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0cml4dGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3F1ZXN0aW9ucy9tYXRyaXh0YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi9zcmMvcXVlc3Rpb25zL21hdHJpeHRhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7QUFPOUMsTUFBTSxPQUFPLG9CQUFxQixTQUFRLFdBQWdEO0lBRzlFLFFBQVE7UUFDaEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFDTSxXQUFXLENBQUMsQ0FBUyxFQUFFLElBQVM7UUFDckMsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFDTSxVQUFVLENBQUMsS0FBYSxFQUFFLEdBQVE7UUFDdkMsT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDO0lBQ2hCLENBQUM7O2tIQVhVLG9CQUFvQjtzR0FBcEIsb0JBQW9CLG1JQ1JqQywwb0RBK0JNOzRGRHZCTyxvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsV0FBVyxFQUFFLDhCQUE4QjtpQkFDNUM7OEJBRVUsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEJhc2VBbmd1bGFyIH0gZnJvbSBcIi4uL2Jhc2UtYW5ndWxhclwiO1xuaW1wb3J0IHsgUXVlc3Rpb25NYXRyaXhEcm9wZG93bk1vZGVsQmFzZSwgUXVlc3Rpb25NYXRyaXhEcm9wZG93blJlbmRlcmVkVGFibGUgfSBmcm9tIFwic3VydmV5LWNvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcInN2LW5nLW1hdHJpeC10YWJsZVwiLFxuICB0ZW1wbGF0ZVVybDogXCIuL21hdHJpeHRhYmxlLmNvbXBvbmVudC5odG1sXCJcbn0pXG5leHBvcnQgY2xhc3MgTWF0cml4VGFibGVDb21wb25lbnQgZXh0ZW5kcyBCYXNlQW5ndWxhcjxRdWVzdGlvbk1hdHJpeERyb3Bkb3duUmVuZGVyZWRUYWJsZT4ge1xuICBASW5wdXQoKSBxdWVzdGlvbiE6IFF1ZXN0aW9uTWF0cml4RHJvcGRvd25Nb2RlbEJhc2U7XG4gIEBJbnB1dCgpIHRhYmxlITogUXVlc3Rpb25NYXRyaXhEcm9wZG93blJlbmRlcmVkVGFibGU7XG4gIHByb3RlY3RlZCBnZXRNb2RlbCgpOiBRdWVzdGlvbk1hdHJpeERyb3Bkb3duUmVuZGVyZWRUYWJsZSB7XG4gICAgcmV0dXJuIHRoaXMudGFibGU7XG4gIH1cbiAgcHVibGljIHRyYWNrQ2VsbEJ5KF86IG51bWJlciwgY2VsbDogYW55KTogc3RyaW5nIHtcbiAgICByZXR1cm4gY2VsbC5pZDtcbiAgfVxuICBwdWJsaWMgdHJhY2tSb3dCeShpbmRleDogbnVtYmVyLCByb3c6IGFueSk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHJvdy5pZDtcbiAgfVxufVxuIiwiPGRpdiBbc3R5bGVdPVwieyBvdmVyZmxvd1g6IHF1ZXN0aW9uLnNob3dIb3Jpem9udGFsU2Nyb2xsID8gJ3Njcm9sbCcgOiAnJyB9XCIgI2NvbnRlbnRFbGVtZW50IFtjbGFzc109XCJxdWVzdGlvbi5jc3NDbGFzc2VzLnRhYmxlV3JhcHBlclwiPlxuICA8dGFibGUgW2NsYXNzXT1cInF1ZXN0aW9uLmdldFRhYmxlQ3NzKClcIj5cbiAgICA8dGhlYWQgKm5nSWY9XCJ0YWJsZS5zaG93SGVhZGVyXCI+XG4gICAgICA8dHI+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAqbmdGb3I9XCJsZXQgY2VsbCBvZiB0YWJsZS5oZWFkZXJSb3cuY2VsbHM7IHRyYWNrQnk6IHRyYWNrQ2VsbEJ5XCJcbiAgICAgICAgPlxuICAgICAgICAgICAgICA8dGggKm5nSWY9XCJjZWxsLmhhc1RpdGxlXCIgW2NsYXNzXT1cImNlbGwuY2xhc3NOYW1lXCIgW3N0eWxlXT1cInsgbWluV2lkdGg6IGNlbGwubWluV2lkdGgsIHdpZHRoOiBjZWxsLndpZHRoIH1cIj5cbiAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgW2NvbXBvbmVudF09XCJ7IG5hbWU6IHF1ZXN0aW9uLmdldENvbHVtbkhlYWRlcldyYXBwZXJDb21wb25lbnROYW1lKCRhbnkoY2VsbCkpLCBkYXRhOiB7IGNvbXBvbmVudERhdGE6IHF1ZXN0aW9uLmdldENvbHVtbkhlYWRlcldyYXBwZXJDb21wb25lbnREYXRhKCRhbnkoY2VsbCkpIH0gfVwiPlxuICAgICAgICAgICAgICAgICAgPHN2LW5nLXN0cmluZyBbbW9kZWxdPVwiY2VsbC5sb2NUaXRsZVwiPjwvc3Ytbmctc3RyaW5nPlxuICAgICAgICAgICAgICAgICAgPHN2LW5nLW1hdHJpeGhlYWRlcnJlcXVpcmVkICpuZ0lmPVwiISFjZWxsLmNvbHVtblwiIFtjb2x1bW5dPVwiY2VsbC5jb2x1bW5cIiBbcXVlc3Rpb25dPVwicXVlc3Rpb25cIj5cbiAgICAgICAgICAgICAgICAgIDwvc3YtbmctbWF0cml4aGVhZGVycmVxdWlyZWQ+XG4gICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgICAgICAgICAgPC90aD5cbiAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgIDx0ZCAqbmdJZj1cIiFjZWxsLmhhc1RpdGxlXCIgW2NsYXNzXT1cImNlbGwuY2xhc3NOYW1lXCIgW3N0eWxlXT1cInsgbWluV2lkdGg6IGNlbGwubWluV2lkdGgsIHdpZHRoOiBjZWxsLndpZHRoIH1cIj48L3RkPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgIDwvdHI+XG4gICAgPC90aGVhZD5cbiAgICA8dGJvZHk+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCByb3cgb2YgdGFibGUucm93czsgdHJhY2tCeTogdHJhY2tSb3dCeVwiPlxuICAgICAgICA8c3YtbmctbWF0cml4LXJvdyBbbW9kZWxdPVwicm93XCIgW3F1ZXN0aW9uXT1cInF1ZXN0aW9uXCI+PC9zdi1uZy1tYXRyaXgtcm93PlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC90Ym9keT5cbiAgICA8dGZvb3QgKm5nSWY9XCJ0YWJsZS5zaG93Rm9vdGVyXCI+XG4gICAgICA8dHI+XG4gICAgICAgIDxzdi1uZy1tYXRyaXhkcm9wZG93bi1jZWxsIFtjZWxsXT1cImNlbGxcIiBbcXVlc3Rpb25dPVwicXVlc3Rpb25cIiAqbmdGb3I9XCJsZXQgY2VsbCBvZiB0YWJsZS5mb290ZXJSb3cuY2VsbHM7IHRyYWNrQnk6IHRyYWNrQ2VsbEJ5XCI+XG4gICAgICAgIDwvc3YtbmctbWF0cml4ZHJvcGRvd24tY2VsbD5cbiAgICAgIDwvdHI+XG4gICAgPC90Zm9vdD5cbiAgPC90YWJsZT5cbjwvZGl2PiJdfQ==