@dignite-ng/expand.cms 0.0.18 → 0.0.19

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.
Files changed (31) hide show
  1. package/esm2022/lib/cms-routing.module.mjs +2 -2
  2. package/esm2022/lib/cms.module.mjs +20 -28
  3. package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +10 -4
  4. package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +20 -11
  5. package/esm2022/lib/components/dynamic-form/form-control-group.mjs +18 -18
  6. package/esm2022/lib/components/dynamic-form/index.mjs +3 -3
  7. package/esm2022/lib/components/dynamic-form/matrix/index.mjs +4 -0
  8. package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +229 -0
  9. package/esm2022/lib/components/dynamic-form/matrix/matrix-config.mjs +50 -0
  10. package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +111 -0
  11. package/esm2022/lib/components/dynamic-form/table/index.mjs +4 -0
  12. package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +174 -0
  13. package/esm2022/lib/components/dynamic-form/table/table-config.mjs +38 -0
  14. package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +114 -0
  15. package/esm2022/lib/services/field-abstracts.service.mjs +1 -1
  16. package/fesm2022/dignite-ng-expand.cms.mjs +732 -56
  17. package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
  18. package/lib/cms.module.d.ts +20 -16
  19. package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +3 -1
  20. package/lib/components/admin/fields/create-or-edit-field.component.d.ts +4 -0
  21. package/lib/components/dynamic-form/index.d.ts +2 -0
  22. package/lib/components/dynamic-form/matrix/index.d.ts +3 -0
  23. package/lib/components/dynamic-form/matrix/matrix-config.component.d.ts +73 -0
  24. package/lib/components/dynamic-form/matrix/matrix-config.d.ts +24 -0
  25. package/lib/components/dynamic-form/matrix/matrix-control.component.d.ts +39 -0
  26. package/lib/components/dynamic-form/table/index.d.ts +3 -0
  27. package/lib/components/dynamic-form/table/table-config.component.d.ts +58 -0
  28. package/lib/components/dynamic-form/table/table-config.d.ts +18 -0
  29. package/lib/components/dynamic-form/table/table-control.component.d.ts +36 -0
  30. package/lib/services/field-abstracts.service.d.ts +1 -1
  31. package/package.json +3 -3
@@ -0,0 +1,114 @@
1
+ import { Component, Input, ViewChild, inject } from '@angular/core';
2
+ import { FormBuilder, Validators } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/forms";
6
+ import * as i3 from "@abp/ng.core";
7
+ import * as i4 from "@ngx-validate/core";
8
+ import * as i5 from "ng-zorro-antd/table";
9
+ import * as i6 from "@dignite-ng/expand.dynamic-form";
10
+ class TableControlComponent {
11
+ constructor() {
12
+ }
13
+ fb = inject(FormBuilder);
14
+ /**表单实体 */
15
+ _entity;
16
+ set entity(v) {
17
+ this._entity = v;
18
+ this.dataLoaded();
19
+ }
20
+ /**字段配置列表 */
21
+ _fields = '';
22
+ set fields(v) {
23
+ this._fields = v;
24
+ this.dataLoaded();
25
+ }
26
+ /**父级字段名称,用于为表单设置控件赋值 */
27
+ _parentFiledName;
28
+ set parentFiledName(v) {
29
+ this._parentFiledName = v;
30
+ this.dataLoaded();
31
+ }
32
+ /**父级字段名称,用于为表单设置控件赋值 */
33
+ _selected;
34
+ set selected(v) {
35
+ this._selected = v;
36
+ if (v) {
37
+ this.dataLoaded();
38
+ }
39
+ }
40
+ submitclick;
41
+ /** 获取父级字段代表的表单组*/
42
+ extraProperties;
43
+ /**数据加载完成 */
44
+ async dataLoaded() {
45
+ if (this._fields && this._entity && this._parentFiledName) {
46
+ this.extraProperties = this._entity.get(this._parentFiledName);
47
+ await this.AfterInit();
48
+ this.submitclick.nativeElement.click();
49
+ }
50
+ }
51
+ formConfiguration;
52
+ /**获取表格字段代表的控件 */
53
+ fieldNameControl;
54
+ AfterInit() {
55
+ return new Promise((resolve, rejects) => {
56
+ let ValidatorsArray = [];
57
+ if (this._fields.required) {
58
+ ValidatorsArray.push(Validators.required);
59
+ }
60
+ let formConfiguration = this._fields.field.formConfiguration;
61
+ this.formConfiguration = formConfiguration;
62
+ let newArrayGroup = this.fb.array([]);
63
+ this.extraProperties.setControl(this._fields.field.name, newArrayGroup);
64
+ this.fieldNameControl = this.extraProperties.get(this._fields.field.name);
65
+ if (this._selected) {
66
+ this._selected.forEach(el => {
67
+ this.addTableControlItem();
68
+ });
69
+ this.fieldNameControl.patchValue(this._selected);
70
+ }
71
+ else {
72
+ this.addTableControlItem();
73
+ }
74
+ resolve(true);
75
+ });
76
+ }
77
+ /**增加表格项 */
78
+ addTableControlItem() {
79
+ this.fieldNameControl.push(this.fb.group({
80
+ 'extraProperties': this.fb.group({})
81
+ }));
82
+ }
83
+ /**删除表格项 */
84
+ minusTableControlItem(index) {
85
+ this.fieldNameControl.removeAt(index);
86
+ }
87
+ /**调整表格位置 */
88
+ TableArrowUpOrDown(type, index) {
89
+ let controlAt = this.fieldNameControl.at(index);
90
+ this.fieldNameControl.removeAt(index);
91
+ let lastindex = type == 'up' ? index - 1 : index + 1;
92
+ this.fieldNameControl.insert(lastindex, controlAt);
93
+ this._selected = this.fieldNameControl.value;
94
+ }
95
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
96
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TableControlComponent, selector: "df-table-control", inputs: { entity: "entity", fields: "fields", parentFiledName: "parentFiledName", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-2\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <table class=\"table\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let item of formConfiguration.TableColumns\">\n <th scope=\"col\">{{ item.displayName }}</th>\n </ng-container>\n\n <th scope=\"col\" class=\"flex-end\">\n <button class=\"btn btn-light btn-sm\" (click.stop)=\"addTableControlItem()\">\n <i class=\"fas fa-plus-circle\"></i>\n </button>\n </th>\n </tr>\n </thead>\n <tbody [formArrayName]=\"_fields.field.name\">\n <ng-container *ngFor=\"let item of fieldNameControl.controls; let i = index\">\n <tr>\n <ng-container *ngFor=\"let el of formConfiguration.TableColumns\">\n <td>\n <ng-container *ngIf=\"item&&el\">\n <df-dynamic [entity]=\"item\" [fields]=\"{ field: el }\"\n [selected]=\"_selected[i]?.extraProperties[''+el.name+'']\"\n [parentFiledName]=\"'extraProperties'\"></df-dynamic>\n </ng-container>\n </td>\n </ng-container>\n <td scope=\"row\" class=\"\">\n <div class=\"flex-end mb-2\">\n <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"minusTableControlItem(i)\">\n <i class=\"fas fa-minus\"></i>\n </button>\n <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"TableArrowUpOrDown('up',i)\"\n *ngIf=\"i!==0\">\n <i class=\"fas fa-arrow-up\"></i>\n </button>\n <button class=\"btn btn-light btn-sm ms-1\"\n (click.stop)=\"TableArrowUpOrDown('down',i)\"\n *ngIf=\"i!==fieldNameControl.controls.length-1\">\n <i class=\"fas fa-arrow-down\"></i>\n </button>\n </div>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none\" #submitclick></button>\n</form>", styles: [".flex-end{display:flex;align-items:center;justify-content:flex-end}.flex-start{display:flex;align-items:center;justify-content:flex-start}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i2.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i4.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.NzTableCellDirective, selector: "th:not(.nz-disable-th):not([mat-cell]), td:not(.nz-disable-td):not([mat-cell])" }, { kind: "directive", type: i5.NzThMeasureDirective, selector: "th", inputs: ["nzWidth", "colspan", "colSpan", "rowspan", "rowSpan"] }, { kind: "component", type: i5.NzTheadComponent, selector: "thead:not(.ant-table-thead)", outputs: ["nzSortOrderChange"] }, { kind: "component", type: i5.NzTbodyComponent, selector: "tbody" }, { kind: "directive", type: i5.NzTrDirective, selector: "tr:not([mat-row]):not([mat-header-row]):not([nz-table-measure-row]):not([nzExpand]):not([nz-table-fixed-row])" }, { kind: "component", type: i6.DynamicComponent, selector: "df-dynamic", inputs: ["selected", "type", "entity", "culture", "parentFiledName", "fields"] }] });
97
+ }
98
+ export { TableControlComponent };
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TableControlComponent, decorators: [{
100
+ type: Component,
101
+ args: [{ selector: 'df-table-control', template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-2\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <table class=\"table\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let item of formConfiguration.TableColumns\">\n <th scope=\"col\">{{ item.displayName }}</th>\n </ng-container>\n\n <th scope=\"col\" class=\"flex-end\">\n <button class=\"btn btn-light btn-sm\" (click.stop)=\"addTableControlItem()\">\n <i class=\"fas fa-plus-circle\"></i>\n </button>\n </th>\n </tr>\n </thead>\n <tbody [formArrayName]=\"_fields.field.name\">\n <ng-container *ngFor=\"let item of fieldNameControl.controls; let i = index\">\n <tr>\n <ng-container *ngFor=\"let el of formConfiguration.TableColumns\">\n <td>\n <ng-container *ngIf=\"item&&el\">\n <df-dynamic [entity]=\"item\" [fields]=\"{ field: el }\"\n [selected]=\"_selected[i]?.extraProperties[''+el.name+'']\"\n [parentFiledName]=\"'extraProperties'\"></df-dynamic>\n </ng-container>\n </td>\n </ng-container>\n <td scope=\"row\" class=\"\">\n <div class=\"flex-end mb-2\">\n <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"minusTableControlItem(i)\">\n <i class=\"fas fa-minus\"></i>\n </button>\n <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"TableArrowUpOrDown('up',i)\"\n *ngIf=\"i!==0\">\n <i class=\"fas fa-arrow-up\"></i>\n </button>\n <button class=\"btn btn-light btn-sm ms-1\"\n (click.stop)=\"TableArrowUpOrDown('down',i)\"\n *ngIf=\"i!==fieldNameControl.controls.length-1\">\n <i class=\"fas fa-arrow-down\"></i>\n </button>\n </div>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none\" #submitclick></button>\n</form>", styles: [".flex-end{display:flex;align-items:center;justify-content:flex-end}.flex-start{display:flex;align-items:center;justify-content:flex-start}\n"] }]
102
+ }], ctorParameters: function () { return []; }, propDecorators: { entity: [{
103
+ type: Input
104
+ }], fields: [{
105
+ type: Input
106
+ }], parentFiledName: [{
107
+ type: Input
108
+ }], selected: [{
109
+ type: Input
110
+ }], submitclick: [{
111
+ type: ViewChild,
112
+ args: ['submitclick', { static: true }]
113
+ }] } });
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/dynamic-form/table/table-control.component.ts","../../../../../../../projects/cms/src/lib/components/dynamic-form/table/table-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild, ViewContainerRef, inject } from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\n\n@Component({\n  selector: 'df-table-control',\n  templateUrl: './table-control.component.html',\n  styleUrls: ['./table-control.component.scss']\n})\nexport class TableControlComponent {\n\n  constructor(\n    // private fb: FormBuilder,\n  ) {\n  }\n  private fb=inject(FormBuilder)\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded()\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    this.dataLoaded()\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    this.dataLoaded()\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v ;\n    if (v) { this.dataLoaded() }\n\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /** 获取父级字段代表的表单组*/\n  extraProperties: FormGroup | undefined\n  \n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity && this._parentFiledName) {\n      this.extraProperties = this._entity.get(this._parentFiledName) as FormGroup\n      await this.AfterInit()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  formConfiguration: any\n  /**获取表格字段代表的控件 */\n  fieldNameControl: FormArray | undefined\n\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray = []\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required)\n      }\n      let formConfiguration = this._fields.field.formConfiguration\n      this.formConfiguration = formConfiguration\n      let newArrayGroup = this.fb.array([])\n      this.extraProperties.setControl(this._fields.field.name, newArrayGroup)\n      this.fieldNameControl = this.extraProperties.get(this._fields.field.name) as FormArray\n      if (this._selected) {\n        this._selected.forEach(el => {\n          this.addTableControlItem()\n        });\n        this.fieldNameControl.patchValue(this._selected)\n      } else {\n        this.addTableControlItem()\n      }\n      resolve(true)\n    })\n  }\n  /**增加表格项 */\n  addTableControlItem(){\n    this.fieldNameControl.push(this.fb.group({\n      'extraProperties':this.fb.group({})\n    }))\n  }\n  /**删除表格项 */\n  minusTableControlItem(index){\n    this.fieldNameControl.removeAt(index)\n  }\n   /**调整表格位置 */\n   TableArrowUpOrDown(type, index) {\n    let controlAt = this.fieldNameControl.at(index)\n    this.fieldNameControl.removeAt(index)\n    let lastindex = type == 'up' ? index - 1 : index + 1\n    this.fieldNameControl.insert(lastindex, controlAt)\n    this._selected=this.fieldNameControl.value\n  }\n\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\">\n        <div class=\"mb-2\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <table class=\"table\">\n                <thead>\n                    <tr>\n                        <ng-container *ngFor=\"let item of formConfiguration.TableColumns\">\n                            <th scope=\"col\">{{ item.displayName }}</th>\n                        </ng-container>\n\n                        <th scope=\"col\" class=\"flex-end\">\n                            <button class=\"btn btn-light btn-sm\" (click.stop)=\"addTableControlItem()\">\n                                <i class=\"fas fa-plus-circle\"></i>\n                            </button>\n                        </th>\n                    </tr>\n                </thead>\n                <tbody [formArrayName]=\"_fields.field.name\">\n                    <ng-container *ngFor=\"let item of fieldNameControl.controls; let i = index\">\n                        <tr>\n                            <ng-container *ngFor=\"let el of formConfiguration.TableColumns\">\n                                <td>\n                                    <ng-container *ngIf=\"item&&el\">\n                                        <df-dynamic [entity]=\"item\" [fields]=\"{ field: el }\"\n                                            [selected]=\"_selected[i]?.extraProperties[''+el.name+'']\"\n                                            [parentFiledName]=\"'extraProperties'\"></df-dynamic>\n                                    </ng-container>\n                                </td>\n                            </ng-container>\n                            <td scope=\"row\" class=\"\">\n                                <div class=\"flex-end mb-2\">\n                                    <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"minusTableControlItem(i)\">\n                                        <i class=\"fas fa-minus\"></i>\n                                    </button>\n                                    <button class=\"btn btn-light btn-sm ms-1\" (click.stop)=\"TableArrowUpOrDown('up',i)\"\n                                        *ngIf=\"i!==0\">\n                                        <i class=\"fas fa-arrow-up\"></i>\n                                    </button>\n                                    <button class=\"btn btn-light btn-sm ms-1\"\n                                        (click.stop)=\"TableArrowUpOrDown('down',i)\"\n                                        *ngIf=\"i!==fieldNameControl.controls.length-1\">\n                                        <i class=\"fas fa-arrow-down\"></i>\n                                    </button>\n                                </div>\n                            </td>\n                        </tr>\n                    </ng-container>\n                </tbody>\n            </table>\n            <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n        </div>\n    </div>\n    <button type=\"submit\" style=\"display: none\" #submitclick></button>\n</form>"]}
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
42
42
  providedIn: 'root'
43
43
  }]
44
44
  }], ctorParameters: function () { return [{ type: i1.FieldGroupAdminService }, { type: i2.FormAdminService }]; } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtYWJzdHJhY3RzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbXMvc3JjL2xpYi9zZXJ2aWNlcy9maWVsZC1hYnN0cmFjdHMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBTTNDLE1BR2EscUJBQXFCO0lBR3RCO0lBQ0E7SUFGVixZQUNVLHVCQUErQyxFQUMvQyxpQkFBbUM7UUFEbkMsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF3QjtRQUMvQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO0lBQ3pDLENBQUM7SUFDTCxZQUFZO0lBQ1osY0FBYyxHQUFvQixFQUFFLENBQUE7SUFDcEMsY0FBYztJQUNkLGlCQUFpQjtRQUNmLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3ZELElBQUksQ0FBQyxjQUFjLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQTtRQUNqQyxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxZQUFZO0lBQ1osZUFBZSxHQUFVLEVBQUUsQ0FBQTtJQUMzQixjQUFjO0lBQ2Qsa0JBQWtCO1FBQ2hCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ3pELElBQUksQ0FBQyxlQUFlLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQTtnQkFDaEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNwQixDQUFDLENBQUMsQ0FBQTtRQUNKLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUNELHVCQUF1QixDQUFDLFFBQVE7UUFDOUIsaUVBQWlFO1FBQ2pFLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQTtJQUM3QixDQUFDO3dHQTdCVSxxQkFBcUI7NEdBQXJCLHFCQUFxQixjQUZwQixNQUFNOztTQUVQLHFCQUFxQjs0RkFBckIscUJBQXFCO2tCQUhqQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpZWxkR3JvdXBBZG1pblNlcnZpY2UgfSBmcm9tICcuLi9wcm94eS9hZG1pbi9maWVsZHMvZmllbGQtZ3JvdXAtYWRtaW4uc2VydmljZSc7XG5pbXBvcnQgeyBGaWVsZEdyb3VwRHRvIH0gZnJvbSAnLi4vcHJveHkvYWRtaW4vZmllbGRzL21vZGVscyc7XG5pbXBvcnQgeyBmaW5hbGl6ZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IEZvcm1BZG1pblNlcnZpY2UgfSBmcm9tICcuLi9wcm94eS9hZG1pbi9keW5hbWljLWZvcm1zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRmllbGRBYnN0cmFjdHNTZXJ2aWNlIHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9GaWVsZEdyb3VwQWRtaW5TZXJ2aWNlOiBGaWVsZEdyb3VwQWRtaW5TZXJ2aWNlLFxuICAgIHByaXZhdGUgX0Zvcm1BZG1pblNlcnZpY2U6IEZvcm1BZG1pblNlcnZpY2UsXG4gICkgeyB9XG4gIC8qKuWtl+auteWIhue7hOWIl+ihqCAqL1xuICBmaWVsZEdyb3VwTGlzdDogRmllbGRHcm91cER0b1tdID0gW11cbiAgLyoq6I635Y+W5a2X5q615YiG57uE5YiX6KGoICovXG4gIGdldGZpZWxkR3JvdXBMaXN0KCkge1xuICAgIHRoaXMuX0ZpZWxkR3JvdXBBZG1pblNlcnZpY2UuZ2V0TGlzdCh7fSkuc3Vic2NyaWJlKHJlcyA9PiB7XG4gICAgICB0aGlzLmZpZWxkR3JvdXBMaXN0ID0gcmVzLml0ZW1zXG4gICAgfSlcbiAgfVxuXG4gIC8qKuihqOWNleaOp+S7tuexu+WeiyAqL1xuICBmcm9tQ29udHJvbExpc3Q6IGFueVtdID0gW11cbiAgLyoq6I635Y+W6KGo5Y2V5o6n5Lu257G75Z6LICovXG4gIGdldEZyb21Db250cm9sTGlzdCgpIHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5fRm9ybUFkbWluU2VydmljZS5nZXRGb3JtQ29udHJvbHMoe30pLnN1YnNjcmliZShyZXMgPT4ge1xuICAgICAgICB0aGlzLmZyb21Db250cm9sTGlzdCA9IHJlcy5pdGVtc1xuICAgICAgICByZXNvbHZlKHJlcy5pdGVtcylcbiAgICAgIH0pXG4gICAgfSlcbiAgfVxuICBnZXRFeGNsdWRlQXNzaWduQ29udHJvbCh0eXBlTmFtZSkge1xuICAgIC8vIHJldHVybiB0aGlzLmZyb21Db250cm9sTGlzdC5maWx0ZXIoZWwgPT4gZWwubmFtZSAhPT0gdHlwZU5hbWUpXG4gICAgcmV0dXJuIHRoaXMuZnJvbUNvbnRyb2xMaXN0XG4gIH1cblxufVxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtYWJzdHJhY3RzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbXMvc3JjL2xpYi9zZXJ2aWNlcy9maWVsZC1hYnN0cmFjdHMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBTTNDLE1BR2EscUJBQXFCO0lBR3RCO0lBQ0E7SUFGVixZQUNVLHVCQUErQyxFQUMvQyxpQkFBbUM7UUFEbkMsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF3QjtRQUMvQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO0lBQ3pDLENBQUM7SUFDTCxZQUFZO0lBQ1osY0FBYyxHQUFvQixFQUFFLENBQUE7SUFDcEMsY0FBYztJQUNkLGlCQUFpQjtRQUNmLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3ZELElBQUksQ0FBQyxjQUFjLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQTtRQUNqQyxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxZQUFZO0lBQ1osZUFBZSxHQUFVLEVBQUUsQ0FBQTtJQUMzQixjQUFjO0lBQ2Qsa0JBQWtCO1FBQ2hCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ3pELElBQUksQ0FBQyxlQUFlLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQTtnQkFDaEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNwQixDQUFDLENBQUMsQ0FBQTtRQUNKLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUNELHVCQUF1QixDQUFDLFFBQVM7UUFDL0IsaUVBQWlFO1FBQ2pFLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQTtJQUM3QixDQUFDO3dHQTdCVSxxQkFBcUI7NEdBQXJCLHFCQUFxQixjQUZwQixNQUFNOztTQUVQLHFCQUFxQjs0RkFBckIscUJBQXFCO2tCQUhqQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpZWxkR3JvdXBBZG1pblNlcnZpY2UgfSBmcm9tICcuLi9wcm94eS9hZG1pbi9maWVsZHMvZmllbGQtZ3JvdXAtYWRtaW4uc2VydmljZSc7XG5pbXBvcnQgeyBGaWVsZEdyb3VwRHRvIH0gZnJvbSAnLi4vcHJveHkvYWRtaW4vZmllbGRzL21vZGVscyc7XG5pbXBvcnQgeyBmaW5hbGl6ZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IEZvcm1BZG1pblNlcnZpY2UgfSBmcm9tICcuLi9wcm94eS9hZG1pbi9keW5hbWljLWZvcm1zJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRmllbGRBYnN0cmFjdHNTZXJ2aWNlIHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9GaWVsZEdyb3VwQWRtaW5TZXJ2aWNlOiBGaWVsZEdyb3VwQWRtaW5TZXJ2aWNlLFxuICAgIHByaXZhdGUgX0Zvcm1BZG1pblNlcnZpY2U6IEZvcm1BZG1pblNlcnZpY2UsXG4gICkgeyB9XG4gIC8qKuWtl+auteWIhue7hOWIl+ihqCAqL1xuICBmaWVsZEdyb3VwTGlzdDogRmllbGRHcm91cER0b1tdID0gW11cbiAgLyoq6I635Y+W5a2X5q615YiG57uE5YiX6KGoICovXG4gIGdldGZpZWxkR3JvdXBMaXN0KCkge1xuICAgIHRoaXMuX0ZpZWxkR3JvdXBBZG1pblNlcnZpY2UuZ2V0TGlzdCh7fSkuc3Vic2NyaWJlKHJlcyA9PiB7XG4gICAgICB0aGlzLmZpZWxkR3JvdXBMaXN0ID0gcmVzLml0ZW1zXG4gICAgfSlcbiAgfVxuXG4gIC8qKuihqOWNleaOp+S7tuexu+WeiyAqL1xuICBmcm9tQ29udHJvbExpc3Q6IGFueVtdID0gW11cbiAgLyoq6I635Y+W6KGo5Y2V5o6n5Lu257G75Z6LICovXG4gIGdldEZyb21Db250cm9sTGlzdCgpIHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5fRm9ybUFkbWluU2VydmljZS5nZXRGb3JtQ29udHJvbHMoe30pLnN1YnNjcmliZShyZXMgPT4ge1xuICAgICAgICB0aGlzLmZyb21Db250cm9sTGlzdCA9IHJlcy5pdGVtc1xuICAgICAgICByZXNvbHZlKHJlcy5pdGVtcylcbiAgICAgIH0pXG4gICAgfSlcbiAgfVxuICBnZXRFeGNsdWRlQXNzaWduQ29udHJvbCh0eXBlTmFtZT8pIHtcbiAgICAvLyByZXR1cm4gdGhpcy5mcm9tQ29udHJvbExpc3QuZmlsdGVyKGVsID0+IGVsLm5hbWUgIT09IHR5cGVOYW1lKVxuICAgIHJldHVybiB0aGlzLmZyb21Db250cm9sTGlzdFxuICB9XG5cbn1cbiJdfQ==