pruebatlp20v17-design-system 0.0.14 → 0.0.16
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.
- package/esm2022/lib/checkbox/checkbox.component.mjs +2 -2
- package/esm2022/lib/data-table/data-table.component.mjs +2 -2
- package/esm2022/lib/expandable-tile/expandable-tile.component.mjs +4 -4
- package/esm2022/lib/global-styles.component.mjs +2 -2
- package/esm2022/lib/loading/loading.component.mjs +2 -2
- package/esm2022/lib/modal/modal.component.mjs +2 -2
- package/esm2022/lib/notification/notification.component.mjs +2 -2
- package/esm2022/lib/notification/toast.component.mjs +2 -2
- package/esm2022/lib/overflow-menu/overflow-menu.component.mjs +2 -2
- package/esm2022/lib/pagination/pagination.component.mjs +2 -2
- package/esm2022/lib/progress-indicator/progress-indicator.component.mjs +2 -2
- package/esm2022/lib/search/search.component.mjs +2 -2
- package/esm2022/lib/side-panel/side-panel.component.mjs +3 -3
- package/esm2022/lib/textarea/textarea.component.mjs +2 -2
- package/fesm2022/pruebatlp20v17-design-system.mjs +29 -29
- package/fesm2022/pruebatlp20v17-design-system.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -49,7 +49,7 @@ export class CheckboxComponent {
|
|
|
49
49
|
multi: true,
|
|
50
50
|
useExisting: CheckboxComponent,
|
|
51
51
|
},
|
|
52
|
-
], ngImport: i0, template: "<ibm-checkbox\r\n [checked]=\"!!checked\"\r\n [hideLabel]=\"hideLabel\"\r\n [indeterminate]=\"indeterminate\"\r\n [disabled]=\"disabled\"\r\n [value]=\"value\"\r\n [name]=\"name\"\r\n (checkedChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n>\r\n {{ label }}\r\n</ibm-checkbox>\r\n", styles: [":host ::ng-deep .
|
|
52
|
+
], ngImport: i0, template: "<ibm-checkbox\r\n [checked]=\"!!checked\"\r\n [hideLabel]=\"hideLabel\"\r\n [indeterminate]=\"indeterminate\"\r\n [disabled]=\"disabled\"\r\n [value]=\"value\"\r\n [name]=\"name\"\r\n (checkedChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n>\r\n {{ label }}\r\n</ibm-checkbox>\r\n", styles: [":host ::ng-deep .cds--checkbox-label:before{border-radius:2px}:host ::ng-deep .cds--checkbox-label{align-items:center}\n"], dependencies: [{ kind: "component", type: i1.Checkbox, selector: "cds-checkbox, ibm-checkbox", inputs: ["disabled", "skeleton", "hideLabel", "name", "id", "required", "value", "ariaLabel", "ariaLabelledby", "indeterminate", "checked"], outputs: ["click", "checkedChange", "indeterminateChange"] }] });
|
|
53
53
|
}
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxComponent, decorators: [{
|
|
55
55
|
type: Component,
|
|
@@ -59,7 +59,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
59
59
|
multi: true,
|
|
60
60
|
useExisting: CheckboxComponent,
|
|
61
61
|
},
|
|
62
|
-
], template: "<ibm-checkbox\r\n [checked]=\"!!checked\"\r\n [hideLabel]=\"hideLabel\"\r\n [indeterminate]=\"indeterminate\"\r\n [disabled]=\"disabled\"\r\n [value]=\"value\"\r\n [name]=\"name\"\r\n (checkedChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n>\r\n {{ label }}\r\n</ibm-checkbox>\r\n", styles: [":host ::ng-deep .
|
|
62
|
+
], template: "<ibm-checkbox\r\n [checked]=\"!!checked\"\r\n [hideLabel]=\"hideLabel\"\r\n [indeterminate]=\"indeterminate\"\r\n [disabled]=\"disabled\"\r\n [value]=\"value\"\r\n [name]=\"name\"\r\n (checkedChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n>\r\n {{ label }}\r\n</ibm-checkbox>\r\n", styles: [":host ::ng-deep .cds--checkbox-label:before{border-radius:2px}:host ::ng-deep .cds--checkbox-label{align-items:center}\n"] }]
|
|
63
63
|
}], propDecorators: { label: [{
|
|
64
64
|
type: Input
|
|
65
65
|
}], name: [{
|
|
@@ -43,11 +43,11 @@ export class DataTableComponent {
|
|
|
43
43
|
this.rowClick.emit(index);
|
|
44
44
|
}
|
|
45
45
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
46
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableComponent, selector: "tlp-data-table", inputs: { model: "model", showSelectionColumn: "showSelectionColumn", sortable: "sortable", striped: "striped", stickyHeader: "stickyHeader", size: "size" }, outputs: { sort: "sort", selectAll: "selectAll", deselectAll: "deselectAll", selectRow: "selectRow", deselectRow: "deselectRow", rowClick: "rowClick" }, ngImport: i0, template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .
|
|
46
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableComponent, selector: "tlp-data-table", inputs: { model: "model", showSelectionColumn: "showSelectionColumn", sortable: "sortable", striped: "striped", stickyHeader: "stickyHeader", size: "size" }, outputs: { sort: "sort", selectAll: "selectAll", deselectAll: "deselectAll", selectRow: "selectRow", deselectRow: "deselectRow", rowClick: "rowClick" }, ngImport: i0, template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .cds--data-table--sort th{padding-left:0}::ng-deep .cds--table-toolbar{padding-bottom:.5rem}::ng-deep .cds--toolbar-content{column-gap:.5rem}.table-wrapper{overflow-x:auto}\n"], dependencies: [{ kind: "component", type: i1.Table, selector: "cds-table, ibm-table", inputs: ["ariaLabelledby", "ariaDescribedby", "model", "size", "skeleton", "isDataGrid", "sortable", "noBorder", "showExpandAllToggle", "showSelectionColumn", "enableSingleSelect", "scrollLoadDistance", "expandButtonAriaLabel", "sortDescendingLabel", "sortAscendingLabel", "translations", "striped", "stickyHeader", "footerTemplate", "selectionLabelColumn"], outputs: ["sort", "selectAll", "deselectAll", "selectRow", "deselectRow", "rowClick", "scrollLoad"] }] });
|
|
47
47
|
}
|
|
48
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
49
49
|
type: Component,
|
|
50
|
-
args: [{ selector: "tlp-data-table", template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .
|
|
50
|
+
args: [{ selector: "tlp-data-table", template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .cds--data-table--sort th{padding-left:0}::ng-deep .cds--table-toolbar{padding-bottom:.5rem}::ng-deep .cds--toolbar-content{column-gap:.5rem}.table-wrapper{overflow-x:auto}\n"] }]
|
|
51
51
|
}], propDecorators: { model: [{
|
|
52
52
|
type: Input
|
|
53
53
|
}], showSelectionColumn: [{
|
|
@@ -22,7 +22,7 @@ export class ExpandableTileComponent {
|
|
|
22
22
|
this.updateMaxHeight();
|
|
23
23
|
}
|
|
24
24
|
get expandedHeight() {
|
|
25
|
-
const tile = this.element.querySelector(".
|
|
25
|
+
const tile = this.element.querySelector(".cds--tile");
|
|
26
26
|
if (!tile)
|
|
27
27
|
return this.currentExpandedHeight;
|
|
28
28
|
const tilePadding = parseInt(getComputedStyle(tile).paddingBottom, 10) +
|
|
@@ -35,13 +35,13 @@ export class ExpandableTileComponent {
|
|
|
35
35
|
}
|
|
36
36
|
updateMaxHeight() {
|
|
37
37
|
if (this.expanded) {
|
|
38
|
-
const content = this.element.querySelector(".
|
|
38
|
+
const content = this.element.querySelector(".cds--tile-content");
|
|
39
39
|
if (content) {
|
|
40
40
|
this.tileMaxHeight = content.getBoundingClientRect().height;
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
else {
|
|
44
|
-
const aboveFold = this.element.querySelector(".
|
|
44
|
+
const aboveFold = this.element.querySelector(".cds--tile-content__above-the-fold");
|
|
45
45
|
if (aboveFold) {
|
|
46
46
|
this.tileMaxHeight = aboveFold.getBoundingClientRect().height;
|
|
47
47
|
}
|
|
@@ -152,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
152
152
|
</button>
|
|
153
153
|
`, styles: [":host ::ng-deep{--cds-ui-01: #f5f7f9;--cds-hover-ui: #e1e8ed}\n"] }]
|
|
154
154
|
}], ctorParameters: () => [{ type: i1.I18n }, { type: i0.ElementRef }] });
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwYW5kYWJsZS10aWxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9leHBhbmRhYmxlLXRpbGUvZXhwYW5kYWJsZS10aWxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFNBQVMsRUFBYyxNQUFNLGVBQWUsQ0FBQzs7OztBQXVEeEUsTUFBTSxPQUFPLHVCQUF1QjtJQVVaO0lBQXlCO0lBVC9DLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFFakIsYUFBYSxHQUFHLENBQUMsQ0FBQztJQUNsQixxQkFBcUIsR0FBRyxDQUFDLENBQUM7SUFDMUIsT0FBTyxDQUFlO0lBRXRCLE1BQU0sQ0FBeUM7SUFDL0MsUUFBUSxDQUF5QztJQUVqRCxZQUFzQixJQUFhLEVBQVksVUFBc0I7UUFBL0MsU0FBSSxHQUFKLElBQUksQ0FBUztRQUFZLGVBQVUsR0FBVixVQUFVLENBQVk7UUFDbkUsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztRQUM3QyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3ZELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxjQUFjO1FBQ2hCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxJQUFJO1lBQUUsT0FBTyxJQUFJLENBQUMscUJBQXFCLENBQUM7UUFFN0MsTUFBTSxXQUFXLEdBQ2YsUUFBUSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7WUFDbEQsUUFBUSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNsRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsYUFBYSxHQUFHLFdBQVcsQ0FBQztRQUN4RCxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLHFCQUFxQixHQUFHLGNBQWMsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMscUJBQXFCLENBQUM7SUFDcEMsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNsQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1lBQ2pFLElBQUksT0FBTyxFQUFFLENBQUM7Z0JBQ1osSUFBSSxDQUFDLGFBQWEsR0FBRyxPQUFPLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDOUQsQ0FBQztRQUNILENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQzFDLG9DQUFvQyxDQUNyQyxDQUFDO1lBQ0YsSUFBSSxTQUFTLEVBQUUsQ0FBQztnQkFDZCxJQUFJLENBQUMsYUFBYSxHQUFHLFNBQVMsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUNoRSxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDL0IsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7d0dBckRVLHVCQUF1Qjs0RkFBdkIsdUJBQXVCLDJEQWpEeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBK0NUOzs0RkFFVSx1QkFBdUI7a0JBcERuQyxTQUFTOytCQUNFLHFCQUFxQixZQUVyQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0ErQ1QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlckNvbnRlbnRJbml0LCBDb21wb25lbnQsIEVsZW1lbnRSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBJMThuIGFzIElibUkxOG4gfSBmcm9tIFwiY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhci9pMThuXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJ0bHAtZXhwYW5kYWJsZS10aWxlXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL2V4cGFuZGFibGUtdGlsZS5jb21wb25lbnQuc2Nzc1wiXSxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGJ1dHRvblxyXG4gICAgICBjbGFzcz1cImNkcy0tdGlsZSBjZHMtLXRpbGUtLWV4cGFuZGFibGVcIlxyXG4gICAgICBbbmdDbGFzc109XCJ7ICdjZHMtLXRpbGUtLWlzLWV4cGFuZGVkJzogZXhwYW5kZWQgfVwiXHJcbiAgICAgIFtuZ1N0eWxlXT1cInsgJ21heC1oZWlnaHQnOiBleHBhbmRlZEhlaWdodCArICdweCcgfVwiXHJcbiAgICAgIHR5cGU9XCJidXR0b25cIlxyXG4gICAgICAoY2xpY2spPVwib25DbGljaygpXCJcclxuICAgID5cclxuICAgICAgPGRpdiBjbGFzcz1cImNkcy0tdGlsZV9fY2hldnJvblwiPlxyXG4gICAgICAgIDxzdmdcclxuICAgICAgICAgICpuZ0lmPVwiIWV4cGFuZGVkXCJcclxuICAgICAgICAgIHdpZHRoPVwiMTJcIlxyXG4gICAgICAgICAgaGVpZ2h0PVwiN1wiXHJcbiAgICAgICAgICB2aWV3Qm94PVwiMCAwIDEyIDdcIlxyXG4gICAgICAgICAgW2F0dHIudGl0bGVdPVwiZXhwYW5kLnN1YmplY3QgfCBhc3luY1wiXHJcbiAgICAgICAgICByb2xlPVwiaW1nXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICA8dGl0bGU+e3sgZXhwYW5kLnN1YmplY3QgfCBhc3luYyB9fTwvdGl0bGU+XHJcbiAgICAgICAgICA8cGF0aFxyXG4gICAgICAgICAgICBmaWxsLXJ1bGU9XCJub256ZXJvXCJcclxuICAgICAgICAgICAgZD1cIk02LjAwMiA1LjU1TDExLjI3IDBsLjcyNi42ODVMNi4wMDMgNyAwIC42ODUuNzI2IDB6XCJcclxuICAgICAgICAgIC8+XHJcbiAgICAgICAgPC9zdmc+XHJcbiAgICAgICAgPHN2Z1xyXG4gICAgICAgICAgKm5nSWY9XCJleHBhbmRlZFwiXHJcbiAgICAgICAgICB3aWR0aD1cIjEyXCJcclxuICAgICAgICAgIGhlaWdodD1cIjdcIlxyXG4gICAgICAgICAgdmlld0JveD1cIjAgMCAxMiA3XCJcclxuICAgICAgICAgIFthdHRyLnRpdGxlXT1cImNvbGxhcHNlLnN1YmplY3QgfCBhc3luY1wiXHJcbiAgICAgICAgICByb2xlPVwiaW1nXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICA8dGl0bGU+e3sgY29sbGFwc2Uuc3ViamVjdCB8IGFzeW5jIH19PC90aXRsZT5cclxuICAgICAgICAgIDxwYXRoXHJcbiAgICAgICAgICAgIGZpbGwtcnVsZT1cIm5vbnplcm9cIlxyXG4gICAgICAgICAgICBkPVwiTTYuMDAyIDUuNTVMMTEuMjcgMGwuNzI2LjY4NUw2LjAwMyA3IDAgLjY4NS43MjYgMHpcIlxyXG4gICAgICAgICAgLz5cclxuICAgICAgICA8L3N2Zz5cclxuICAgICAgPC9kaXY+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJjZHMtLXRpbGUtY29udGVudFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjZHMtLXRpbGUtY29udGVudF9fYWJvdmUtdGhlLWZvbGRcIj5cclxuICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlthYm92ZV1cIj48L25nLWNvbnRlbnQ+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNkcy0tdGlsZS1jb250ZW50X19iZWxvdy10aGUtZm9sZFwiPlxyXG4gICAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2JlbG93XVwiPjwvbmctY29udGVudD5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2J1dHRvbj5cclxuICBgLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRXhwYW5kYWJsZVRpbGVDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcclxuICBleHBhbmRlZCA9IGZhbHNlO1xyXG5cclxuICB0aWxlTWF4SGVpZ2h0ID0gMDtcclxuICBjdXJyZW50RXhwYW5kZWRIZWlnaHQgPSAwO1xyXG4gIGVsZW1lbnQhOiBIVE1MRWxlbWVudDtcclxuXHJcbiAgZXhwYW5kITogUmV0dXJuVHlwZTxJYm1JMThuW1wiZ2V0T3ZlcnJpZGFibGVcIl0+O1xyXG4gIGNvbGxhcHNlITogUmV0dXJuVHlwZTxJYm1JMThuW1wiZ2V0T3ZlcnJpZGFibGVcIl0+O1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgaTE4bjogSWJtSTE4biwgcHJvdGVjdGVkIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcclxuICAgIHRoaXMuZWxlbWVudCA9IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xyXG4gICAgdGhpcy5leHBhbmQgPSB0aGlzLmkxOG4uZ2V0T3ZlcnJpZGFibGUoXCJUSUxFUy5FWFBBTkRcIik7XHJcbiAgICB0aGlzLmNvbGxhcHNlID0gdGhpcy5pMThuLmdldE92ZXJyaWRhYmxlKFwiVElMRVMuQ09MTEFQU0VcIik7XHJcbiAgfVxyXG5cclxuICBuZ0FmdGVyQ29udGVudEluaXQoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZU1heEhlaWdodCgpO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGV4cGFuZGVkSGVpZ2h0KCkge1xyXG4gICAgY29uc3QgdGlsZSA9IHRoaXMuZWxlbWVudC5xdWVyeVNlbGVjdG9yKFwiLmNkcy0tdGlsZVwiKTtcclxuICAgIGlmICghdGlsZSkgcmV0dXJuIHRoaXMuY3VycmVudEV4cGFuZGVkSGVpZ2h0O1xyXG5cclxuICAgIGNvbnN0IHRpbGVQYWRkaW5nID1cclxuICAgICAgcGFyc2VJbnQoZ2V0Q29tcHV0ZWRTdHlsZSh0aWxlKS5wYWRkaW5nQm90dG9tLCAxMCkgK1xyXG4gICAgICBwYXJzZUludChnZXRDb21wdXRlZFN0eWxlKHRpbGUpLnBhZGRpbmdUb3AsIDEwKTtcclxuICAgIGNvbnN0IGV4cGFuZGVkSGVpZ2h0ID0gdGhpcy50aWxlTWF4SGVpZ2h0ICsgdGlsZVBhZGRpbmc7XHJcbiAgICBpZiAoIWlzTmFOKGV4cGFuZGVkSGVpZ2h0KSkge1xyXG4gICAgICB0aGlzLmN1cnJlbnRFeHBhbmRlZEhlaWdodCA9IGV4cGFuZGVkSGVpZ2h0O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXMuY3VycmVudEV4cGFuZGVkSGVpZ2h0O1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlTWF4SGVpZ2h0KCkge1xyXG4gICAgaWYgKHRoaXMuZXhwYW5kZWQpIHtcclxuICAgICAgY29uc3QgY29udGVudCA9IHRoaXMuZWxlbWVudC5xdWVyeVNlbGVjdG9yKFwiLmNkcy0tdGlsZS1jb250ZW50XCIpO1xyXG4gICAgICBpZiAoY29udGVudCkge1xyXG4gICAgICAgIHRoaXMudGlsZU1heEhlaWdodCA9IGNvbnRlbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkuaGVpZ2h0O1xyXG4gICAgICB9XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICBjb25zdCBhYm92ZUZvbGQgPSB0aGlzLmVsZW1lbnQucXVlcnlTZWxlY3RvcihcclxuICAgICAgICBcIi5jZHMtLXRpbGUtY29udGVudF9fYWJvdmUtdGhlLWZvbGRcIlxyXG4gICAgICApO1xyXG4gICAgICBpZiAoYWJvdmVGb2xkKSB7XHJcbiAgICAgICAgdGhpcy50aWxlTWF4SGVpZ2h0ID0gYWJvdmVGb2xkLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLmhlaWdodDtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgb25DbGljaygpIHtcclxuICAgIHRoaXMuZXhwYW5kZWQgPSAhdGhpcy5leHBhbmRlZDtcclxuICAgIHRoaXMudXBkYXRlTWF4SGVpZ2h0KCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|