@rangertechnologies/ngnxt
Version:
This library was used for creating dymanic UI based on the input JSON/data
133 lines • 38.3 kB
JavaScript
import { CommonModule } from '@angular/common';
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class NxtButtonComponent {
elementRef;
buttonValue = ''; //SKS24JAN25 button text
buttonType = 'primary'; //SKS24JAN25 If the button type is 'text-only', it should display only the text without a border or outline. For 'grey-text', the button should have a border and a background color, but the text color should be gray, similar to 'blue-text'
type = 'button'; //SKS24JAN25 The button types are "button," "group," and "dropdown."
buttonDisable = false; //SKS24JAN25 use this input to disable a button when needed.
btnBgColor = ''; // Use this input to set a custom background color for the button.
btnBorder = ''; // Use this input to set a custom border style for the button.
btnTextColor = ''; // Use this input to set a custom text color for the button.
btnHeight = ''; // Use this input to set a custom height for the button.
btnWidth = ''; // Use this input to set a custom width for the button.
btnIconLeftSrc = ''; // Use this input to set the source of the left-side icon for the button.
btnIconRightSrc = ''; // Use this input to set the source of the right-side icon for the button.
btnHoverBgColor = ''; // Use this input to set the background color of the button on hover.
btnHoverTextColor = ''; // Use this input to set the text color of the button on hover.
btnId = 'default'; // Use this input to set a custom ID for the button. Default is 'default'.
dataDismiss = ''; // Use this input to specify the dismiss action for the button (e.g., 'modal' to close a modal).
buttonBorder = '0px'; // Use this input to set the border size of the button. Default is '0px' for no border.
modalToTrigger = ''; // Use this input to specify the ID or target of the modal to be triggered.
isImageSvg = false; // Use this input to determine if the image is an SVG. Default is false (non-SVG).
tabIndex = ''; // Use this input to set the tab index for the element, controlling the focus order.
buttonConfig = ''; // Use this input to pass configuration settings for the group and dropdown buttons (e.g., styles, actions).
mode = 'edit'; // New mode input
buttonClickEmit = new EventEmitter();
iconSrc = ''; // Ensure it's always a string
isDropdownOpen = false;
// SKS24JAN25 dropdown button config
// dropdownButton = {
// btnBgColor: '#007bff',
// btnBorder: '1px solid #0056b3',
// btnTextColor: '#ffffff',
// btnHeight: '40px',
// btnWidth: '150px',
// btnHoverBgColor: '#0056b3',
// btnHoverTextColor: '#ffffff',
// label: 'Dropdown',
// iconSrc: '',
// items: [
// { label: 'Action 1',iconSrc: '', hover: false },
// { label: 'Action 2',iconSrc: '', hover: false },
// { label: 'Action 3',iconSrc: '', hover: false }
// ]
// };
constructor(elementRef) {
this.elementRef = elementRef;
}
ngOnInit() { }
//SKS24JAN25 Function to get styles for dropdown and group buttons based on the provided configuration.
getButtonStyles(config) {
return {
'button-custom-bg': config.btnBgColor || '',
'button-custom-border': config.btnBorder || '',
'button-custom-color': config.btnTextColor || '',
'button-custom-height': config.btnHeight || '',
'button-custom-width': config.btnWidth || '',
'button-hover-bg': config.btnHoverBgColor || '',
'button-hover-text-color': config.btnHoverTextColor || ''
};
}
buttonClicked($event) {
this.buttonClickEmit.emit($event);
if (this.isDropdownOpen) {
this.isDropdownOpen = false;
}
}
toggleDropdown() {
this.isDropdownOpen = !this.isDropdownOpen;
}
//SKS24JAN25 Listener for clicks outside the dropdown button to close or manage its state.
onClickOutside(event) {
if (this.isDropdownOpen && !this.elementRef.nativeElement.contains(event.target)) {
this.isDropdownOpen = false;
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NxtButtonComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NxtButtonComponent, isStandalone: true, selector: "nxt-button", inputs: { buttonValue: "buttonValue", buttonType: "buttonType", type: "type", buttonDisable: "buttonDisable", btnBgColor: "btnBgColor", btnBorder: "btnBorder", btnTextColor: "btnTextColor", btnHeight: "btnHeight", btnWidth: "btnWidth", btnIconLeftSrc: "btnIconLeftSrc", btnIconRightSrc: "btnIconRightSrc", btnHoverBgColor: "btnHoverBgColor", btnHoverTextColor: "btnHoverTextColor", btnId: "btnId", dataDismiss: "dataDismiss", buttonBorder: "buttonBorder", modalToTrigger: "modalToTrigger", isImageSvg: "isImageSvg", tabIndex: "tabIndex", buttonConfig: "buttonConfig", mode: "mode" }, outputs: { buttonClickEmit: "buttonClickEmit" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<!-- SKS24JAN25 group button -->\n<div *ngIf=\"type === 'group'\" class=\"btn-group\" role=\"group\" aria-label=\"Button Group\">\n <button *ngFor=\"let btn of buttonConfig.buttons\"\n type=\"button\"\n class=\"btn btn-icon {{btn.buttonType}} tooltip-container\"\n [attr.tabindex]=\"btn.tabIndex\"\n [attr.data-bs-toggle]=\"btn.modalToTrigger ? 'modal' : null\"\n [attr.data-bs-target]=\"btn.modalToTrigger ? '#' + btn.modalToTrigger : null\"\n [ngStyle]=\"getButtonStyles(btn)\"\n [disabled]=\"btn.buttonDisable\"\n [attr.data-bs-dismiss]=\"btn.dataDismiss\"\n (click)=\"buttonClicked(btn)\"\n [attr.id]=\"btn.btnId !== 'default' ? btn.btnId : null\">\n <img *ngIf=\"btn.isImageSvg\" [src]=\"btn.iconSrc\">\n <span class=\"custom-tooltip\" \n style=\"background-color:{{btn.tooltipBcColor}};\n color:{{btn.tooltipColor}};\n font-size:{{btn.tooltipFSize}}\">\n {{ btn.tooltip }}\n <div class=\"tooltip-pointer\" style=\"background-color:{{btn.tooltipBcColor}};\"></div>\n </span>\n </button>\n</div>\n \n<!-- SKS24JAN25 single button -->\n<button type=\"button\" *ngIf=\"type !== 'group' && type !== 'dropdown'\" class=\"btn btn-primary fc-button {{buttonType}}\" [tabindex]=\"tabIndex\"\n [attr.data-bs-toggle]=\"modalToTrigger != '' ? 'modal' : ''\"\n [attr.data-bs-target]=\"modalToTrigger != '' ? '#'+modalToTrigger : ''\"\n style=\"button-custom-bg: {{btnBgColor}};button-custom-border: {{btnBorder}};button-custom-color: {{btnTextColor}};button-custom-height: {{btnHeight}};button-custom-width: {{btnWidth}};button-hover-bg: {{btnHoverBgColor}};button-hover-text-color: {{btnHoverTextColor}};\"\n [disabled]=\"buttonDisable\" [attr.data-bs-dismiss]='dataDismiss' (click)=\"buttonClicked($event)\"\n [attr.id]=\"btnId != 'default' ? btnId : null\">\n <img *ngIf=\"btnIconLeftSrc != '' && isImageSvg\" src=\"{{btnIconLeftSrc}}\"\n class=\"fc-btn-icon left-icon\">\n <img *ngIf=\"btnIconLeftSrc != '' && !isImageSvg\" src=\"{{btnIconLeftSrc}}\" class=\"fc-btn-icon left-icon\">\n <span class=\"fc-btn-text\">{{buttonValue}}</span>\n <img *ngIf=\"btnIconRightSrc != '' && isImageSvg\" src=\"{{btnIconRightSrc}}\"\n class=\"fc-btn-icon right-icon\">\n <img *ngIf=\"btnIconRightSrc != '' && !isImageSvg\" src=\"{{btnIconRightSrc}}\" class=\"fc-btn-icon right-icon\">\n</button>\n\n<!-- SKS24JAN25 dropdown button -->\n<div *ngIf=\"type === 'dropdown'\" class=\"dropdown\">\n <svg class=\"clickable-img\" (click)=\"toggleDropdown()\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.3\" y=\"0.3\" width=\"39.4\" height=\"39.4\" rx=\"11.7\" fill=\"#FAFBFD\" stroke=\"#D5D5D5\" stroke-width=\"0.6\"/>\n <path d=\"M19.9999 25.6667C23.6818 25.6667 26.6666 22.6819 26.6666 19C26.6666 15.3181 23.6818 12.3334 19.9999 12.3334C16.318 12.3334 13.3333 15.3181 13.3333 19C13.3333 22.6819 16.318 25.6667 19.9999 25.6667Z\" fill=\"#292D32\" stroke=\"#292D32\" stroke-width=\"1.5\" stroke-miterlimit=\"10\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M17.6467 18.16L20.0001 20.5067L22.3534 18.16\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> \n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\">\n <button *ngFor=\"let btn of buttonConfig.buttons\"\n type=\"button\"\n class=\"btn btn-icon {{btn.buttonType}} tooltip-container\"\n [attr.tabindex]=\"btn.tabIndex\"\n [attr.data-bs-toggle]=\"btn.modalToTrigger ? 'modal' : null\"\n [attr.data-bs-target]=\"btn.modalToTrigger ? '#' + btn.modalToTrigger : null\"\n [ngStyle]=\"getButtonStyles(btn)\"\n [disabled]=\"btn.buttonDisable\"\n [attr.data-bs-dismiss]=\"btn.dataDismiss\"\n (click)=\"buttonClicked(btn)\"\n [attr.id]=\"btn.btnId !== 'default' ? btn.btnId : null\">\n <img *ngIf=\"btn.isImageSvg\" [src]=\"btn.iconSrc\">\n <span class=\"fc-btn-text\" style=\"padding-left: 12px;\">{{btn.name}}</span>\n </button>\n </div>\n</div>\n", styles: [".fc-button,.fc-button:hover,.fc-button:active,.fc-button:focus{outline:none;border:none;box-shadow:none}.fc-button{padding:6.5px}.fc-button:active{transform:scale(1.02)}.text-only{background:transparent;color:var(--fc-primary-color);border:none;outline:none}.grey-text{color:var(--fc-text-color)}.blue-text{color:var(--fc-primary-color)}.grey-border{color:#272525;background:transparent;border:2px solid #dddddd}.grey-border:hover{color:#272525;background:#6a2aff0a;border:2px solid #6a2aff59}.grey-border:active,.grey-border:focus{background-color:#386bf6;border:2px solid #3268ff;color:#fff}.blue-border,.blue-border:hover,.blue-border:active,.blue-border:focus{border:1px solid var(--fc-primary-color)}.bg-transparent{background-color:transparent}.custom-btn{background-color:var(button-custom-bg);border-color:var(button-custom-border);color:var(button-custom-color);height:var(button-custom-height);width:var(button-custom-width)}.custom-btn:hover,.custom-btn:active,.custom-btn:focus{border-color:var(button-custom-border);background-color:var(button-hover-bg);color:var(button-hover-text-color)}.fc-btn-text{display:inline-flex;vertical-align:middle;font-size:14px;font-weight:400;padding-left:5px;padding-right:5px}.right-icon{margin-left:5px}.left-icon{margin-right:5px}.fc-button.side-save-component,.fc-button.side-cancel-component{border:1px solid transparent}.fc-button.side-save-component:focus,.fc-button.side-cancel-component:focus{box-shadow:0 0 0 .25rem #0d6efd40;border:1px solid #86b7fe}.btn-group{background-color:#fdfeff;border:1px solid #dddddd;border-radius:7px}.btn-icon{background-color:#fdfeff;border:1px solid #dddddd}.custom-tooltip{visibility:visible;position:absolute;background-color:#0773ff;color:#fff;text-align:center;padding:5px 10px;border-radius:4px;font-size:12px;white-space:nowrap;bottom:100%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .2s;z-index:10;margin-bottom:10px}.tooltip-pointer{position:absolute;width:0;height:0;bottom:-5px;left:50%;transform:translate(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #0773ff}.tooltip-container:hover .custom-tooltip{visibility:visible;opacity:1}.clickable-img{position:relative;cursor:pointer;height:41px;transition:transform .3s ease,box-shadow .3s ease;border:2px solid #dddddd;border-radius:13px}.clickable-img:hover{transform:scale(.95);border:2px solid rgb(31,105,255);border-radius:14px}.dropdown{position:relative;display:inline-block}.dropdown-menu{right:0;top:45px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 8px #0000001a;left:unset}.dropdown .dropdown-menu{display:block}.dropdown-menu .btn{display:block;padding:10px;width:100%;text-align:left;background:transparent;border:none;cursor:pointer}.dropdown-menu .btn:hover{background-color:#f1f1f1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NxtButtonComponent, decorators: [{
type: Component,
args: [{ selector: 'nxt-button', standalone: true, imports: [CommonModule], template: "<!-- SKS24JAN25 group button -->\n<div *ngIf=\"type === 'group'\" class=\"btn-group\" role=\"group\" aria-label=\"Button Group\">\n <button *ngFor=\"let btn of buttonConfig.buttons\"\n type=\"button\"\n class=\"btn btn-icon {{btn.buttonType}} tooltip-container\"\n [attr.tabindex]=\"btn.tabIndex\"\n [attr.data-bs-toggle]=\"btn.modalToTrigger ? 'modal' : null\"\n [attr.data-bs-target]=\"btn.modalToTrigger ? '#' + btn.modalToTrigger : null\"\n [ngStyle]=\"getButtonStyles(btn)\"\n [disabled]=\"btn.buttonDisable\"\n [attr.data-bs-dismiss]=\"btn.dataDismiss\"\n (click)=\"buttonClicked(btn)\"\n [attr.id]=\"btn.btnId !== 'default' ? btn.btnId : null\">\n <img *ngIf=\"btn.isImageSvg\" [src]=\"btn.iconSrc\">\n <span class=\"custom-tooltip\" \n style=\"background-color:{{btn.tooltipBcColor}};\n color:{{btn.tooltipColor}};\n font-size:{{btn.tooltipFSize}}\">\n {{ btn.tooltip }}\n <div class=\"tooltip-pointer\" style=\"background-color:{{btn.tooltipBcColor}};\"></div>\n </span>\n </button>\n</div>\n \n<!-- SKS24JAN25 single button -->\n<button type=\"button\" *ngIf=\"type !== 'group' && type !== 'dropdown'\" class=\"btn btn-primary fc-button {{buttonType}}\" [tabindex]=\"tabIndex\"\n [attr.data-bs-toggle]=\"modalToTrigger != '' ? 'modal' : ''\"\n [attr.data-bs-target]=\"modalToTrigger != '' ? '#'+modalToTrigger : ''\"\n style=\"button-custom-bg: {{btnBgColor}};button-custom-border: {{btnBorder}};button-custom-color: {{btnTextColor}};button-custom-height: {{btnHeight}};button-custom-width: {{btnWidth}};button-hover-bg: {{btnHoverBgColor}};button-hover-text-color: {{btnHoverTextColor}};\"\n [disabled]=\"buttonDisable\" [attr.data-bs-dismiss]='dataDismiss' (click)=\"buttonClicked($event)\"\n [attr.id]=\"btnId != 'default' ? btnId : null\">\n <img *ngIf=\"btnIconLeftSrc != '' && isImageSvg\" src=\"{{btnIconLeftSrc}}\"\n class=\"fc-btn-icon left-icon\">\n <img *ngIf=\"btnIconLeftSrc != '' && !isImageSvg\" src=\"{{btnIconLeftSrc}}\" class=\"fc-btn-icon left-icon\">\n <span class=\"fc-btn-text\">{{buttonValue}}</span>\n <img *ngIf=\"btnIconRightSrc != '' && isImageSvg\" src=\"{{btnIconRightSrc}}\"\n class=\"fc-btn-icon right-icon\">\n <img *ngIf=\"btnIconRightSrc != '' && !isImageSvg\" src=\"{{btnIconRightSrc}}\" class=\"fc-btn-icon right-icon\">\n</button>\n\n<!-- SKS24JAN25 dropdown button -->\n<div *ngIf=\"type === 'dropdown'\" class=\"dropdown\">\n <svg class=\"clickable-img\" (click)=\"toggleDropdown()\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"0.3\" y=\"0.3\" width=\"39.4\" height=\"39.4\" rx=\"11.7\" fill=\"#FAFBFD\" stroke=\"#D5D5D5\" stroke-width=\"0.6\"/>\n <path d=\"M19.9999 25.6667C23.6818 25.6667 26.6666 22.6819 26.6666 19C26.6666 15.3181 23.6818 12.3334 19.9999 12.3334C16.318 12.3334 13.3333 15.3181 13.3333 19C13.3333 22.6819 16.318 25.6667 19.9999 25.6667Z\" fill=\"#292D32\" stroke=\"#292D32\" stroke-width=\"1.5\" stroke-miterlimit=\"10\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n <path d=\"M17.6467 18.16L20.0001 20.5067L22.3534 18.16\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> \n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\">\n <button *ngFor=\"let btn of buttonConfig.buttons\"\n type=\"button\"\n class=\"btn btn-icon {{btn.buttonType}} tooltip-container\"\n [attr.tabindex]=\"btn.tabIndex\"\n [attr.data-bs-toggle]=\"btn.modalToTrigger ? 'modal' : null\"\n [attr.data-bs-target]=\"btn.modalToTrigger ? '#' + btn.modalToTrigger : null\"\n [ngStyle]=\"getButtonStyles(btn)\"\n [disabled]=\"btn.buttonDisable\"\n [attr.data-bs-dismiss]=\"btn.dataDismiss\"\n (click)=\"buttonClicked(btn)\"\n [attr.id]=\"btn.btnId !== 'default' ? btn.btnId : null\">\n <img *ngIf=\"btn.isImageSvg\" [src]=\"btn.iconSrc\">\n <span class=\"fc-btn-text\" style=\"padding-left: 12px;\">{{btn.name}}</span>\n </button>\n </div>\n</div>\n", styles: [".fc-button,.fc-button:hover,.fc-button:active,.fc-button:focus{outline:none;border:none;box-shadow:none}.fc-button{padding:6.5px}.fc-button:active{transform:scale(1.02)}.text-only{background:transparent;color:var(--fc-primary-color);border:none;outline:none}.grey-text{color:var(--fc-text-color)}.blue-text{color:var(--fc-primary-color)}.grey-border{color:#272525;background:transparent;border:2px solid #dddddd}.grey-border:hover{color:#272525;background:#6a2aff0a;border:2px solid #6a2aff59}.grey-border:active,.grey-border:focus{background-color:#386bf6;border:2px solid #3268ff;color:#fff}.blue-border,.blue-border:hover,.blue-border:active,.blue-border:focus{border:1px solid var(--fc-primary-color)}.bg-transparent{background-color:transparent}.custom-btn{background-color:var(button-custom-bg);border-color:var(button-custom-border);color:var(button-custom-color);height:var(button-custom-height);width:var(button-custom-width)}.custom-btn:hover,.custom-btn:active,.custom-btn:focus{border-color:var(button-custom-border);background-color:var(button-hover-bg);color:var(button-hover-text-color)}.fc-btn-text{display:inline-flex;vertical-align:middle;font-size:14px;font-weight:400;padding-left:5px;padding-right:5px}.right-icon{margin-left:5px}.left-icon{margin-right:5px}.fc-button.side-save-component,.fc-button.side-cancel-component{border:1px solid transparent}.fc-button.side-save-component:focus,.fc-button.side-cancel-component:focus{box-shadow:0 0 0 .25rem #0d6efd40;border:1px solid #86b7fe}.btn-group{background-color:#fdfeff;border:1px solid #dddddd;border-radius:7px}.btn-icon{background-color:#fdfeff;border:1px solid #dddddd}.custom-tooltip{visibility:visible;position:absolute;background-color:#0773ff;color:#fff;text-align:center;padding:5px 10px;border-radius:4px;font-size:12px;white-space:nowrap;bottom:100%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .2s;z-index:10;margin-bottom:10px}.tooltip-pointer{position:absolute;width:0;height:0;bottom:-5px;left:50%;transform:translate(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #0773ff}.tooltip-container:hover .custom-tooltip{visibility:visible;opacity:1}.clickable-img{position:relative;cursor:pointer;height:41px;transition:transform .3s ease,box-shadow .3s ease;border:2px solid #dddddd;border-radius:13px}.clickable-img:hover{transform:scale(.95);border:2px solid rgb(31,105,255);border-radius:14px}.dropdown{position:relative;display:inline-block}.dropdown-menu{right:0;top:45px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 8px #0000001a;left:unset}.dropdown .dropdown-menu{display:block}.dropdown-menu .btn{display:block;padding:10px;width:100%;text-align:left;background:transparent;border:none;cursor:pointer}.dropdown-menu .btn:hover{background-color:#f1f1f1}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { buttonValue: [{
type: Input
}], buttonType: [{
type: Input
}], type: [{
type: Input
}], buttonDisable: [{
type: Input
}], btnBgColor: [{
type: Input
}], btnBorder: [{
type: Input
}], btnTextColor: [{
type: Input
}], btnHeight: [{
type: Input
}], btnWidth: [{
type: Input
}], btnIconLeftSrc: [{
type: Input
}], btnIconRightSrc: [{
type: Input
}], btnHoverBgColor: [{
type: Input
}], btnHoverTextColor: [{
type: Input
}], btnId: [{
type: Input
}], dataDismiss: [{
type: Input
}], buttonBorder: [{
type: Input
}], modalToTrigger: [{
type: Input
}], isImageSvg: [{
type: Input
}], tabIndex: [{
type: Input
}], buttonConfig: [{
type: Input
}], mode: [{
type: Input
}], buttonClickEmit: [{
type: Output
}], onClickOutside: [{
type: HostListener,
args: ['document:click', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnh0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvY29tcG9uZW50cy9idXR0b24vbnh0LWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvY29tcG9uZW50cy9idXR0b24vbnh0LWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVF6RyxNQUFNLE9BQU8sa0JBQWtCO0lBZ0RUO0lBOUNYLFdBQVcsR0FBVyxFQUFFLENBQUMsQ0FBQyx5QkFBeUI7SUFDbkQsVUFBVSxHQUFXLFNBQVMsQ0FBQyxDQUFDLCtPQUErTztJQUMvUSxJQUFJLEdBQVcsUUFBUSxDQUFDLENBQUMsb0VBQW9FO0lBQzdGLGFBQWEsR0FBWSxLQUFLLENBQUMsQ0FBQyw0REFBNEQ7SUFDNUYsVUFBVSxHQUFXLEVBQUUsQ0FBQyxDQUFDLGtFQUFrRTtJQUMzRixTQUFTLEdBQVcsRUFBRSxDQUFDLENBQUMsOERBQThEO0lBQ3RGLFlBQVksR0FBVyxFQUFFLENBQUMsQ0FBQyw0REFBNEQ7SUFDdkYsU0FBUyxHQUFXLEVBQUUsQ0FBQyxDQUFDLHdEQUF3RDtJQUNoRixRQUFRLEdBQVcsRUFBRSxDQUFDLENBQUMsdURBQXVEO0lBQzlFLGNBQWMsR0FBVyxFQUFFLENBQUMsQ0FBQyx5RUFBeUU7SUFDdEcsZUFBZSxHQUFXLEVBQUUsQ0FBQyxDQUFDLDBFQUEwRTtJQUN4RyxlQUFlLEdBQVcsRUFBRSxDQUFDLENBQUMscUVBQXFFO0lBQ25HLGlCQUFpQixHQUFX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Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUVJLGVBQWU7c0JBQXhCLE1BQU07Z0JBcURQLGNBQWM7c0JBRGIsWUFBWTt1QkFBQyxnQkFBZ0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ254dC1idXR0b24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGVVcmw6ICcuL254dC1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ueHQtYnV0dG9uLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBOeHRCdXR0b25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuIFxuICBASW5wdXQoKSBidXR0b25WYWx1ZTogc3RyaW5nID0gJyc7IC8vU0tTMjRKQU4yNSBidXR0b24gdGV4dCBcbiAgQElucHV0KCkgYnV0dG9uVHlwZTogc3RyaW5nID0gJ3ByaW1hcnknOyAvL1NLUzI0SkFOMjUgSWYgdGhlIGJ1dHRvbiB0eXBlIGlzICd0ZXh0LW9ubHknLCBpdCBzaG91bGQgZGlzcGxheSBvbmx5IHRoZSB0ZXh0IHdpdGhvdXQgYSBib3JkZXIgb3Igb3V0bGluZS4gRm9yICdncmV5LXRleHQnLCB0aGUgYnV0dG9uIHNob3VsZCBoYXZlIGEgYm9yZGVyIGFuZCBhIGJhY2tncm91bmQgY29sb3IsIGJ1dCB0aGUgdGV4dCBjb2xvciBzaG91bGQgYmUgZ3JheSwgc2ltaWxhciB0byAnYmx1ZS10ZXh0J1xuICBASW5wdXQoKSB0eXBlOiBzdHJpbmcgPSAnYnV0dG9uJzsgLy9TS1MyNEpBTjI1IFRoZSBidXR0b24gdHlwZXMgYXJlIFwiYnV0dG9uLFwiIFwiZ3JvdXAsXCIgYW5kIFwiZHJvcGRvd24uXCJcbiAgQElucHV0KCkgYnV0dG9uRGlzYWJsZTogYm9vbGVhbiA9IGZhbHNlOyAvL1NLUzI0SkFOMjUgdXNlIHRoaXMgaW5wdXQgdG8gZGlzYWJsZSBhIGJ1dHRvbiB3aGVuIG5lZWRlZC5cbiAgQElucHV0KCkgYnRuQmdDb2xvcjogc3RyaW5nID0gJyc7IC8vIFVzZSB0aGlzIGlucHV0IHRvIHNldCBhIGN1c3RvbSBiYWNrZ3JvdW5kIGNvbG9yIGZvciB0aGUgYnV0dG9uLlxuICBASW5wdXQoKSBidG5Cb3JkZXI6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgYSBjdXN0b20gYm9yZGVyIHN0eWxlIGZvciB0aGUgYnV0dG9uLlxuICBASW5wdXQoKSBidG5UZXh0Q29sb3I6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgYSBjdXN0b20gdGV4dCBjb2xvciBmb3IgdGhlIGJ1dHRvbi5cbiAgQElucHV0KCkgYnRuSGVpZ2h0OiBzdHJpbmcgPSAnJzsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gc2V0IGEgY3VzdG9tIGhlaWdodCBmb3IgdGhlIGJ1dHRvbi5cbiAgQElucHV0KCkgYnRuV2lkdGg6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgYSBjdXN0b20gd2lkdGggZm9yIHRoZSBidXR0b24uXG4gIEBJbnB1dCgpIGJ0bkljb25MZWZ0U3JjOiBzdHJpbmcgPSAnJzsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gc2V0IHRoZSBzb3VyY2Ugb2YgdGhlIGxlZnQtc2lkZSBpY29uIGZvciB0aGUgYnV0dG9uLlxuICBASW5wdXQoKSBidG5JY29uUmlnaHRTcmM6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgdGhlIHNvdXJjZSBvZiB0aGUgcmlnaHQtc2lkZSBpY29uIGZvciB0aGUgYnV0dG9uLlxuICBASW5wdXQoKSBidG5Ib3ZlckJnQ29sb3I6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgdGhlIGJhY2tncm91bmQgY29sb3Igb2YgdGhlIGJ1dHRvbiBvbiBob3Zlci5cbiAgQElucHV0KCkgYnRuSG92ZXJUZXh0Q29sb3I6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzZXQgdGhlIHRleHQgY29sb3Igb2YgdGhlIGJ1dHRvbiBvbiBob3Zlci5cbiAgQElucHV0KCkgYnRuSWQ6IHN0cmluZyA9ICdkZWZhdWx0JzsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gc2V0IGEgY3VzdG9tIElEIGZvciB0aGUgYnV0dG9uLiBEZWZhdWx0IGlzICdkZWZhdWx0Jy5cbiAgQElucHV0KCkgZGF0YURpc21pc3M6IHN0cmluZyA9ICcnOyAvLyBVc2UgdGhpcyBpbnB1dCB0byBzcGVjaWZ5IHRoZSBkaXNtaXNzIGFjdGlvbiBmb3IgdGhlIGJ1dHRvbiAoZS5nLiwgJ21vZGFsJyB0byBjbG9zZSBhIG1vZGFsKS5cbiAgQElucHV0KCkgYnV0dG9uQm9yZGVyOiBzdHJpbmcgPSAnMHB4JzsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gc2V0IHRoZSBib3JkZXIgc2l6ZSBvZiB0aGUgYnV0dG9uLiBEZWZhdWx0IGlzICcwcHgnIGZvciBubyBib3JkZXIuXG4gIEBJbnB1dCgpIG1vZGFsVG9UcmlnZ2VyOiBzdHJpbmcgPSAnJzsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gc3BlY2lmeSB0aGUgSUQgb3IgdGFyZ2V0IG9mIHRoZSBtb2RhbCB0byBiZSB0cmlnZ2VyZWQuXG4gIEBJbnB1dCgpIGlzSW1hZ2VTdmc6IGJvb2xlYW4gPSBmYWxzZTsgLy8gVXNlIHRoaXMgaW5wdXQgdG8gZGV0ZXJtaW5lIGlmIHRoZSBpbWFnZSBpcyBhbiBTVkcuIERlZmF1bHQgaXMgZmFsc2UgKG5vbi1TVkcpLlxuICBASW5wdXQoKSB0YWJJbmRleDogYW55ID0gJyc7Ly8gVXNlIHRoaXMgaW5wdXQgdG8gc2V0IHRoZSB0YWIgaW5kZXggZm9yIHRoZSBlbGVtZW50LCBjb250cm9sbGluZyB0aGUgZm9jdXMgb3JkZXIuXG4gIEBJbnB1dCgpIGJ1dHRvbkNvbmZpZzogYW55ID0gJyc7IC8vIFVzZSB0aGlzIGlucHV0IHRvIHBhc3MgY29uZmlndXJhdGlvbiBzZXR0aW5ncyBmb3IgdGhlIGdyb3VwIGFuZCBkcm9wZG93biBidXR0b25zIChlLmcuLCBzdHlsZXMsIGFjdGlvbnMpLlxuICBASW5wdXQoKSBtb2RlOiAndmlldycgfCAnZWRpdCcgfCAncHJpbnQnID0gJ2VkaXQnOyAvLyBOZXcgbW9kZSBpbnB1dFxuICBcbiAgQE91dHB1dCgpIGJ1dHRvbkNsaWNrRW1pdDpFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuICBpY29uU3JjOiBhbnkgPSAnJzsgLy8gRW5zdXJlIGl0J3MgYWx3YXlzIGEgc3RyaW5nXG4gIGlzRHJvcGRvd25PcGVuID0gZmFsc2U7XG5cbiAgXG5cbiAgLy8gU0tTMjRKQU4yNSBkcm9wZG93biBidXR0b24gY29uZmlnXG5cbiAgLy8gZHJvcGRvd25CdXR0b24gPSB7XG4gIC8vICAgYnRuQmdDb2xvcjogJyMwMDdiZmYnLFxuICAvLyAgIGJ0bkJvcmRlcjogJzFweCBzb2xpZCAjMDA1NmIzJyxcbiAgLy8gICBidG5UZXh0Q29sb3I6ICcjZmZmZmZmJyxcbiAgLy8gICBidG5IZWlnaHQ6ICc0MHB4JyxcbiAgLy8gICBidG5XaWR0aDogJzE1MHB4JyxcbiAgLy8gICBidG5Ib3ZlckJnQ29sb3I6ICcjMDA1NmIzJyxcbiAgLy8gICBidG5Ib3ZlclRleHRDb2xvcjogJyNmZmZmZmYnLFxuICAvLyAgIGxhYmVsOiAnRHJvcGRvd24nLFxuICAvLyAgIGljb25TcmM6ICcnLFxuICAvLyAgIGl0ZW1zOiBbXG4gIC8vICAgICB7IGxhYmVsOiAnQWN0aW9uIDEnLGljb25TcmM6ICcnLCBob3ZlcjogZmFsc2UgfSxcbiAgLy8gICAgIHsgbGFiZWw6ICdBY3Rpb24gMicsaWNvblNyYzogJycsIGhvdmVyOiBmYWxzZSB9LFxuICAvLyAgICAgeyBsYWJlbDogJ0FjdGlvbiAzJyxpY29uU3JjOiAnJywgaG92ZXI6IGZhbHNlIH1cbiAgLy8gICBdXG4gIC8vIH07XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZikgeyB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7fVxuICAvL1NLUzI0SkFOMjUgRnVuY3Rpb24gdG8gZ2V0IHN0eWxlcyBmb3IgZHJvcGRvd24gYW5kIGdyb3VwIGJ1dHRvbnMgYmFzZWQgb24gdGhlIHByb3ZpZGVkIGNvbmZpZ3VyYXRpb24uXG4gIGdldEJ1dHRvblN0eWxlcyhjb25maWc6IGFueSk6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0ge1xuICAgIHJldHVybiB7XG4gICAgICAnYnV0dG9uLWN1c3RvbS1iZyc6IGNvbmZpZy5idG5CZ0NvbG9yIHx8ICcnLFxuICAgICAgJ2J1dHRvbi1jdXN0b20tYm9yZGVyJzogY29uZmlnLmJ0bkJvcmRlciB8fCAnJyxcbiAgICAgICdidXR0b24tY3VzdG9tLWNvbG9yJzogY29uZmlnLmJ0blRleHRDb2xvciB8fCAnJyxcbiAgICAgICdidXR0b24tY3VzdG9tLWhlaWdodCc6IGNvbmZpZy5idG5IZWlnaHQgfHwgJycsXG4gICAgICAnYnV0dG9uLWN1c3RvbS13aWR0aCc6IGNvbmZpZy5idG5XaWR0aCB8fCAnJyxcbiAgICAgICdidXR0b24taG92ZXItYmcnOiBjb25maWcuYnRuSG92ZXJCZ0NvbG9yIHx8ICcnLFxuICAgICAgJ2J1dHRvbi1ob3Zlci10ZXh0LWNvbG9yJzogY29uZmlnLmJ0bkhvdmVyVGV4dENvbG9yIHx8ICcnXG4gICAgfTtcbiAgfVxuICBcblxuICBidXR0b25DbGlja2VkKCRldmVudDphbnkpe1xuICAgIHRoaXMuYnV0dG9uQ2xpY2tFbWl0LmVtaXQoJGV2ZW50KTtcbiAgICBpZih0aGlzLmlzRHJvcGRvd25PcGVuKXtcbiAgICAgIHRoaXMuaXNEcm9wZG93bk9wZW49ZmFsc2VcbiAgICB9XG4gIH1cblxuICB0b2dnbGVEcm9wZG93bigpIHtcbiAgICB0aGlzLmlzRHJvcGRvd25PcGVuID0gIXRoaXMuaXNEcm9wZG93bk9wZW47XG4gIH1cbi8vU0tTMjRKQU4yNSBMaXN0ZW5lciBmb3IgY2xpY2tzIG91dHNpZGUgdGhlIGRyb3Bkb3duIGJ1dHRvbiB0byBjbG9zZSBvciBtYW5hZ2UgaXRzIHN0YXRlLlxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50J10pXG4gIG9uQ2xpY2tPdXRzaWRlKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgaWYgKHRoaXMuaXNEcm9wZG93bk9wZW4gJiYgIXRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldClcbiAgICApIHtcbiAgICAgIHRoaXMuaXNEcm9wZG93bk9wZW4gPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cbiIsIjwhLS0gU0tTMjRKQU4yNSBncm91cCBidXR0b24gLS0+XG48ZGl2ICpuZ0lmPVwidHlwZSA9PT0gJ2dyb3VwJ1wiIGNsYXNzPVwiYnRuLWdyb3VwXCIgcm9sZT1cImdyb3VwXCIgYXJpYS1sYWJlbD1cIkJ1dHRvbiBHcm91cFwiPlxuICAgIDxidXR0b24gKm5nRm9yPVwibGV0IGJ0biBvZiBidXR0b25Db25maWcuYnV0dG9uc1wiXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIGNsYXNzPVwiYnRuIGJ0bi1pY29uIHt7YnRuLmJ1dHRvblR5cGV9fSB0b29sdGlwLWNvbnRhaW5lclwiXG4gICAgICAgICAgICBbYXR0ci50YWJpbmRleF09XCJidG4udGFiSW5kZXhcIlxuICAgICAgICAgICAgW2F0dHIuZGF0YS1icy10b2dnbGVdPVwiYnRuLm1vZGFsVG9UcmlnZ2VyID8gJ21vZGFsJyA6IG51bGxcIlxuICAgICAgICAgICAgW2F0dHIuZGF0YS1icy10YXJnZXRdPVwiYnRuLm1vZGFsVG9UcmlnZ2VyID8gJyMnICsgYnRuLm1vZGFsVG9UcmlnZ2VyIDogbnVsbFwiXG4gICAgICAgICAgICBbbmdTdHlsZV09XCJnZXRCdXR0b25TdHlsZXMoYnRuKVwiXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwiYnRuLmJ1dHRvbkRpc2FibGVcIlxuICAgICAgICAgICAgW2F0dHIuZGF0YS1icy1kaXNtaXNzXT1cImJ0bi5kYXRhRGlzbWlzc1wiXG4gICAgICAgICAgICAoY2xpY2spPVwiYnV0dG9uQ2xpY2tlZChidG4pXCJcbiAgICAgICAgICAgIFthdHRyLmlkXT1cImJ0bi5idG5JZCAhPT0gJ2RlZmF1bHQnID8gYnRuLmJ0bklkIDogbnVsbFwiPlxuICAgICAgICA8aW1nICpuZ0lmPVwiYnRuLmlzSW1hZ2VTdmdcIiBbc3JjXT1cImJ0bi5pY29uU3JjXCI+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiY3VzdG9tLXRvb2x0aXBcIiBcbiAgICAgICAgICAgIHN0eWxlPVwiYmFja2dyb3VuZC1jb2xvcjp7e2J0bi50b29sdGlwQmNDb2xvcn19O1xuICAgICAgICAgICAgY29sb3I6e3tidG4udG9vbHRpcENvbG9yfX07XG4gICAgICAgICAgICBmb250LXNpemU6e3tidG4udG9vbHRpcEZTaXplfX1cIj5cbiAgICAgICAgICAgIHt7IGJ0bi50b29sdGlwIH19XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwidG9vbHRpcC1wb2ludGVyXCIgc3R5bGU9XCJiYWNrZ3JvdW5kLWNvbG9yOnt7YnRuLnRvb2x0aXBCY0NvbG9yfX07XCI+PC9kaXY+XG4gICAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbjwvZGl2PlxuICBcbjwhLS0gU0tTMjRKQU4yNSBzaW5nbGUgYnV0dG9uIC0tPlxuPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgICpuZ0lmPVwidHlwZSAhPT0gJ2dyb3VwJyAmJiB0eXBlICE9PSAnZHJvcGRvd24nXCIgY2xhc3M9XCJidG4gYnRuLXByaW1hcnkgZmMtYnV0dG9uIHt7YnV0dG9uVHlwZX19XCIgW3RhYmluZGV4XT1cInRhYkluZGV4XCJcbiAgICBbYXR0ci5kYXRhLWJzLXRvZ2dsZV09XCJtb2RhbFRvVHJpZ2dlciAhPSAnJyA/ICdtb2RhbCcgOiAnJ1wiXG4gICAgW2F0dHIuZGF0YS1icy10YXJnZXRdPVwibW9kYWxUb1RyaWdnZXIgIT0gJycgPyAnIycrbW9kYWxUb1RyaWdnZXIgOiAnJ1wiXG4gICAgc3R5bGU9XCJidXR0b24tY3VzdG9tLWJnOiB7e2J0bkJnQ29sb3J9fTtidXR0b24tY3VzdG9tLWJvcmRlcjoge3tidG5Cb3JkZXJ9fTtidXR0b24tY3VzdG9tLWNvbG9yOiB7e2J0blRleHRDb2xvcn19O2J1dHRvbi1jdXN0b20taGVpZ2h0OiB7e2J0bkhlaWdodH19O2J1dHRvbi1jdXN0b20td2lkdGg6IHt7YnRuV2lkdGh9fTtidXR0b24taG92ZXItYmc6IHt7YnRuSG92ZXJCZ0NvbG9yfX07YnV0dG9uLWhvdmVyLXRleHQtY29sb3I6IHt7YnRuSG92ZXJUZXh0Q29sb3J9fTtcIlxuICAgIFtkaXNhYmxlZF09XCJidXR0b25EaXNhYmxlXCIgW2F0dHIuZGF0YS1icy1kaXNtaXNzXT0nZGF0YURpc21pc3MnIChjbGljayk9XCJidXR0b25DbGlja2VkKCRldmVudClcIlxuICAgIFthdHRyLmlkXT1cImJ0bklkICE9ICdkZWZhdWx0JyA/IGJ0bklkIDogbnVsbFwiPlxuICAgIDxpbWcgKm5nSWY9XCJidG5JY29uTGVmdFNyYyAhPSAnJyAmJiBpc0ltYWdlU3ZnXCIgc3JjPVwie3tidG5JY29uTGVmdFNyY319XCJcbiAgICAgICAgY2xhc3M9XCJmYy1idG4taWNvbiBsZWZ0LWljb25cIj5cbiAgICA8aW1nICpuZ0lmPVwiYnRuSWNvbkxlZnRTcmMgIT0gJycgJiYgIWlzSW1hZ2VTdmdcIiBzcmM9XCJ7e2J0bkljb25MZWZ0U3JjfX1cIiBjbGFzcz1cImZjLWJ0bi1pY29uIGxlZnQtaWNvblwiPlxuICAgIDxzcGFuIGNsYXNzPVwiZmMtYnRuLXRleHRcIj57e2J1dHRvblZhbHVlfX08L3NwYW4+XG4gICAgPGltZyAqbmdJZj1cImJ0bkljb25SaWdodFNyYyAhPSAnJyAmJiBpc0ltYWdlU3ZnXCIgc3JjPVwie3tidG5JY29uUmlnaHRTcmN9fVwiXG4gICAgICAgIGNsYXNzPVwiZmMtYnRuLWljb24gcmlnaHQtaWNvblwiPlxuICAgIDxpbWcgKm5nSWY9XCJidG5JY29uUmlnaHRTcmMgIT0gJycgJiYgIWlzSW1hZ2VTdmdcIiBzcmM9XCJ7e2J0bkljb25SaWdodFNyY319XCIgY2xhc3M9XCJmYy1idG4taWNvbiByaWdodC1pY29uXCI+XG48L2J1dHRvbj5cblxuPCEtLSBTS1MyNEpBTjI1IGRyb3Bkb3duIGJ1dHRvbiAtLT5cbjxkaXYgKm5nSWY9XCJ0eXBlID09PSAnZHJvcGRvd24nXCIgY2xhc3M9XCJkcm9wZG93blwiPlxuICAgIDxzdmcgY2xhc3M9XCJjbGlja2FibGUtaW1nXCIgKGNsaWNrKT1cInRvZ2dsZURyb3Bkb3duKClcIiAgd2lkdGg9XCI0MFwiIGhlaWdodD1cIjQwXCIgdmlld0JveD1cIjAgMCA0MCA0MFwiIGZpbGw9XCJub25lXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgICA8cmVjdCB4PVwiMC4zXCIgeT1cIjAuM1wiIHdpZHRoPVwiMzkuNFwiIGhlaWdodD1cIjM5LjRcIiByeD1cIjExLjdcIiBmaWxsPVwiI0ZBRkJGRFwiIHN0cm9rZT1cIiNENUQ1RDVcIiBzdHJva2Utd2lkdGg9XCIwLjZcIi8+XG4gICAgICAgIDxwYXRoIGQ9XCJNMTkuOTk5OSAyNS42NjY3QzIzLjY4MTggMjUuNjY2NyAyNi42NjY2IDIyLjY4MTkgMjYuNjY2NiAxOUMyNi42NjY2IDE1LjMxODEgMjMuNjgxOCAxMi4zMzM0IDE5Ljk5OTkgMTIuMzMzNEMxNi4zMTggMTIuMzMzNCAxMy4zMzMzIDE1LjMxODEgMTMuMzMzMyAxOUMxMy4zMzMzIDIyLjY4MTkgMTYuMzE4IDI1LjY2NjcgMTkuOTk5OSAyNS42NjY3WlwiIGZpbGw9XCIjMjkyRDMyXCIgc3Ryb2tlPVwiIzI5MkQzMlwiIHN0cm9rZS13aWR0aD1cIjEuNVwiIHN0cm9rZS1taXRlcmxpbWl0PVwiMTBcIiBzdHJva2UtbGluZWNhcD1cInJvdW5kXCIgc3Ryb2tlLWxpbmVqb2luPVwicm91bmRcIi8+XG4gICAgICAgIDxwYXRoIGQ9XCJNMTcuNjQ2NyAxOC4xNkwyMC4wMDAxIDIwLjUwNjdMMjIuMzUzNCAxOC4xNlwiIHN0cm9rZT1cIndoaXRlXCIgc3Ryb2tlLXdpZHRoPVwiMS41XCIgc3Ryb2tlLWxpbmVjYXA9XCJyb3VuZFwiIHN0cm9rZS1saW5lam9pbj1cInJvdW5kXCIvPlxuICAgIDwvc3ZnPiAgXG4gICAgPGRpdiBjbGFzcz1cImRyb3Bkb3duLW1lbnVcIiAgKm5nSWY9XCJpc0Ryb3Bkb3duT3BlblwiPlxuICAgICAgICA8YnV0dG9uICpuZ0Zvcj1cImxldCBidG4gb2YgYnV0dG9uQ29uZmlnLmJ1dHRvbnNcIlxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICBjbGFzcz1cImJ0biBidG4taWNvbiB7e2J0bi5idXR0b25UeXBlfX0gdG9vbHRpcC1jb250YWluZXJcIlxuICAgICAgICAgICAgW2F0dHIudGFiaW5kZXhdPVwiYnRuLnRhYkluZGV4XCJcbiAgICAgICAgICAgIFthdHRyLmRhdGEtYnMtdG9nZ2xlXT1cImJ0bi5tb2RhbFRvVHJpZ2dlciA/ICdtb2RhbCcgOiBudWxsXCJcbiAgICAgICAgICAgIFthdHRyLmRhdGEtYnMtdGFyZ2V0XT1cImJ0bi5tb2RhbFRvVHJpZ2dlciA/ICcjJyArIGJ0bi5tb2RhbFRvVHJpZ2dlciA6IG51bGxcIlxuICAgICAgICAgICAgW25nU3R5bGVdPVwiZ2V0QnV0dG9uU3R5bGVzKGJ0bilcIlxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cImJ0bi5idXR0b25EaXNhYmxlXCJcbiAgICAgICAgICAgIFthdHRyLmRhdGEtYnMtZGlzbWlzc109XCJidG4uZGF0YURpc21pc3NcIlxuICAgICAgICAgICAgKGNsaWNrKT1cImJ1dHRvbkNsaWNrZWQoYnRuKVwiXG4gICAgICAgICAgICBbYXR0ci5pZF09XCJidG4uYnRuSWQgIT09ICdkZWZhdWx0JyA/IGJ0bi5idG5JZCA6IG51bGxcIj5cbiAgICAgICAgICAgIDxpbWcgKm5nSWY9XCJidG4uaXNJbWFnZVN2Z1wiIFtzcmNdPVwiYnRuLmljb25TcmNcIj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZmMtYnRuLXRleHRcIiBzdHlsZT1cInBhZGRpbmctbGVmdDogMTJweDtcIj57e2J0bi5uYW1lfX08L3NwYW4+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=