UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

362 lines 58.6 kB
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core'; import { clamp, min, round } from 'lodash-es'; import { mergeRight } from 'ramda'; import { isMac } from '../../core/utils/browser'; import { GraphStoreService } from '../graph-store.service'; import { getRect } from '../utils'; import * as i0 from "@angular/core"; import * as i1 from "../graph-store.service"; import * as i2 from "@angular/common"; import * as i3 from "@alauda/ui"; import * as i4 from "../../translate/translate.pipe"; const _c0 = ["canvas"]; const _c1 = ["surface"]; const _c2 = ["*", [["acl-graph-links"]], [["acl-graph-actions"]]]; const _c3 = ["*", "acl-graph-links", "acl-graph-actions"]; function GraphCanvasComponent_div_21_ng_container_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainerStart(0); i0.ɵɵelement(1, "aui-icon", 15); i0.ɵɵelementStart(2, "span"); i0.ɵɵtext(3); i0.ɵɵpipe(4, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementContainerEnd(); } if (rf & 2) { i0.ɵɵadvance(3); i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 1, "loading_please_wait")); } } function GraphCanvasComponent_div_21_ng_container_3_Template(rf, ctx) { if (rf & 1) { const _r3 = i0.ɵɵgetCurrentView(); i0.ɵɵelementContainerStart(0); i0.ɵɵelementStart(1, "span"); i0.ɵɵtext(2); i0.ɵɵpipe(3, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementStart(4, "button", 16); i0.ɵɵlistener("click", function GraphCanvasComponent_div_21_ng_container_3_Template_button_click_4_listener() { i0.ɵɵrestoreView(_r3); const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.retry.emit()); }); i0.ɵɵtext(5); i0.ɵɵpipe(6, "translate"); i0.ɵɵelementEnd(); i0.ɵɵelementContainerEnd(); } if (rf & 2) { i0.ɵɵadvance(2); i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 2, "failed_load_please")); i0.ɵɵadvance(3); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 4, "retry"), " "); } } function GraphCanvasComponent_div_21_Template(rf, ctx) { if (rf & 1) { const _r2 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "div", 12); i0.ɵɵlistener("wheel", function GraphCanvasComponent_div_21_Template_div_wheel_0_listener($event) { i0.ɵɵrestoreView(_r2); return i0.ɵɵresetView($event.stopPropagation()); })("mousedown", function GraphCanvasComponent_div_21_Template_div_mousedown_0_listener($event) { i0.ɵɵrestoreView(_r2); return i0.ɵɵresetView($event.stopPropagation()); }); i0.ɵɵelementStart(1, "div", 13); i0.ɵɵtemplate(2, GraphCanvasComponent_div_21_ng_container_2_Template, 5, 3, "ng-container", 14)(3, GraphCanvasComponent_div_21_ng_container_3_Template, 7, 6, "ng-container", 14); i0.ɵɵelementEnd()(); } if (rf & 2) { const ctx_r3 = i0.ɵɵnextContext(); i0.ɵɵadvance(2); i0.ɵɵproperty("ngIf", ctx_r3.loading); i0.ɵɵadvance(); i0.ɵɵproperty("ngIf", ctx_r3.loadFailed); } } const isMacSystem = isMac(); export class GraphCanvasComponent { get dragging() { return !!this.dragStartPoint; } get canvasStyle() { return { padding: this.boundary + 'px', justifyContent: xSelector(this.transformState.origin[0], [ 'flex-start', 'center', 'flex-end', ]), alignItems: ySelector(this.transformState.origin[1], [ 'flex-start', 'center', 'flex-end', ]), cursor: this.dragging ? 'grabbing' : 'grab', }; } get surfaceStyle() { return { transformOrigin: this.transformState.origin.join(' '), transform: `translate(${this.transformState.translate[0]}px, ${this.transformState.translate[1]}px) scale(${this.transformState.scale})`, }; } constructor(graphStore) { this.graphStore = graphStore; this.minScale = 0.25; this.maxScale = 2; this.originX = 'center'; this.originY = 'top'; this.boundary = 60; this.loading = false; this.loadFailed = false; this.retry = new EventEmitter(); this.getCanvasRect = () => getRect(this.canvasRef.nativeElement); this.getSurfaceRect = () => getRect(this.surfaceRef.nativeElement); } ngOnInit() { this.transformState = { origin: [this.originX, this.originY], translate: [0, 0], scale: this.graphStore.getScale(), }; } ngAfterViewInit() { this.graphStore.registerSurfaceNode({ getRect: this.getSurfaceRect }); } ngOnDestroy() { this.graphStore.disconnectObserver(); } handleWheelEvent(e) { e.preventDefault(); e.stopPropagation(); const { deltaX, deltaY, ctrlKey, shiftKey, clientX, clientY } = e; if (ctrlKey) { this.zoomByWheel(-deltaY, [clientX, clientY]); } else if (shiftKey && !isMacSystem) { this.move(-deltaY, -deltaX); } else { this.move(-deltaX, -deltaY); } } handleMouseDown(e) { this.dragStartPoint = [e.clientX, e.clientY]; } handleMouseMove(e) { if (!this.dragStartPoint) { return; } this.move(e.clientX - this.dragStartPoint[0], e.clientY - this.dragStartPoint[1]); this.dragStartPoint = [e.clientX, e.clientY]; } handleMouseUp() { this.dragStartPoint = null; } zoomByWheel(v, pointerPosition) { this.dispatchTransform((transform, rects) => { const { scale, translate } = transform; const nextScale = scaleLimit(scale + v / 500); const origin = originCoordinatePoint(transform, rects); const pointer = coordinate(rects.canvasRect, pointerPosition); const deltaX = ((pointer[0] - origin[0]) / scale) * nextScale - (pointer[0] - origin[0]); const deltaY = ((pointer[1] - origin[1]) / scale) * nextScale - (pointer[1] - origin[1]); return { translate: [translate[0] - deltaX, translate[1] - deltaY], scale: nextScale, }; }); } zoomByDefaultStep(direction) { this.dispatchTransform(({ scale }) => ({ scale: scaleLimit(scale + (direction === 'in' ? 0.25 : -0.25)), })); } zoomOriginal() { this.dispatchTransform(() => ({ origin: [this.originX, this.originY], translate: [0, 0], scale: 1, })); } zoomOverview() { this.dispatchTransform((_, { canvasRect, surfaceRect }) => { const scaleX = (canvasRect.offsetWidth - this.boundary * 2) / surfaceRect.offsetWidth; const scaleY = (canvasRect.offsetHeight - this.boundary * 2) / surfaceRect.offsetHeight; return { origin: ['center', 'center'], translate: [0, 0], scale: scaleLimit(min([scaleX, scaleY, 1])), }; }); } move(x, y) { this.dispatchTransform(({ translate }) => ({ translate: [translate[0] + x, translate[1] + y], })); } dispatchTransform(action) { const rects = { canvasRect: this.getCanvasRect(), surfaceRect: this.getSurfaceRect(), }; const nextTransform = mergeRight(this.transformState, action(this.transformState, rects)); this.transformState = applyCanvasBoundaries({ rects, transform: nextTransform, boundary: this.boundary, }); this.graphStore.setScale(this.transformState.scale); } static { this.ɵfac = function GraphCanvasComponent_Factory(t) { return new (t || GraphCanvasComponent)(i0.ɵɵdirectiveInject(i1.GraphStoreService)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: GraphCanvasComponent, selectors: [["acl-graph-canvas"]], viewQuery: function GraphCanvasComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 7); i0.ɵɵviewQuery(_c1, 7); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.canvasRef = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.surfaceRef = _t.first); } }, hostBindings: function GraphCanvasComponent_HostBindings(rf, ctx) { if (rf & 1) { i0.ɵɵlistener("mousemove", function GraphCanvasComponent_mousemove_HostBindingHandler($event) { return ctx.handleMouseMove($event); }, false, i0.ɵɵresolveDocument)("mouseup", function GraphCanvasComponent_mouseup_HostBindingHandler($event) { return ctx.handleMouseUp($event); }, false, i0.ɵɵresolveDocument); } }, inputs: { minScale: "minScale", maxScale: "maxScale", originX: "originX", originY: "originY", boundary: "boundary", loading: "loading", loadFailed: "loadFailed" }, outputs: { retry: "retry" }, features: [i0.ɵɵProvidersFeature([GraphStoreService])], ngContentSelectors: _c3, decls: 22, vars: 20, consts: [["canvas", ""], ["surface", ""], [1, "acl-graph-canvas", 3, "wheel", "mousedown", "ngStyle"], [1, "acl-graph-canvas__surface", 3, "ngStyle"], [1, "acl-graph-canvas__action-wrapper", "right", "bottom"], [1, "acl-graph-canvas__action", "square", 3, "click", "mousedown", "title"], ["icon", "full_size"], [1, "acl-graph-canvas__scale-controller"], ["icon", "minus", 3, "click", "mousedown", "title"], ["icon", "plus", 3, "click", "mousedown", "title"], ["icon", "actual_size"], ["class", "acl-graph-canvas__loading-mask", 3, "wheel", "mousedown", 4, "ngIf"], [1, "acl-graph-canvas__loading-mask", 3, "wheel", "mousedown"], [1, "acl-graph-canvas__loading"], [4, "ngIf"], ["icon", "spinner"], ["aui-button", "text", 3, "click"]], template: function GraphCanvasComponent_Template(rf, ctx) { if (rf & 1) { const _r1 = i0.ɵɵgetCurrentView(); i0.ɵɵprojectionDef(_c2); i0.ɵɵelementStart(0, "div", 2, 0); i0.ɵɵlistener("wheel", function GraphCanvasComponent_Template_div_wheel_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.handleWheelEvent($event)); })("mousedown", function GraphCanvasComponent_Template_div_mousedown_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.handleMouseDown($event)); }); i0.ɵɵelementStart(2, "div", 3, 1); i0.ɵɵprojection(4); i0.ɵɵprojection(5, 1); i0.ɵɵelementEnd(); i0.ɵɵelementStart(6, "div", 4)(7, "div", 5); i0.ɵɵpipe(8, "translate"); i0.ɵɵlistener("click", function GraphCanvasComponent_Template_div_click_7_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.zoomOverview()); })("mousedown", function GraphCanvasComponent_Template_div_mousedown_7_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView($event.stopPropagation()); }); i0.ɵɵelement(9, "aui-icon", 6); i0.ɵɵelementEnd(); i0.ɵɵelementStart(10, "div", 7)(11, "aui-icon", 8); i0.ɵɵpipe(12, "translate"); i0.ɵɵlistener("click", function GraphCanvasComponent_Template_aui_icon_click_11_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.zoomByDefaultStep("out")); })("mousedown", function GraphCanvasComponent_Template_aui_icon_mousedown_11_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView($event.stopPropagation()); }); i0.ɵɵelementEnd(); i0.ɵɵelementStart(13, "span"); i0.ɵɵtext(14); i0.ɵɵelementEnd(); i0.ɵɵelementStart(15, "aui-icon", 9); i0.ɵɵpipe(16, "translate"); i0.ɵɵlistener("click", function GraphCanvasComponent_Template_aui_icon_click_15_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.zoomByDefaultStep("in")); })("mousedown", function GraphCanvasComponent_Template_aui_icon_mousedown_15_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView($event.stopPropagation()); }); i0.ɵɵelementEnd()(); i0.ɵɵelementStart(17, "div", 5); i0.ɵɵpipe(18, "translate"); i0.ɵɵlistener("click", function GraphCanvasComponent_Template_div_click_17_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.zoomOriginal()); })("mousedown", function GraphCanvasComponent_Template_div_mousedown_17_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView($event.stopPropagation()); }); i0.ɵɵelement(19, "aui-icon", 10); i0.ɵɵelementEnd()(); i0.ɵɵprojection(20, 2); i0.ɵɵtemplate(21, GraphCanvasComponent_div_21_Template, 4, 2, "div", 11); i0.ɵɵelementEnd(); } if (rf & 2) { i0.ɵɵproperty("ngStyle", ctx.canvasStyle); i0.ɵɵadvance(2); i0.ɵɵproperty("ngStyle", ctx.surfaceStyle); i0.ɵɵadvance(5); i0.ɵɵproperty("title", i0.ɵɵpipeBind1(8, 12, "panoramic_view")); i0.ɵɵadvance(4); i0.ɵɵclassProp("disabled", ctx.transformState.scale <= ctx.minScale); i0.ɵɵproperty("title", i0.ɵɵpipeBind1(12, 14, "zoom_out")); i0.ɵɵadvance(3); i0.ɵɵtextInterpolate1("", (ctx.transformState.scale * 100).toFixed(0), "%"); i0.ɵɵadvance(); i0.ɵɵclassProp("disabled", ctx.transformState.scale >= ctx.maxScale); i0.ɵɵproperty("title", i0.ɵɵpipeBind1(16, 16, "zoom_in")); i0.ɵɵadvance(2); i0.ɵɵproperty("title", i0.ɵɵpipeBind1(18, 18, "isometric_view")); i0.ɵɵadvance(4); i0.ɵɵproperty("ngIf", ctx.loading || ctx.loadFailed); } }, dependencies: [i2.NgIf, i2.NgStyle, i3.IconComponent, i3.ButtonComponent, i4.TranslatePipe], styles: [".acl-graph-canvas{display:flex;width:100%;height:100%;border-radius:var(--aui-border-radius-l);background-color:rgb(var(--aui-color-n-9));background-image:radial-gradient(rgba(var(--aui-color-n-7),.5) 1px,transparent 1px);background-size:10px 10px;background-position:center center;position:relative;overflow:hidden}.acl-graph-canvas:after{content:\"\";display:block;position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;overflow:hidden;pointer-events:none}:root .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__surface{position:relative}.acl-graph-canvas__links{position:absolute;top:0;left:0;width:1000px;height:1000px;overflow:visible;color:rgb(var(--aui-color-primary));pointer-events:none}.acl-graph-canvas__links .acl-graph-link__line{fill:none;stroke:currentcolor;stroke-width:2px}.acl-graph-canvas__links .acl-graph-link__dot,.acl-graph-canvas__links .acl-graph-link__arrow{fill:currentcolor}.acl-graph-canvas__loading{padding:8px 16px;border-radius:var(--aui-border-radius-m);font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text))}:root .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.05)}html[aui-theme-mode=light] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.05)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.1)}}html[aui-theme-mode=dark] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.1)}.acl-graph-canvas__loading aui-icon{margin-right:8px;color:rgb(var(--aui-color-primary));font-size:var(--aui-icon-size-m)}.acl-graph-canvas__loading-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;cursor:default}.acl-graph-canvas__action-wrapper{position:absolute;display:flex}.acl-graph-canvas__action-wrapper.top{top:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.right{right:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.left{left:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.bottom{bottom:var(--aui-spacing-m)}.acl-graph-canvas acl-graph-actions .acl-graph-canvas__action-wrapper.bottom.right{right:168px}.acl-graph-canvas__action{padding:0 6px;height:24px;display:flex;align-items:center;justify-content:center;background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-m);cursor:pointer;user-select:none;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text))}:root .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__action.square{width:24px}.acl-graph-canvas__action:hover,.acl-graph-canvas__action.active{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.acl-graph-canvas__action.disabled{color:rgb(var(--aui-color-disabled-text));background-color:rgb(var(--aui-color-n-10))}.acl-graph-canvas__action+.acl-graph-canvas__action{margin-left:4px}.acl-graph-canvas__scale-controller{display:flex;align-items:center;justify-content:center;margin:0 4px;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text));background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-m);user-select:none}:root .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__scale-controller aui-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;cursor:pointer}.acl-graph-canvas__scale-controller aui-icon:hover{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.acl-graph-canvas__scale-controller aui-icon.disabled{color:rgb(var(--aui-color-disabled-text));background-color:rgb(var(--aui-color-n-10));cursor:not-allowed}.acl-graph-canvas__scale-controller span{text-align:center;height:16px;width:50px;border-left:1px solid rgb(var(--aui-color-n-8));border-right:1px solid rgb(var(--aui-color-n-8))}\n"], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(GraphCanvasComponent, [{ type: Component, args: [{ selector: 'acl-graph-canvas', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [GraphStoreService], template: "<div\n #canvas\n class=\"acl-graph-canvas\"\n [ngStyle]=\"canvasStyle\"\n (wheel)=\"handleWheelEvent($event)\"\n (mousedown)=\"handleMouseDown($event)\"\n>\n <div\n #surface\n class=\"acl-graph-canvas__surface\"\n [ngStyle]=\"surfaceStyle\"\n >\n <ng-content></ng-content>\n <ng-content select=\"acl-graph-links\"></ng-content>\n </div>\n\n <div class=\"acl-graph-canvas__action-wrapper right bottom\">\n <div\n class=\"acl-graph-canvas__action square\"\n [title]=\"'panoramic_view' | translate\"\n (click)=\"zoomOverview()\"\n (mousedown)=\"$event.stopPropagation()\"\n >\n <aui-icon icon=\"full_size\"></aui-icon>\n </div>\n <div class=\"acl-graph-canvas__scale-controller\">\n <aui-icon\n icon=\"minus\"\n [title]=\"'zoom_out' | translate\"\n [class.disabled]=\"transformState.scale <= minScale\"\n (click)=\"zoomByDefaultStep('out')\"\n (mousedown)=\"$event.stopPropagation()\"\n ></aui-icon>\n <span>{{ (transformState.scale * 100).toFixed(0) }}%</span>\n <aui-icon\n icon=\"plus\"\n [title]=\"'zoom_in' | translate\"\n [class.disabled]=\"transformState.scale >= maxScale\"\n (click)=\"zoomByDefaultStep('in')\"\n (mousedown)=\"$event.stopPropagation()\"\n ></aui-icon>\n </div>\n <div\n class=\"acl-graph-canvas__action square\"\n [title]=\"'isometric_view' | translate\"\n (click)=\"zoomOriginal()\"\n (mousedown)=\"$event.stopPropagation()\"\n >\n <aui-icon icon=\"actual_size\"></aui-icon>\n </div>\n </div>\n <ng-content select=\"acl-graph-actions\"></ng-content>\n <div\n *ngIf=\"loading || loadFailed\"\n class=\"acl-graph-canvas__loading-mask\"\n (wheel)=\"$event.stopPropagation()\"\n (mousedown)=\"$event.stopPropagation()\"\n >\n <div class=\"acl-graph-canvas__loading\">\n <ng-container *ngIf=\"loading\">\n <aui-icon icon=\"spinner\"></aui-icon>\n <span>{{ 'loading_please_wait' | translate }}</span>\n </ng-container>\n <ng-container *ngIf=\"loadFailed\">\n <span>{{ 'failed_load_please' | translate }}</span>\n <button\n aui-button=\"text\"\n (click)=\"retry.emit()\"\n >\n {{ 'retry' | translate }}\n </button>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: [".acl-graph-canvas{display:flex;width:100%;height:100%;border-radius:var(--aui-border-radius-l);background-color:rgb(var(--aui-color-n-9));background-image:radial-gradient(rgba(var(--aui-color-n-7),.5) 1px,transparent 1px);background-size:10px 10px;background-position:center center;position:relative;overflow:hidden}.acl-graph-canvas:after{content:\"\";display:block;position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;overflow:hidden;pointer-events:none}:root .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas:after{box-shadow:inset 0 0 4px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__surface{position:relative}.acl-graph-canvas__links{position:absolute;top:0;left:0;width:1000px;height:1000px;overflow:visible;color:rgb(var(--aui-color-primary));pointer-events:none}.acl-graph-canvas__links .acl-graph-link__line{fill:none;stroke:currentcolor;stroke-width:2px}.acl-graph-canvas__links .acl-graph-link__dot,.acl-graph-canvas__links .acl-graph-link__arrow{fill:currentcolor}.acl-graph-canvas__loading{padding:8px 16px;border-radius:var(--aui-border-radius-m);font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text))}:root .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.05)}html[aui-theme-mode=light] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.05)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.1)}}html[aui-theme-mode=dark] .acl-graph-canvas__loading{background-color:rgba(var(--aui-color-n-1),.1)}.acl-graph-canvas__loading aui-icon{margin-right:8px;color:rgb(var(--aui-color-primary));font-size:var(--aui-icon-size-m)}.acl-graph-canvas__loading-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;cursor:default}.acl-graph-canvas__action-wrapper{position:absolute;display:flex}.acl-graph-canvas__action-wrapper.top{top:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.right{right:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.left{left:var(--aui-spacing-m)}.acl-graph-canvas__action-wrapper.bottom{bottom:var(--aui-spacing-m)}.acl-graph-canvas acl-graph-actions .acl-graph-canvas__action-wrapper.bottom.right{right:168px}.acl-graph-canvas__action{padding:0 6px;height:24px;display:flex;align-items:center;justify-content:center;background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-m);cursor:pointer;user-select:none;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text))}:root .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas__action{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__action.square{width:24px}.acl-graph-canvas__action:hover,.acl-graph-canvas__action.active{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.acl-graph-canvas__action.disabled{color:rgb(var(--aui-color-disabled-text));background-color:rgb(var(--aui-color-n-10))}.acl-graph-canvas__action+.acl-graph-canvas__action{margin-left:4px}.acl-graph-canvas__scale-controller{display:flex;align-items:center;justify-content:center;margin:0 4px;font-size:var(--aui-font-size-s);line-height:var(--aui-line-height-s);font-weight:var(--aui-font-weight-normal);color:rgb(var(--aui-color-secondary-text));background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-m);user-select:none}:root .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-graph-canvas__scale-controller{box-shadow:0 2px 8px rgba(var(--aui-color-origin-shadow),.75)}.acl-graph-canvas__scale-controller aui-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;cursor:pointer}.acl-graph-canvas__scale-controller aui-icon:hover{color:rgb(var(--aui-color-primary));background-color:rgb(var(--aui-color-p-6))}.acl-graph-canvas__scale-controller aui-icon.disabled{color:rgb(var(--aui-color-disabled-text));background-color:rgb(var(--aui-color-n-10));cursor:not-allowed}.acl-graph-canvas__scale-controller span{text-align:center;height:16px;width:50px;border-left:1px solid rgb(var(--aui-color-n-8));border-right:1px solid rgb(var(--aui-color-n-8))}\n"] }] }], () => [{ type: i1.GraphStoreService }], { minScale: [{ type: Input }], maxScale: [{ type: Input }], originX: [{ type: Input }], originY: [{ type: Input }], boundary: [{ type: Input }], loading: [{ type: Input }], loadFailed: [{ type: Input }], retry: [{ type: Output }], canvasRef: [{ type: ViewChild, args: ['canvas', { static: true }] }], surfaceRef: [{ type: ViewChild, args: ['surface', { static: true }] }], handleMouseMove: [{ type: HostListener, args: ['document:mousemove', ['$event']] }], handleMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event']] }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(GraphCanvasComponent, { className: "GraphCanvasComponent" }); })(); function scaleLimit(scale) { return clamp(round(scale, 2), 0.25, 2); } function applyCanvasBoundaries({ transform, rects, boundary, }) { const { origin: [originX, originY], scale, translate, } = transform; const { surfaceRect: { offsetWidth: surfaceWidth, offsetHeight: surfaceHeight }, canvasRect: { offsetWidth: canvasWidth, offsetHeight: canvasHeight }, } = rects; const x = xSelector(originX, [ boundary, canvasWidth / 2, canvasWidth - boundary, ]); const x1 = x + xSelector(originX, [surfaceWidth * scale, (surfaceWidth * scale) / 2, 0]); const x2 = canvasWidth - (x - xSelector(originX, [ 0, (surfaceWidth * scale) / 2, surfaceWidth * scale, ])); const y = ySelector(originY, [ boundary, canvasHeight / 2, canvasHeight - boundary, ]); const y1 = y + ySelector(originY, [surfaceHeight * scale, (surfaceHeight * scale) / 2, 0]); const y2 = canvasHeight - (y - ySelector(originY, [ 0, (surfaceHeight * scale) / 2, surfaceHeight * scale, ])); return mergeRight(transform, { translate: [ clamp(translate[0], boundary - x1, x2 - boundary), clamp(translate[1], boundary - y1, y2 - boundary), ], }); } function originCoordinatePoint({ origin: [originX, originY] }, { surfaceRect, canvasRect }) { const [left, top] = coordinate(canvasRect, [ surfaceRect.left, surfaceRect.top, ]); const x = xSelector(originX, [ left, left + surfaceRect.width / 2, left + surfaceRect.width, ]); const y = ySelector(originY, [ top, top + surfaceRect.height / 2, top + surfaceRect.height, ]); return [x, y]; } function xSelector(x, [l, c, r]) { return x === 'left' ? l : x === 'center' ? c : r; } function ySelector(y, [t, c, b]) { return y === 'top' ? t : y === 'center' ? c : b; } function coordinate(canvas, [left, top]) { return [left - canvas.left, top - canvas.top]; } //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGgtY2FudmFzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9ncmFwaC1jYW52YXMvY29tcG9uZW50cy9ncmFwaC1jYW52YXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2dyYXBoLWNhbnZhcy9jb21wb25lbnRzL2dyYXBoLWNhbnZhcy50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osWUFBWSxFQUNaLEtBQUssRUFHTCxNQUFNLEVBQ04sU0FBUyxFQUNULGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDOUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUVuQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFTM0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFVBQVUsQ0FBQzs7Ozs7Ozs7Ozs7SUNnQzdCLDZCQUE4QjtJQUM1QiwrQkFBb0M7SUFDcEMsNEJBQU07SUFBQSxZQUF1Qzs7SUFBQSxpQkFBTzs7O0lBQTlDLGVBQXVDO0lBQXZDLGlFQUF1Qzs7OztJQUUvQyw2QkFBaUM7SUFDL0IsNEJBQU07SUFBQSxZQUFzQzs7SUFBQSxpQkFBTztJQUNuRCxrQ0FHQztJQURDLGlNQUFTLG1CQUFZLEtBQUM7SUFFdEIsWUFDRjs7SUFBQSxpQkFBUzs7O0lBTkgsZUFBc0M7SUFBdEMsZ0VBQXNDO0lBSzFDLGVBQ0Y7SUFERSw4REFDRjs7OztJQWxCTiwrQkFLQztJQURDLEFBREEsaUpBQVMsd0JBQXdCLEtBQUMsNElBQ3JCLHdCQUF3QixLQUFDO0lBRXRDLCtCQUF1QztJQUtyQyxBQUpBLCtGQUE4QixrRkFJRztJQVVyQyxBQURFLGlCQUFNLEVBQ0Y7OztJQWRhLGVBQWE7SUFBYixxQ0FBYTtJQUliLGNBQWdCO0lBQWhCLHdDQUFnQjs7QURsQ3JDLE1BQU0sV0FBVyxHQUFHLEtBQUssRUFBRSxDQUFDO0FBVTVCLE1BQU0sT0FBTyxvQkFBb0I7SUF3Qy9CLElBQUksUUFBUTtRQUNWLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU87WUFDTCxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJO1lBQzdCLGNBQWMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ3ZELFlBQVk7Z0JBQ1osUUFBUTtnQkFDUixVQUFVO2FBQ1gsQ0FBQztZQUNGLFVBQVUsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ25ELFlBQVk7Z0JBQ1osUUFBUTtnQkFDUixVQUFVO2FBQ1gsQ0FBQztZQUNGLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLE1BQU07U0FDNUMsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxPQUFPO1lBQ0wsZUFBZSxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDckQsU0FBUyxFQUFFLGFBQWEsSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLGNBQWMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEdBQUc7U0FDMUksQ0FBQztJQUNKLENBQUM7SUFFRCxZQUE2QixVQUE2QjtRQUE3QixlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQWxFMUQsYUFBUSxHQUFHLElBQUksQ0FBQztRQUdoQixhQUFRLEdBQUcsQ0FBQyxDQUFDO1FBR2IsWUFBTyxHQUFZLFFBQVEsQ0FBQztRQUc1QixZQUFPLEdBQVksS0FBSyxDQUFDO1FBR3pCLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFHZCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBR2hCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFHbkIsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFReEIsa0JBQWEsR0FBRyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUVwRCxtQkFBYyxHQUFHLEdBQUcsRUFBRSxDQUNyQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQWtDb0IsQ0FBQztJQUU5RCxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsR0FBRztZQUNwQixNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDcEMsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNqQixLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUU7U0FDbEMsQ0FBQztJQUNKLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUN2QyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsQ0FBYTtRQUM1QixDQUFDLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3BCLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQztRQUNsRSxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ2hELENBQUM7YUFBTSxJQUFJLFFBQVEsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM5QixDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM5QixDQUFDO0lBQ0gsQ0FBQztJQUVELGVBQWUsQ0FBQyxDQUFhO1FBQzNCLElBQUksQ0FBQyxjQUFjLEdBQUcsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBR0QsZUFBZSxDQUFDLENBQWE7UUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN6QixPQUFPO1FBQ1QsQ0FBQztRQUNELElBQUksQ0FBQyxJQUFJLENBQ1AsQ0FBQyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxFQUNsQyxDQUFDLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQ25DLENBQUM7UUFDRixJQUFJLENBQUMsY0FBYyxHQUFHLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUdELGFBQWE7UUFDWCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQztJQUM3QixDQUFDO0lBRUQsV0FBVyxDQUFDLENBQVMsRUFBRSxlQUFpQztRQUN0RCxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxTQUFTLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDMUMsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxTQUFTLENBQUM7WUFDdkMsTUFBTSxTQUFTLEdBQUcsVUFBVSxDQUFDLEtBQUssR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUM7WUFDOUMsTUFBTSxNQUFNLEdBQUcscUJBQXFCLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3ZELE1BQU0sT0FBTyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBRTlELE1BQU0sTUFBTSxHQUNWLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLEdBQUcsU0FBUztnQkFDOUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDM0IsTUFBTSxNQUFNLEdBQ1YsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsR0FBRyxTQUFTO2dCQUM5QyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUUzQixPQUFPO2dCQUNMLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQztnQkFDekQsS0FBSyxFQUFFLFNBQVM7YUFDakIsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLFNBQXVCO1FBQ3ZDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDckMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxTQUFTLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDL0QsQ0FBQyxDQUFDLENBQUM7SUFDTixDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQzVCLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUNwQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ2pCLEtBQUssRUFBRSxDQUFDO1NBQ1QsQ0FBQyxDQUFDLENBQUM7SUFDTixDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsRUFBRSxFQUFFO1lBQ3hELE1BQU0sTUFBTSxHQUNWLENBQUMsVUFBVSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUM7WUFDekUsTUFBTSxNQUFNLEdBQ1YsQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO2dCQUM3QyxXQUFXLENBQUMsWUFBWSxDQUFDO1lBRTNCLE9BQU87Z0JBQ0wsTUFBTSxFQUFFLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQztnQkFDNUIsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDakIsS0FBSyxFQUFFLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDNUMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksQ0FBQyxDQUFTLEVBQUUsQ0FBUztRQUN2QixJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3pDLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNoRCxDQUFDLENBQUMsQ0FBQztJQUNOLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUF1QjtRQUN2QyxNQUFNLEtBQUssR0FBRztZQUNaLFVBQVUsRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ2hDLFdBQVcsRUFBRSxJQUFJLENBQUMsY0FBYyxFQUFFO1NBQ25DLENBQUM7UUFFRixNQUFNLGFBQWEsR0FBRyxVQUFVLENBQzlCLElBQUksQ0FBQyxjQUFjLEVBQ25CLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLEtBQUssQ0FBQyxDQUNqQixDQUFDO1FBRXBCLElBQUksQ0FBQyxjQUFjLEdBQUcscUJBQXFCLENBQUM7WUFDMUMsS0FBSztZQUNMLFNBQVMsRUFBRSxhQUFhO1lBQ3hCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtTQUN4QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RELENBQUM7cUZBbk1VLG9CQUFvQjtvRUFBcEIsb0JBQW9COzs7Ozs7OztZQUFwQix1R0FBQSwyQkFBdUIsaUNBQUgsc0ZBQXBCLHlCQUFxQixpQ0FBRDsrT0FGcEIsQ0FBQyxpQkFBaUIsQ0FBQzs7O1lDckNoQyxpQ0FNQztZQURDLEFBREEsMElBQVMsNEJBQXdCLEtBQUMscUlBQ3JCLDJCQUF1QixLQUFDO1lBRXJDLGlDQUlDO1lBQ0Msa0JBQXlCO1lBQ3pCLHFCQUFrRDtZQUNwRCxpQkFBTTtZQUdKLEFBREYsOEJBQTJELGFBTXhEOztZQURDLEFBREEsb0lBQVMsa0JBQWMsS0FBQyxxSUFDWCx3QkFBd0IsS0FBQztZQUV0Qyw4QkFBc0M7WUFDeEMsaUJBQU07WUFFSixBQURGLCtCQUFnRCxtQkFPN0M7O1lBREMsQUFEQSwwSUFBUyxzQkFBa0IsS0FBSyxDQUFDLEtBQUMsMklBQ3JCLHdCQUF3QixLQUFDO1lBQ3ZDLGlCQUFXO1lBQ1osNkJBQU07WUFBQSxhQUE4QztZQUFBLGlCQUFPO1lBQzNELG9DQU1DOztZQURDLEFBREEsMElBQVMsc0JBQWtCLElBQUksQ0FBQyxLQUFDLDJJQUNwQix3QkFBd0IsS0FBQztZQUUxQyxBQURHLGlCQUFXLEVBQ1I7WUFDTiwrQkFLQzs7WUFEQyxBQURBLHFJQUFTLGtCQUFjLEtBQUMsc0lBQ1gsd0JBQXdCLEtBQUM7WUFFdEMsZ0NBQXdDO1lBRTVDLEFBREUsaUJBQU0sRUFDRjtZQUNOLHNCQUFvRDtZQUNwRCx3RUFLQztZQWlCSCxpQkFBTTs7WUF2RUoseUNBQXVCO1lBT3JCLGVBQXdCO1lBQXhCLDBDQUF3QjtZQVN0QixlQUFzQztZQUF0QywrREFBc0M7WUFVcEMsZUFBbUQ7WUFBbkQsb0VBQW1EO1lBRG5ELDBEQUFnQztZQUs1QixlQUE4QztZQUE5QywyRUFBOEM7WUFJbEQsY0FBbUQ7WUFBbkQsb0VBQW1EO1lBRG5ELHlEQUErQjtZQVFqQyxlQUFzQztZQUF0QyxnRUFBc0M7WUFTdkMsZUFBMkI7WUFBM0Isb0RBQTJCOzs7aUZEZG5CLG9CQUFvQjtjQVJoQyxTQUFTOzJCQUNFLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLGFBQzFCLENBQUMsaUJBQWlCLENBQUM7a0RBSTlCLFFBQVE7a0JBRFAsS0FBSztZQUlOLFFBQVE7a0JBRFAsS0FBSztZQUlOLE9BQU87a0JBRE4sS0FBSztZQUlOLE9BQU87a0JBRE4sS0FBSztZQUlOLFFBQVE7a0JBRFAsS0FBSztZQUlOLE9BQU87a0JBRE4sS0FBSztZQUlOLFVBQVU7a0JBRFQsS0FBSztZQUlOLEtBQUs7a0JBREosTUFBTTtZQUlVLFNBQVM7a0JBRHpCLFNBQVM7bUJBQUMsUUFBUSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtZQUlwQixVQUFVO2tCQUQxQixTQUFTO21CQUFDLFNBQVMsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7WUE0RXRDLGVBQWU7a0JBRGQsWUFBWTttQkFBQyxvQkFBb0IsRUFBRSxDQUFDLFFBQVEsQ0FBQztZQWE5QyxhQUFhO2tCQURaLFlBQVk7bUJBQUMsa0JBQWtCLEVBQUUsQ0FBQyxRQUFRLENBQUM7O2tGQW5IakMsb0JBQW9CO0FBc01qQyxTQUFTLFVBQVUsQ0FBQyxLQUFhO0lBQy9CLE9BQU8sS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ3pDLENBQUM7QUFFRCxTQUFTLHFCQUFxQixDQUFDLEVBQzdCLFNBQVMsRUFDVCxLQUFLLEVBQ0wsUUFBUSxHQUtUO0lBQ0MsTUFBTSxFQUNKLE1BQU0sRUFBRSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsRUFDMUIsS0FBSyxFQUNMLFNBQVMsR0FDVixHQUFHLFNBQVMsQ0FBQztJQUNkLE1BQU0sRUFDSixXQUFXLEVBQUUsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsRUFDdkUsVUFBVSxFQUFFLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLEdBQ3JFLEdBQUcsS0FBSyxDQUFDO0lBRVYsTUFBTSxDQUFDLEdBQUcsU0FBUyxDQUFDLE9BQU8sRUFBRTtRQUMzQixRQUFRO1FBQ1IsV0FBVyxHQUFHLENBQUM7UUFDZixXQUFXLEdBQUcsUUFBUTtLQUN2QixDQUFDLENBQUM7SUFDSCxNQUFNLEVBQUUsR0FDTixDQUFDO1FBQ0QsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLFlBQVksR0FBRyxLQUFLLEVBQUUsQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUUsTUFBTSxFQUFFLEdBQ04sV0FBVztRQUNYLENBQUMsQ0FBQztZQUNBLFNBQVMsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2pCLENBQUM7Z0JBQ0QsQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQztnQkFDMUIsWUFBWSxHQUFHLEtBQUs7YUFDckIsQ0FBQyxDQUFDLENBQUM7SUFFUixNQUFNLENBQUMsR0FBRyxTQUFTLENBQUMsT0FBTyxFQUFFO1FBQzNCLFFBQVE7UUFDUixZQUFZLEdBQUcsQ0FBQztRQUNoQixZQUFZLEdBQUcsUUFBUTtLQUN4QixDQUFDLENBQUM7SUFDSCxNQUFNLEVBQUUsR0FDTixDQUFDO1FBQ0QsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLGFBQWEsR0FBRyxLQUFLLEVBQUUsQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUUsTUFBTSxFQUFFLEdBQ04sWUFBWTtRQUNaLENBQUMsQ0FBQztZQUNBLFNBQVMsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2pCLENBQUM7Z0JBQ0QsQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQztnQkFDM0IsYUFBYSxHQUFHLEtBQUs7YUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFFUixPQUFPLFVBQVUsQ0FBQyxTQUFTLEVBQUU7UUFDM0IsU0FBUyxFQUFFO1lBQ1QsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxRQUFRLENBQUM7WUFDakQsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxRQUFRLENBQUM7U0FDekM7S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxxQkFBcUIsQ0FDNUIsRUFBRSxNQUFNLEVBQUUsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLEVBQWtCLEVBQzlDLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBUztJQUVsQyxNQUFNLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxVQUFVLEVBQUU7UUFDekMsV0FBVyxDQUFDLElBQUk7UUFDaEIsV0FBVyxDQUFDLEdBQUc7S0FDaEIsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxDQUFDLEdBQUcsU0FBUyxDQUFDLE9BQU8sRUFBRTtRQUMzQixJQUFJO1FBQ0osSUFBSSxHQUFHLFdBQVcsQ0FBQyxLQUFLLEdBQUcsQ0FBQztRQUM1QixJQUFJLEdBQUcsV0FBVyxDQUFDLEtBQUs7S0FDekIsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxDQUFDLEdBQUcsU0FBUyxDQUFDLE9BQU8sRUFBRTtRQUMzQixHQUFHO1FBQ0gsR0FBRyxHQUFHLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQztRQUM1QixHQUFHLEdBQUcsV0FBVyxDQUFDLE1BQU07S0FDekIsQ0FBQyxDQUFDO0lBRUgsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNoQixDQUFDO0FBRUQsU0FBUyxTQUFTLENBQVUsQ0FBVSxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQVk7SUFDMUQsT0FBTyxDQUFDLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ25ELENBQUM7QUFFRCxTQUFTLFNBQVMsQ0FBVSxDQUFVLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBWTtJQUMxRCxPQUFPLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbEQsQ0FBQztBQUVELFNBQVMsVUFBVSxDQUFDLE1BQVksRUFBRSxDQUFDLElBQUksRUFBRSxHQUFHLENBQW1CO0lBQzdELE9BQU8sQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksRUFBRSxHQUFHLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ2hELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIEhvc3RMaXN0ZW5lcixcbiAgSW5wdXQsXG4gIE9uRGVzdHJveSxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFZpZXdDaGlsZCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgY2xhbXAsIG1pbiwgcm91bmQgfSBmcm9tICdsb2Rhc2gtZXMnO1xuaW1wb3J0IHsgbWVyZ2VSaWdodCB9IGZyb20gJ3JhbWRhJztcblxuaW1wb3J0IHsgaXNNYWMgfSBmcm9tICcuLi8uLi9jb3JlL3V0aWxzL2Jyb3dzZXInO1xuaW1wb3J0IHsgR3JhcGhTdG9yZVNlcnZpY2UgfSBmcm9tICcuLi9ncmFwaC1zdG9yZS5zZXJ2aWNlJztcbmltcG9ydCB7XG4gIE9yaWdpblgsXG4gIE9yaWdpblksXG4gIFJlY3QsXG4gIFJlY3RzLFxuICBUcmFuc2Zvcm1BY3Rpb24sXG4gIFRyYW5zZm9ybVN0YXRlLFxufSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBnZXRSZWN0IH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5jb25zdCBpc01hY1N5c3RlbSA9IGlzTWFjKCk7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FjbC1ncmFwaC1jYW52YXMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZ3JhcGgtY2FudmFzLnRlbXBsYXRlLmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ncmFwaC1jYW52YXMuc3R5bGUuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJvdmlkZXJzOiBbR3JhcGhTdG9yZVNlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBHcmFwaENhbnZhc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KClcbiAgbWluU2NhbGUgPSAwLjI1O1xuXG4gIEBJbnB1dCgpXG4gIG1heFNjYWxlID0gMjtcblxuICBASW5wdXQoKVxuICBvcmlnaW5YOiBPcmlnaW5YID0gJ2NlbnRlcic7XG5cbiAgQElucHV0KClcbiAgb3JpZ2luWTogT3JpZ2luWSA9ICd0b3AnO1xuXG4gIEBJbnB1dCgpXG4gIGJvdW5kYXJ5ID0gNjA7XG5cbiAgQElucHV0KClcbiAgbG9hZGluZyA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIGxvYWRGYWlsZWQgPSBmYWxzZTtcblxuICBAT3V0cHV0KClcbiAgcmV0cnkgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgQFZpZXdDaGlsZCgnY2FudmFzJywgeyBzdGF0aWM6IHRydWUgfSlcbiAgcHJpdmF0ZSByZWFkb25seSBjYW52YXNSZWY6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuXG4gIEBWaWV3Q2hpbGQoJ3N1cmZhY2UnLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICBwcml2YXRlIHJlYWRvbmx5IHN1cmZhY2VSZWY6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuXG4gIHJlYWRvbmx5IGdldENhbnZhc1JlY3QgPSAoKSA9PiBnZXRSZWN0KHRoaXMuY2FudmFzUmVmLm5hdGl2ZUVsZW1lbnQpO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgZ2V0U3VyZmFjZVJlY3QgPSAoKSA9PlxuICAgIGdldFJlY3QodGhpcy5zdXJmYWNlUmVmLm5hdGl2ZUVsZW1lbnQpO1xuXG4gIHByaXZhdGUgZHJhZ1N0YXJ0UG9pbnQ6IFtudW1iZXIsIG51bWJlcl07XG5cbiAgdHJhbnNmb3JtU3RhdGU6IFRyYW5zZm9ybVN0YXRlO1xuXG4gIGdldCBkcmFnZ2luZygpIHtcbiAgICByZXR1cm4gISF0aGlzLmRyYWdTdGFydFBvaW50O1xuICB9XG5cbiAgZ2V0IGNhbnZhc1N0eWxlKCkge1xuICAgIHJldHVybiB7XG4gICAgICBwYWRkaW5nOiB0aGlzLmJvdW5kYXJ5ICsgJ3B4JyxcbiAgICAgIGp1c3RpZnlDb250ZW50OiB4U2VsZWN0b3IodGhpcy50cmFuc2Zvcm1TdGF0ZS5vcmlnaW5bMF0sIFtcbiAgICAgICAgJ2ZsZXgtc3RhcnQnLFxuICAgICAgICAnY2VudGVyJyxcbiAgICAgICAgJ2ZsZXgtZW5kJyxcbiAgICAgIF0pLFxuICAgICAgYWxpZ25JdGVtczogeVNlbGVjdG9yKHRoaXMudHJhbnNmb3JtU3RhdGUub3JpZ2luWzFdLCBbXG4gICAgICAgICdmbGV4LXN0YXJ0JyxcbiAgICAgICAgJ2NlbnRlcicsXG4gICAgICAgICdmbGV4LWVuZCcsXG4gICAgICBdKSxcbiAgICAgIGN1cnNvcjogdGhpcy5kcmFnZ2luZyA/ICdncmFiYmluZycgOiAnZ3JhYicsXG4gICAgfTtcbiAgfVxuXG4gIGdldCBzdXJmYWNlU3R5bGUoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRyYW5zZm9ybU9yaWdpbjogdGhpcy50cmFuc2Zvcm1TdGF0ZS5vcmlnaW4uam9pbignICcpLFxuICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7dGhpcy50cmFuc2Zvcm1TdGF0ZS50cmFuc2xhdGVbMF19cHgsICR7dGhpcy50cmFuc2Zvcm1TdGF0ZS50cmFuc2xhdGVbMV19cHgpICBzY2FsZSgke3RoaXMudHJhbnNmb3JtU3RhdGUuc2NhbGV9KWAsXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgZ3JhcGhTdG9yZTogR3JhcGhTdG9yZVNlcnZpY2UpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy50cmFuc2Zvcm1TdGF0ZSA9IHtcbiAgICAgIG9yaWdpbjogW3RoaXMub3JpZ2luWCwgdGhpcy5vcmlnaW5ZXSxcbiAgICAgIHRyYW5zbGF0ZTogWzAsIDBdLFxuICAgICAgc2NhbGU6IHRoaXMuZ3JhcGhTdG9yZS5nZXRTY2FsZSgpLFxuICAgIH07XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5ncmFwaFN0b3JlLnJlZ2lzdGVyU3VyZmFjZU5vZGUoeyBnZXRSZWN0OiB0aGlzLmdldFN1cmZhY2VSZWN0IH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5ncmFwaFN0b3JlLmRpc2Nvbm5lY3RPYnNlcnZlcigpO1xuICB9XG5cbiAgaGFuZGxlV2hlZWxFdmVudChlOiBXaGVlbEV2ZW50KSB7XG4gICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgY29uc3QgeyBkZWx0YVgsIGRlbHRhWSwgY3RybEtleSwgc2hpZnRLZXksIGNsaWVudFgsIGNsaWVudFkgfSA9IGU7XG4gICAgaWYgKGN0cmxLZXkpIHtcbiAgICAgIHRoaXMuem9vbUJ5V2hlZWwoLWRlbHRhWSwgW2NsaWVudFgsIGNsaWVudFldKTtcbiAgICB9IGVsc2UgaWYgKHNoaWZ0S2V5ICYmICFpc01hY1N5c3RlbSkge1xuICAgICAgdGhpcy5tb3ZlKC1kZWx0YVksIC1kZWx0YVgpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1vdmUoLWRlbHRhWCwgLWRlbHRhWSk7XG4gICAgfVxuICB9XG5cbiAgaGFuZGxlTW91c2VEb3duKGU6IE1vdXNlRXZlbnQpIHtcbiAgICB0aGlzLmRyYWdTdGFydFBvaW50ID0gW2UuY2xpZW50WCwgZS5jbGllbnRZXTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50Om1vdXNlbW92ZScsIFsnJGV2ZW50J10pXG4gIGhhbmRsZU1vdXNlTW92ZShlOiBNb3VzZUV2ZW50KSB7XG4gICAgaWYgKCF0aGlzLmRyYWdTdGFydFBvaW50KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMubW92ZShcbiAgICAgIGUuY2xpZW50WCAtIHRoaXMuZHJhZ1N0YXJ0UG9pbnRbMF0sXG4gICAgICBlLmNsaWVudFkgLSB0aGlzLmRyYWdTdGFydFBvaW50WzFdLFxuICAgICk7XG4gICAgdGhpcy5kcmFnU3RhcnRQb2ludCA9IFtlLmNsaWVudFgsIGUuY2xpZW50WV07XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDptb3VzZXVwJywgWyckZXZlbnQnXSlcbiAgaGFuZGxlTW91c2VVcCgpIHtcbiAgICB0aGlzLmRyYWdTdGFydFBvaW50ID0gbnVsbDtcbiAgfVxuXG4gIHpvb21CeVdoZWVsKHY6IG51bWJlciwgcG9pbnRlclBvc2l0aW9uOiBbbnVtYmVyLCBudW1iZXJdKSB7XG4gICAgdGhpcy5kaXNwYXRjaFRyYW5zZm9ybSgodHJhbnNmb3JtLCByZWN0cykgPT4ge1xuICAgICAgY29uc3QgeyBzY2FsZSwgdHJhbnNsYXRlIH0gPSB0cmFuc2Zvcm07XG4gICAgICBjb25zdCBuZXh0U2NhbGUgPSBzY2FsZUxpbWl0KHNjYWxlICsgdiAvIDUwMCk7XG4gICAgICBjb25zdCBvcmlnaW4gPSBvcmlnaW5Db29yZGluYXRlUG9pbnQodHJhbnNmb3JtLCByZWN0cyk7XG4gICAgICBjb25zdCBwb2ludGVyID0gY29vcmRpbmF0ZShyZWN0cy5jYW52YXNSZWN0LCBwb2ludGVyUG9zaXRpb24pO1xuXG4gICAgICBjb25zdCBkZWx0YVggPVxuICAgICAgICAoKHBvaW50ZXJbMF0gLSBvcmlnaW5bMF0pIC8gc2NhbGUpICogbmV4dFNjYWxlIC1cbiAgICAgICAgKHBvaW50ZXJbMF0gLSBvcmlnaW5bMF0pO1xuICAgICAgY29uc3QgZGVsdGFZID1cbiAgICAgICAgKChwb2ludGVyWzFdIC0gb3JpZ2luWzFdKSAvIHNjYWxlKSAqIG5leHRTY2FsZSAtXG4gICAgICAgIChwb2ludGVyWzFdIC0gb3JpZ2luWzFdKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdHJhbnNsYXRlOiBbdHJhbnNsYXRlWzBdIC0gZGVsdGFYLCB0cmFuc2xhdGVbMV0gLSBkZWx0YVldLFxuICAgICAgICBzY2FsZTogbmV4dFNjYW