barsa-develop-components 1.0.281 → 1.0.286

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.
@@ -2,16 +2,14 @@ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
2
  import { takeUntil } from 'rxjs/operators';
3
3
  import { FormBaseComponent, FormPanelService } from 'barsa-novin-ray-core';
4
4
  import * as i0 from "@angular/core";
5
- import * as i1 from "barsa-novin-ray-core";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "barsa-sap-ui";
8
- import * as i4 from "@fundamental-ngx/core/button";
9
- import * as i5 from "@fundamental-ngx/core/dynamic-side-content";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "barsa-sap-ui";
7
+ import * as i3 from "@fundamental-ngx/core/button";
8
+ import * as i4 from "@fundamental-ngx/core/dynamic-side-content";
9
+ import * as i5 from "barsa-novin-ray-core";
10
10
  export class SettingFormComponent extends FormBaseComponent {
11
- constructor(_formPanelService, portalService) {
12
- super(_formPanelService);
13
- this._formPanelService = _formPanelService;
14
- this.portalService = portalService;
11
+ constructor() {
12
+ super(...arguments);
15
13
  this.deviceSize = 'xl';
16
14
  this.selectedSetting = false;
17
15
  this.groupSettingFieldCaption = 'گروه تنظیمات2';
@@ -19,8 +17,8 @@ export class SettingFormComponent extends FormBaseComponent {
19
17
  }
20
18
  ngOnInit() {
21
19
  super.ngOnInit();
22
- this.rtl$ = this.portalService.rtl$;
23
- this.portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((deviceSize) => {
20
+ this.rtl$ = this._portalService.rtl$;
21
+ this._portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((deviceSize) => {
24
22
  switch (deviceSize) {
25
23
  case 's':
26
24
  this.deviceSize = 'sm';
@@ -57,10 +55,10 @@ export class SettingFormComponent extends FormBaseComponent {
57
55
  this.selectedSetting = true;
58
56
  }
59
57
  }
60
- SettingFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: SettingFormComponent, deps: [{ token: i1.FormPanelService }, { token: i1.PortalService }], target: i0.ɵɵFactoryTarget.Component });
61
- SettingFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: SettingFormComponent, selector: "bdc-setting-form", providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"mo$ | async as mo; else loading\">\r\n <ng-container *ngIf=\"layout94$ | async as layout\">\r\n <div *ngIf=\"deviceSize === 'sm'; else sideContent\" style=\"display: flex; flex-direction: column\">\r\n <div *ngIf=\"selectedSetting\" style=\"width: 100%\">\r\n <button\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"(rtl$ | async)!! ? 'arrow-left' : 'arrow-right'\"\r\n (click)=\"onBack()\"\r\n ></button>\r\n </div>\r\n\r\n <div [class.hide]=\"selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n <div [class.hide]=\"!selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n <ng-template #sideContent>\r\n <fd-dynamic-side-content [size]=\"deviceSize\">\r\n <fd-dynamic-side-content-side>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-side>\r\n <fd-dynamic-side-content-main>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-main>\r\n </fd-dynamic-side-content>\r\n </ng-template>\r\n </ng-container>\r\n <ng-template #renderForm let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"objectSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n (click)=\"onSettingClick()\"\r\n class=\"form-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"objectSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n [focus]=\"true\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n <ng-template #renderSetting let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"groupSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n class=\"list-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"groupSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n</ng-container>\r\n<ng-template #loading>\r\n <bsu-mask></bsu-mask>\r\n</ng-template>\r\n", styles: [":host{width:100%}:host ::ng-deep bsu-ulv-context-menu,:host ::ng-deep li button{display:none}.list-setting{height:100%;border-left:1px solid #ccc}.list-setting ::ng-deep bnrc-field-ui{height:100%;padding:0}.list-setting.is-mobile{border:none}.form-setting{height:100%;padding-top:5px}.form-setting ::ng-deep bnrc-field-ui{height:100%!important}fd-dynamic-side-content{height:100%}fd-dynamic-side-content-main{overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i3.LayoutControlComponent, selector: "bsu-layout-control", inputs: ["inlineEdit", "caption", "focusControl", "showLabel", "maxLabelWidth", "hasHorizontalText", "contentDensity", "flex", "RefreshLabel", "SetVisible"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.DynamicSideContentComponent, selector: "fd-dynamic-side-content", inputs: ["position", "size", "id"] }, { kind: "component", type: i5.DynamicSideContentSideComponent, selector: "fd-dynamic-side-content-side", inputs: ["id"] }, { kind: "component", type: i5.DynamicSideContentMainComponent, selector: "fd-dynamic-side-content-main", inputs: ["id"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.ControlUiPipe, name: "controlUi" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
58
+ SettingFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: SettingFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
59
+ SettingFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: SettingFormComponent, selector: "bdc-setting-form", providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"mo$ | async as mo; else loading\">\r\n <ng-container *ngIf=\"layout94$ | async as layout\">\r\n <div *ngIf=\"deviceSize === 'sm'; else sideContent\" style=\"display: flex; flex-direction: column\">\r\n <div *ngIf=\"selectedSetting\" style=\"width: 100%\">\r\n <button\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"(rtl$ | async)!! ? 'arrow-left' : 'arrow-right'\"\r\n (click)=\"onBack()\"\r\n ></button>\r\n </div>\r\n\r\n <div [class.hide]=\"selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n <div [class.hide]=\"!selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n <ng-template #sideContent>\r\n <fd-dynamic-side-content [size]=\"deviceSize\">\r\n <fd-dynamic-side-content-side>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-side>\r\n <fd-dynamic-side-content-main>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-main>\r\n </fd-dynamic-side-content>\r\n </ng-template>\r\n </ng-container>\r\n <ng-template #renderForm let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"objectSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n (click)=\"onSettingClick()\"\r\n class=\"form-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"objectSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n [focus]=\"true\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n <ng-template #renderSetting let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"groupSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n class=\"list-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"groupSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n</ng-container>\r\n<ng-template #loading>\r\n <bsu-mask></bsu-mask>\r\n</ng-template>\r\n", styles: [":host{width:100%}:host ::ng-deep bsu-ulv-context-menu,:host ::ng-deep li button{display:none}.list-setting{height:100%;border-left:1px solid #ccc}.list-setting ::ng-deep bnrc-field-ui{height:100%;padding:0}.list-setting.is-mobile{border:none}.form-setting{height:100%;padding-top:5px}.form-setting ::ng-deep bnrc-field-ui{height:100%!important}fd-dynamic-side-content{height:100%}fd-dynamic-side-content-main{overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i2.LayoutControlComponent, selector: "bsu-layout-control", inputs: ["inlineEdit", "caption", "focusControl", "showLabel", "maxLabelWidth", "hasHorizontalText", "contentDensity", "flex", "RefreshLabel", "SetVisible"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.DynamicSideContentComponent, selector: "fd-dynamic-side-content", inputs: ["position", "size", "id"] }, { kind: "component", type: i4.DynamicSideContentSideComponent, selector: "fd-dynamic-side-content-side", inputs: ["id"] }, { kind: "component", type: i4.DynamicSideContentMainComponent, selector: "fd-dynamic-side-content-main", inputs: ["id"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.ControlUiPipe, name: "controlUi" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
62
60
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: SettingFormComponent, decorators: [{
63
61
  type: Component,
64
62
  args: [{ selector: 'bdc-setting-form', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], template: "<ng-container *ngIf=\"mo$ | async as mo; else loading\">\r\n <ng-container *ngIf=\"layout94$ | async as layout\">\r\n <div *ngIf=\"deviceSize === 'sm'; else sideContent\" style=\"display: flex; flex-direction: column\">\r\n <div *ngIf=\"selectedSetting\" style=\"width: 100%\">\r\n <button\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"(rtl$ | async)!! ? 'arrow-left' : 'arrow-right'\"\r\n (click)=\"onBack()\"\r\n ></button>\r\n </div>\r\n\r\n <div [class.hide]=\"selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n <div [class.hide]=\"!selectedSetting\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: true\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n <ng-template #sideContent>\r\n <fd-dynamic-side-content [size]=\"deviceSize\">\r\n <fd-dynamic-side-content-side>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderSetting;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-side>\r\n <fd-dynamic-side-content-main>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n renderForm;\r\n context: {\r\n $implicit: layout,\r\n isMobile: false\r\n }\r\n \"\r\n ></ng-container>\r\n </fd-dynamic-side-content-main>\r\n </fd-dynamic-side-content>\r\n </ng-template>\r\n </ng-container>\r\n <ng-template #renderForm let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"objectSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n (click)=\"onSettingClick()\"\r\n class=\"form-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"objectSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n [focus]=\"true\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n <ng-template #renderSetting let-layout let-isMobile=\"isMobile\">\r\n <bsu-layout-control\r\n *ngIf=\"groupSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n class=\"list-setting\"\r\n [class.is-mobile]=\"isMobile\"\r\n [caption]=\"groupSettingFieldCaption\"\r\n [config]=\"layoutConfig\"\r\n ></bsu-layout-control>\r\n </ng-template>\r\n</ng-container>\r\n<ng-template #loading>\r\n <bsu-mask></bsu-mask>\r\n</ng-template>\r\n", styles: [":host{width:100%}:host ::ng-deep bsu-ulv-context-menu,:host ::ng-deep li button{display:none}.list-setting{height:100%;border-left:1px solid #ccc}.list-setting ::ng-deep bnrc-field-ui{height:100%;padding:0}.list-setting.is-mobile{border:none}.form-setting{height:100%;padding-top:5px}.form-setting ::ng-deep bnrc-field-ui{height:100%!important}fd-dynamic-side-content{height:100%}fd-dynamic-side-content-main{overflow-y:auto}\n"] }]
65
- }], ctorParameters: function () { return [{ type: i1.FormPanelService }, { type: i1.PortalService }]; } });
66
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setting-form.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/setting-form/setting-form.component.ts","../../../../../projects/barsa-develop-components/src/lib/setting-form/setting-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,uBAAuB,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAErG,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAiB,MAAM,sBAAsB,CAAC;;;;;;;AAS1F,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;IAOvD,YAAsB,iBAAmC,EAAU,aAA4B;QAC3F,KAAK,CAAC,iBAAiB,CAAC,CAAC;QADP,sBAAiB,GAAjB,iBAAiB,CAAkB;QAAU,kBAAa,GAAb,aAAa,CAAe;QAN/F,eAAU,GAAuB,IAAI,CAAC;QACtC,oBAAe,GAAG,KAAK,CAAC;QAExB,6BAAwB,GAAG,eAAe,CAAC;QAC3C,8BAAyB,GAAG,YAAY,CAAC;IAIzC,CAAC;IACD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACtF,QAAQ,UAAU,EAAE;gBAChB,KAAK,GAAG;oBACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,MAAM;gBACV,KAAK,GAAG;oBACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,MAAM;gBACV;oBACI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;aAC9B;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,eAAe;QACX,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,OAAO,GAAQ,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CACrD,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,KAAK,IAAI,CAAC,wBAAwB,CAC9E,CAAC;QACF,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;gBACrB,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;aACjD,CAAC,CAAC;SACN;QACD,IAAI,CAAC,sBAAsB,GAAG,OAAO,CAAC;IAC1C,CAAC;IACD,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;SACvF;IACL,CAAC;IACD,cAAc,KAAU,CAAC;IACzB,MAAM;QACF,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IACjC,CAAC;IACD,mBAAmB;QACf,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;;iHAlDQ,oBAAoB;qGAApB,oBAAoB,2CAFlB,CAAC,gBAAgB,CAAC,iDCVjC,uiHAsFA;2FD1Ea,oBAAoB;kBAPhC,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,aACpC,CAAC,gBAAgB,CAAC","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { FormBaseComponent, FormPanelService, PortalService } from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bdc-setting-form',\r\n    templateUrl: './setting-form.component.html',\r\n    styleUrls: ['./setting-form.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [FormPanelService]\r\n})\r\nexport class SettingFormComponent extends FormBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n    deviceSize: 'xl' | 'md' | 'sm' = 'xl';\r\n    selectedSetting = false;\r\n    rtl$: Observable<boolean>;\r\n    groupSettingFieldCaption = 'گروه تنظیمات2';\r\n    objectSettingFieldCaption = 'شی تنظیمات';\r\n    private _groupSettingControlUi: any;\r\n    constructor(protected _formPanelService: FormPanelService, private portalService: PortalService) {\r\n        super(_formPanelService);\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.rtl$ = this.portalService.rtl$;\r\n        this.portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((deviceSize) => {\r\n            switch (deviceSize) {\r\n                case 's':\r\n                    this.deviceSize = 'sm';\r\n                    break;\r\n                case 'm':\r\n                    this.deviceSize = 'md';\r\n                    break;\r\n                default:\r\n                    this.deviceSize = 'xl';\r\n            }\r\n        });\r\n    }\r\n    ngAfterViewInit(): void {\r\n        super.ngAfterViewInit();\r\n        const fieldUi: any = Object.values(this.listFieldUi).find(\r\n            (c: any) => c.Setting.ControlFieldCaption === this.groupSettingFieldCaption\r\n        );\r\n        if (fieldUi) {\r\n            fieldUi.viewerControl.on({\r\n                rowselect: this._setSelectedSetting.bind(this)\r\n            });\r\n        }\r\n        this._groupSettingControlUi = fieldUi;\r\n    }\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        if (this._groupSettingControlUi) {\r\n            this._groupSettingControlUi.viewerControl.un('rowselect', this._setSelectedSetting);\r\n        }\r\n    }\r\n    onSettingClick(): void {}\r\n    onBack(): void {\r\n        this.selectedSetting = false;\r\n    }\r\n    _setSelectedSetting(): void {\r\n        this.selectedSetting = true;\r\n    }\r\n}\r\n","<ng-container *ngIf=\"mo$ | async as mo; else loading\">\r\n    <ng-container *ngIf=\"layout94$ | async as layout\">\r\n        <div *ngIf=\"deviceSize === 'sm'; else sideContent\" style=\"display: flex; flex-direction: column\">\r\n            <div *ngIf=\"selectedSetting\" style=\"width: 100%\">\r\n                <button\r\n                    fd-button\r\n                    [fdType]=\"'transparent'\"\r\n                    [glyph]=\"(rtl$ | async)!! ? 'arrow-left' : 'arrow-right'\"\r\n                    (click)=\"onBack()\"\r\n                ></button>\r\n            </div>\r\n\r\n            <div [class.hide]=\"selectedSetting\">\r\n                <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                        renderSetting;\r\n                        context: {\r\n                            $implicit: layout,\r\n                            isMobile: true\r\n                        }\r\n                    \"\r\n                ></ng-container>\r\n            </div>\r\n            <div [class.hide]=\"!selectedSetting\">\r\n                <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                        renderForm;\r\n                        context: {\r\n                            $implicit: layout,\r\n                            isMobile: true\r\n                        }\r\n                    \"\r\n                ></ng-container>\r\n            </div>\r\n        </div>\r\n        <ng-template #sideContent>\r\n            <fd-dynamic-side-content [size]=\"deviceSize\">\r\n                <fd-dynamic-side-content-side>\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                            renderSetting;\r\n                            context: {\r\n                                $implicit: layout,\r\n                                isMobile: false\r\n                            }\r\n                        \"\r\n                    ></ng-container>\r\n                </fd-dynamic-side-content-side>\r\n                <fd-dynamic-side-content-main>\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                            renderForm;\r\n                            context: {\r\n                                $implicit: layout,\r\n                                isMobile: false\r\n                            }\r\n                        \"\r\n                    ></ng-container>\r\n                </fd-dynamic-side-content-main>\r\n            </fd-dynamic-side-content>\r\n        </ng-template>\r\n    </ng-container>\r\n    <ng-template #renderForm let-layout let-isMobile=\"isMobile\">\r\n        <bsu-layout-control\r\n            *ngIf=\"objectSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n            (click)=\"onSettingClick()\"\r\n            class=\"form-setting\"\r\n            [class.is-mobile]=\"isMobile\"\r\n            [caption]=\"objectSettingFieldCaption\"\r\n            [config]=\"layoutConfig\"\r\n            [focus]=\"true\"\r\n        ></bsu-layout-control>\r\n    </ng-template>\r\n    <ng-template #renderSetting let-layout let-isMobile=\"isMobile\">\r\n        <bsu-layout-control\r\n            *ngIf=\"groupSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n            class=\"list-setting\"\r\n            [class.is-mobile]=\"isMobile\"\r\n            [caption]=\"groupSettingFieldCaption\"\r\n            [config]=\"layoutConfig\"\r\n        ></bsu-layout-control>\r\n    </ng-template>\r\n</ng-container>\r\n<ng-template #loading>\r\n    <bsu-mask></bsu-mask>\r\n</ng-template>\r\n"]}
63
+ }] });
64
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setting-form.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/setting-form/setting-form.component.ts","../../../../../projects/barsa-develop-components/src/lib/setting-form/setting-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,uBAAuB,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAErG,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAS3E,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;IAP3D;;QAQI,eAAU,GAAuB,IAAI,CAAC;QACtC,oBAAe,GAAG,KAAK,CAAC;QAExB,6BAAwB,GAAG,eAAe,CAAC;QAC3C,8BAAyB,GAAG,YAAY,CAAC;KA4C5C;IAzCG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACvF,QAAQ,UAAU,EAAE;gBAChB,KAAK,GAAG;oBACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,MAAM;gBACV,KAAK,GAAG;oBACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,MAAM;gBACV;oBACI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;aAC9B;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,eAAe;QACX,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,OAAO,GAAQ,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CACrD,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,KAAK,IAAI,CAAC,wBAAwB,CAC9E,CAAC;QACF,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;gBACrB,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;aACjD,CAAC,CAAC;SACN;QACD,IAAI,CAAC,sBAAsB,GAAG,OAAO,CAAC;IAC1C,CAAC;IACD,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;SACvF;IACL,CAAC;IACD,cAAc,KAAU,CAAC;IACzB,MAAM;QACF,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IACjC,CAAC;IACD,mBAAmB;QACf,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;;iHAhDQ,oBAAoB;qGAApB,oBAAoB,2CAFlB,CAAC,gBAAgB,CAAC,iDCVjC,uiHAsFA;2FD1Ea,oBAAoB;kBAPhC,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,aACpC,CAAC,gBAAgB,CAAC","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, OnDestroy, OnInit } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { FormBaseComponent, FormPanelService } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bdc-setting-form',\n    templateUrl: './setting-form.component.html',\n    styleUrls: ['./setting-form.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [FormPanelService]\n})\nexport class SettingFormComponent extends FormBaseComponent implements OnInit, AfterViewInit, OnDestroy {\n    deviceSize: 'xl' | 'md' | 'sm' = 'xl';\n    selectedSetting = false;\n    rtl$: Observable<boolean>;\n    groupSettingFieldCaption = 'گروه تنظیمات2';\n    objectSettingFieldCaption = 'شی تنظیمات';\n    private _groupSettingControlUi: any;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.rtl$ = this._portalService.rtl$;\n        this._portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((deviceSize) => {\n            switch (deviceSize) {\n                case 's':\n                    this.deviceSize = 'sm';\n                    break;\n                case 'm':\n                    this.deviceSize = 'md';\n                    break;\n                default:\n                    this.deviceSize = 'xl';\n            }\n        });\n    }\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        const fieldUi: any = Object.values(this.listFieldUi).find(\n            (c: any) => c.Setting.ControlFieldCaption === this.groupSettingFieldCaption\n        );\n        if (fieldUi) {\n            fieldUi.viewerControl.on({\n                rowselect: this._setSelectedSetting.bind(this)\n            });\n        }\n        this._groupSettingControlUi = fieldUi;\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        if (this._groupSettingControlUi) {\n            this._groupSettingControlUi.viewerControl.un('rowselect', this._setSelectedSetting);\n        }\n    }\n    onSettingClick(): void {}\n    onBack(): void {\n        this.selectedSetting = false;\n    }\n    _setSelectedSetting(): void {\n        this.selectedSetting = true;\n    }\n}\n","<ng-container *ngIf=\"mo$ | async as mo; else loading\">\r\n    <ng-container *ngIf=\"layout94$ | async as layout\">\r\n        <div *ngIf=\"deviceSize === 'sm'; else sideContent\" style=\"display: flex; flex-direction: column\">\r\n            <div *ngIf=\"selectedSetting\" style=\"width: 100%\">\r\n                <button\r\n                    fd-button\r\n                    [fdType]=\"'transparent'\"\r\n                    [glyph]=\"(rtl$ | async)!! ? 'arrow-left' : 'arrow-right'\"\r\n                    (click)=\"onBack()\"\r\n                ></button>\r\n            </div>\r\n\r\n            <div [class.hide]=\"selectedSetting\">\r\n                <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                        renderSetting;\r\n                        context: {\r\n                            $implicit: layout,\r\n                            isMobile: true\r\n                        }\r\n                    \"\r\n                ></ng-container>\r\n            </div>\r\n            <div [class.hide]=\"!selectedSetting\">\r\n                <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                        renderForm;\r\n                        context: {\r\n                            $implicit: layout,\r\n                            isMobile: true\r\n                        }\r\n                    \"\r\n                ></ng-container>\r\n            </div>\r\n        </div>\r\n        <ng-template #sideContent>\r\n            <fd-dynamic-side-content [size]=\"deviceSize\">\r\n                <fd-dynamic-side-content-side>\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                            renderSetting;\r\n                            context: {\r\n                                $implicit: layout,\r\n                                isMobile: false\r\n                            }\r\n                        \"\r\n                    ></ng-container>\r\n                </fd-dynamic-side-content-side>\r\n                <fd-dynamic-side-content-main>\r\n                    <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                            renderForm;\r\n                            context: {\r\n                                $implicit: layout,\r\n                                isMobile: false\r\n                            }\r\n                        \"\r\n                    ></ng-container>\r\n                </fd-dynamic-side-content-main>\r\n            </fd-dynamic-side-content>\r\n        </ng-template>\r\n    </ng-container>\r\n    <ng-template #renderForm let-layout let-isMobile=\"isMobile\">\r\n        <bsu-layout-control\r\n            *ngIf=\"objectSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n            (click)=\"onSettingClick()\"\r\n            class=\"form-setting\"\r\n            [class.is-mobile]=\"isMobile\"\r\n            [caption]=\"objectSettingFieldCaption\"\r\n            [config]=\"layoutConfig\"\r\n            [focus]=\"true\"\r\n        ></bsu-layout-control>\r\n    </ng-template>\r\n    <ng-template #renderSetting let-layout let-isMobile=\"isMobile\">\r\n        <bsu-layout-control\r\n            *ngIf=\"groupSettingFieldCaption | controlUi: layout as layoutConfig\"\r\n            class=\"list-setting\"\r\n            [class.is-mobile]=\"isMobile\"\r\n            [caption]=\"groupSettingFieldCaption\"\r\n            [config]=\"layoutConfig\"\r\n        ></bsu-layout-control>\r\n    </ng-template>\r\n</ng-container>\r\n<ng-template #loading>\r\n    <bsu-mask></bsu-mask>\r\n</ng-template>\r\n"]}
@@ -23,6 +23,14 @@ export class TabProcessViewComponent extends ReportViewBaseComponent {
23
23
  }
24
24
  });
25
25
  }
26
+ onTabChange2(e) {
27
+ const index = this.moDataList.findIndex((c) => c.Id === e.Id);
28
+ const mo = this.moDataList[index];
29
+ if (mo.$IsChecked) {
30
+ return;
31
+ }
32
+ super.onRowCheck({ mo, index });
33
+ }
26
34
  onTabChange(e) {
27
35
  const index = this.moDataList.findIndex((c) => c.Id === e.id);
28
36
  const mo = this.moDataList[index];
@@ -30,12 +38,12 @@ export class TabProcessViewComponent extends ReportViewBaseComponent {
30
38
  }
31
39
  }
32
40
  TabProcessViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TabProcessViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
33
- TabProcessViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: TabProcessViewComponent, selector: "bdc-tab-process-view", viewQueries: [{ propertyName: "tabList", first: true, predicate: TabListComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<fd-tab-list mode=\"process\" (selectedTabChange)=\"onTabChange($event)\">\r\n <fd-tab\r\n *ngFor=\"let item of moDataList; let index = index; let last = last\"\r\n [id]=\"item.Id\"\r\n [active]=\"item.$IsChecked\"\r\n >\r\n <ng-template fd-tab-title-template>\r\n <span\r\n fd-tab-icon\r\n [icon]=\"(fieldIcon | rval: item:allColumns) ? (fieldIcon | rval: item:allColumns) : defaultIcon\"\r\n ></span>\r\n <div fd-tab-process>\r\n <span fd-tab-label>{{ fieldTitle | rval: item:allColumns }}</span>\r\n <span fd-tab-label>{{ fieldSubtitle | rval: item:allColumns }}</span>\r\n </div>\r\n </ng-template>\r\n </fd-tab>\r\n</fd-tab-list>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.TabListComponent, selector: "fd-tab-list", inputs: ["size", "mode", "collapseOverflow", "maxVisibleTabs", "stackContent", "maxContentHeight", "collapsibleTabs", "expandOverflowText", "defaultTab", "selectDefaultOnTabsChange"], outputs: ["selectedTabChange", "visibleItemsCount", "hiddenItemsCount"] }, { kind: "component", type: i2.TabPanelComponent, selector: "fd-tab", inputs: ["id", "ariaLabel", "ariaLabelledBy", "title", "count", "glyph", "header", "disabled", "tabState"], outputs: ["opened", "closed"] }, { kind: "directive", type: i2.TabTitleDirective, selector: "[fdTabTitleTemplate], [fd-tab-title-template]" }, { kind: "component", type: i2.TabIconComponent, selector: "[fd-tab-icon]", inputs: ["class", "icon"] }, { kind: "directive", type: i2.TabLabelDirective, selector: "[fdTabLabel], [fd-tab-label]" }, { kind: "directive", type: i2.TabProcessDirective, selector: "[fdTabProcess], [fd-tab-process]" }, { kind: "pipe", type: i3.MoReportValuePipe, name: "rval" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
41
+ TabProcessViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: TabProcessViewComponent, selector: "bdc-tab-process-view", viewQueries: [{ propertyName: "tabList", first: true, predicate: TabListComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<fd-tab-list mode=\"process\">\n <fd-tab\n *ngFor=\"let item of moDataList; let index = index; let last = last\"\n [id]=\"item.Id\"\n [active]=\"item.$IsChecked\"\n >\n <ng-template fd-tab-title-template>\n <span\n (click)=\"onTabChange2(item)\"\n fd-tab-icon\n [icon]=\"(fieldIcon | rval: item:allColumns) ? (fieldIcon | rval: item:allColumns) : defaultIcon\"\n ></span>\n <div fd-tab-process (click)=\"onTabChange2(item)\">\n <span fd-tab-label>{{ fieldTitle | rval: item:allColumns }}</span>\n <span fd-tab-label>{{ fieldSubtitle | rval: item:allColumns }}</span>\n </div>\n </ng-template>\n </fd-tab>\n</fd-tab-list>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.TabListComponent, selector: "fd-tab-list", inputs: ["size", "mode", "collapseOverflow", "maxVisibleTabs", "stackContent", "maxContentHeight", "collapsibleTabs", "expandOverflowText", "defaultTab", "selectDefaultOnTabsChange"], outputs: ["selectedTabChange", "visibleItemsCount", "hiddenItemsCount"] }, { kind: "component", type: i2.TabPanelComponent, selector: "fd-tab", inputs: ["id", "ariaLabel", "ariaLabelledBy", "title", "count", "glyph", "header", "disabled", "tabState"], outputs: ["opened", "closed"] }, { kind: "directive", type: i2.TabTitleDirective, selector: "[fdTabTitleTemplate], [fd-tab-title-template]" }, { kind: "component", type: i2.TabIconComponent, selector: "[fd-tab-icon]", inputs: ["class", "icon"] }, { kind: "directive", type: i2.TabLabelDirective, selector: "[fdTabLabel], [fd-tab-label]" }, { kind: "directive", type: i2.TabProcessDirective, selector: "[fdTabProcess], [fd-tab-process]" }, { kind: "pipe", type: i3.MoReportValuePipe, name: "rval" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
34
42
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TabProcessViewComponent, decorators: [{
35
43
  type: Component,
36
- args: [{ selector: 'bdc-tab-process-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-tab-list mode=\"process\" (selectedTabChange)=\"onTabChange($event)\">\r\n <fd-tab\r\n *ngFor=\"let item of moDataList; let index = index; let last = last\"\r\n [id]=\"item.Id\"\r\n [active]=\"item.$IsChecked\"\r\n >\r\n <ng-template fd-tab-title-template>\r\n <span\r\n fd-tab-icon\r\n [icon]=\"(fieldIcon | rval: item:allColumns) ? (fieldIcon | rval: item:allColumns) : defaultIcon\"\r\n ></span>\r\n <div fd-tab-process>\r\n <span fd-tab-label>{{ fieldTitle | rval: item:allColumns }}</span>\r\n <span fd-tab-label>{{ fieldSubtitle | rval: item:allColumns }}</span>\r\n </div>\r\n </ng-template>\r\n </fd-tab>\r\n</fd-tab-list>\r\n" }]
44
+ args: [{ selector: 'bdc-tab-process-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-tab-list mode=\"process\">\n <fd-tab\n *ngFor=\"let item of moDataList; let index = index; let last = last\"\n [id]=\"item.Id\"\n [active]=\"item.$IsChecked\"\n >\n <ng-template fd-tab-title-template>\n <span\n (click)=\"onTabChange2(item)\"\n fd-tab-icon\n [icon]=\"(fieldIcon | rval: item:allColumns) ? (fieldIcon | rval: item:allColumns) : defaultIcon\"\n ></span>\n <div fd-tab-process (click)=\"onTabChange2(item)\">\n <span fd-tab-label>{{ fieldTitle | rval: item:allColumns }}</span>\n <span fd-tab-label>{{ fieldSubtitle | rval: item:allColumns }}</span>\n </div>\n </ng-template>\n </fd-tab>\n</fd-tab-list>\n" }]
37
45
  }], propDecorators: { tabList: [{
38
46
  type: ViewChild,
39
47
  args: [TabListComponent]
40
48
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLXByb2Nlc3Mtdmlldy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1kZXZlbG9wLWNvbXBvbmVudHMvc3JjL2xpYi90YWItcHJvY2Vzcy12aWV3L3RhYi1wcm9jZXNzLXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvdGFiLXByb2Nlc3Mtdmlldy90YWItcHJvY2Vzcy12aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUUvRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQXFCLE1BQU0sdUJBQXVCLENBQUM7Ozs7O0FBTzVFLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSx1QkFBOEM7SUFVdkYsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQyx3QkFBd0IsQ0FBQztRQUNoRixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDO1FBQzlDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUM7UUFDcEQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQztRQUM1QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDO1FBQ2hELElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7WUFDeEYsSUFBSSxVQUFVLEVBQUU7Z0JBQ1osTUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUNoRSxJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksYUFBYSxHQUFHLENBQUMsQ0FBQyxFQUFFO29CQUNwQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO2lCQUNuRjthQUNKO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVyxDQUFDLENBQW9CO1FBQzVCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM5RCxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLEtBQUssQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNwQyxDQUFDOztvSEEvQlEsdUJBQXVCO3dHQUF2Qix1QkFBdUIscUdBQ3JCLGdCQUFnQix1RUNiL0Isb3hCQWtCQTsyRkROYSx1QkFBdUI7a0JBTm5DLFNBQVM7K0JBQ0ksc0JBQXNCLG1CQUdmLHVCQUF1QixDQUFDLE1BQU07OEJBR2xCLE9BQU87c0JBQW5DLFNBQVM7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgUmVwb3J0Vmlld0Jhc2VDb21wb25lbnQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5pbXBvcnQgeyBUYWJQcm9jZXNzVmlld1NldHRpbmcgfSBmcm9tICcuLi9tb2RlbHMnO1xuaW1wb3J0IHsgVGFiTGlzdENvbXBvbmVudCwgVGFiUGFuZWxDb21wb25lbnQgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L2NvcmUnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdiZGMtdGFiLXByb2Nlc3MtdmlldycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RhYi1wcm9jZXNzLXZpZXcuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3RhYi1wcm9jZXNzLXZpZXcuY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBUYWJQcm9jZXNzVmlld0NvbXBvbmVudCBleHRlbmRzIFJlcG9ydFZpZXdCYXNlQ29tcG9uZW50PFRhYlByb2Nlc3NWaWV3U2V0dGluZz4gaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBWaWV3Q2hpbGQoVGFiTGlzdENvbXBvbmVudCkgdGFiTGlzdDogVGFiTGlzdENvbXBvbmVudDtcbiAgICBmaWVsZFRpdGxlOiBzdHJpbmc7XG4gICAgZmllbGRJY29uOiBzdHJpbmc7XG4gICAgZmllbGRTdGF0ZTogc3RyaW5nO1xuICAgIG1vZGU6IHN0cmluZztcbiAgICBhcnJvd1JpZ2h0OiBzdHJpbmc7XG4gICAgZmllbGRTdWJ0aXRsZTogc3RyaW5nO1xuICAgIGRlZmF1bHRJY29uOiBzdHJpbmc7XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5hcnJvd1JpZ2h0ID0gdGhpcy5ydGwgPyAnbmF2aWdhdGlvbi1sZWZ0LWFycm93JyA6ICduYXZpZ2F0aW9uLXJpZ2h0LWFycm93JztcbiAgICAgICAgdGhpcy5maWVsZFRpdGxlID0gdGhpcy52aWV3U2V0dGluZy5GaWVsZFRpdGxlO1xuICAgICAgICB0aGlzLmZpZWxkU3VidGl0bGUgPSB0aGlzLnZpZXdTZXR0aW5nLkZpZWxkU3VidGl0bGU7XG4gICAgICAgIHRoaXMuZmllbGRJY29uID0gdGhpcy52aWV3U2V0dGluZy5GaWVsZEljb247XG4gICAgICAgIHRoaXMuZGVmYXVsdEljb24gPSB0aGlzLnZpZXdTZXR0aW5nLkRlZmF1bHRJY29uO1xuICAgICAgICB0aGlzLl91bHZNYWluU2VydmljZS5tb0RhdGFMaXN0JC5waXBlKHRha2VVbnRpbCh0aGlzLl9vbkRlc3Ryb3kkKSkuc3Vic2NyaWJlKChtb0RhdGFMaXN0KSA9PiB7XG4gICAgICAgICAgICBpZiAobW9EYXRhTGlzdCkge1xuICAgICAgICAgICAgICAgIGNvbnN0IHNlbGVjdGVkSW5kZXggPSBtb0RhdGFMaXN0LmZpbmRJbmRleCgoYykgPT4gYy4kSXNDaGVja2VkKTtcbiAgICAgICAgICAgICAgICBpZiAodGhpcy50YWJMaXN0ICYmIHNlbGVjdGVkSW5kZXggPiAtMSkge1xuICAgICAgICAgICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHRoaXMudGFiTGlzdC50YWJQYW5lbHMudG9BcnJheSgpW3NlbGVjdGVkSW5kZXhdLm9wZW4odHJ1ZSksIDApO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgb25UYWJDaGFuZ2UoZTogVGFiUGFuZWxDb21wb25lbnQpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgaW5kZXggPSB0aGlzLm1vRGF0YUxpc3QuZmluZEluZGV4KChjKSA9PiBjLklkID09PSBlLmlkKTtcbiAgICAgICAgY29uc3QgbW8gPSB0aGlzLm1vRGF0YUxpc3RbaW5kZXhdO1xuICAgICAgICBzdXBlci5vblJvd0NoZWNrKHsgbW8sIGluZGV4IH0pO1xuICAgIH1cbn1cbiIsIjxmZC10YWItbGlzdCBtb2RlPVwicHJvY2Vzc1wiIChzZWxlY3RlZFRhYkNoYW5nZSk9XCJvblRhYkNoYW5nZSgkZXZlbnQpXCI+XHJcbiAgICA8ZmQtdGFiXHJcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbW9EYXRhTGlzdDsgbGV0IGluZGV4ID0gaW5kZXg7IGxldCBsYXN0ID0gbGFzdFwiXHJcbiAgICAgICAgW2lkXT1cIml0ZW0uSWRcIlxyXG4gICAgICAgIFthY3RpdmVdPVwiaXRlbS4kSXNDaGVja2VkXCJcclxuICAgID5cclxuICAgICAgICA8bmctdGVtcGxhdGUgZmQtdGFiLXRpdGxlLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICA8c3BhblxyXG4gICAgICAgICAgICAgICAgZmQtdGFiLWljb25cclxuICAgICAgICAgICAgICAgIFtpY29uXT1cIihmaWVsZEljb24gfCBydmFsOiBpdGVtOmFsbENvbHVtbnMpID8gKGZpZWxkSWNvbiB8IHJ2YWw6IGl0ZW06YWxsQ29sdW1ucykgOiBkZWZhdWx0SWNvblwiXHJcbiAgICAgICAgICAgID48L3NwYW4+XHJcbiAgICAgICAgICAgIDxkaXYgZmQtdGFiLXByb2Nlc3M+XHJcbiAgICAgICAgICAgICAgICA8c3BhbiBmZC10YWItbGFiZWw+e3sgZmllbGRUaXRsZSB8IHJ2YWw6IGl0ZW06YWxsQ29sdW1ucyB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDxzcGFuIGZkLXRhYi1sYWJlbD57eyBmaWVsZFN1YnRpdGxlIHwgcnZhbDogaXRlbTphbGxDb2x1bW5zIH19PC9zcGFuPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgPC9mZC10YWI+XHJcbjwvZmQtdGFiLWxpc3Q+XHJcbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLXByb2Nlc3Mtdmlldy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1kZXZlbG9wLWNvbXBvbmVudHMvc3JjL2xpYi90YWItcHJvY2Vzcy12aWV3L3RhYi1wcm9jZXNzLXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvdGFiLXByb2Nlc3Mtdmlldy90YWItcHJvY2Vzcy12aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQUUsdUJBQXVCLEVBQXVCLE1BQU0sc0JBQXNCLENBQUM7QUFFcEYsT0FBTyxFQUFFLGdCQUFnQixFQUFxQixNQUFNLHVCQUF1QixDQUFDOzs7OztBQU81RSxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsdUJBQThDO0lBVXZGLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsd0JBQXdCLENBQUM7UUFDaEYsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQztRQUM5QyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDO1FBQ3BELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUM7UUFDNUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQztRQUNoRCxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ3hGLElBQUksVUFBVSxFQUFFO2dCQUNaLE1BQU0sYUFBYSxHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQztnQkFDaEUsSUFBSSxJQUFJLENBQUMsT0FBTyxJQUFJLGFBQWEsR0FBRyxDQUFDLENBQUMsRUFBRTtvQkFDcEMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztpQkFDbkY7YUFDSjtRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUNELFlBQVksQ0FBQyxDQUFzQjtRQUMvQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDOUQsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsQyxJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUU7WUFDZixPQUFPO1NBQ1Y7UUFDRCxLQUFLLENBQUMsVUFBVSxDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUNELFdBQVcsQ0FBQyxDQUFvQjtRQUM1QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDOUQsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsQyxLQUFLLENBQUMsVUFBVSxDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDcEMsQ0FBQzs7b0hBdENRLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLHFHQUNyQixnQkFBZ0IsdUVDYi9CLG14QkFtQkE7MkZEUGEsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNJLHNCQUFzQixtQkFHZix1QkFBdUIsQ0FBQyxNQUFNOzhCQUdsQixPQUFPO3NCQUFuQyxTQUFTO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IFJlcG9ydFZpZXdCYXNlQ29tcG9uZW50LCBNZXRhb2JqZWN0RGF0YU1vZGVsIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuaW1wb3J0IHsgVGFiUHJvY2Vzc1ZpZXdTZXR0aW5nIH0gZnJvbSAnLi4vbW9kZWxzJztcbmltcG9ydCB7IFRhYkxpc3RDb21wb25lbnQsIFRhYlBhbmVsQ29tcG9uZW50IH0gZnJvbSAnQGZ1bmRhbWVudGFsLW5neC9jb3JlJztcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYmRjLXRhYi1wcm9jZXNzLXZpZXcnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90YWItcHJvY2Vzcy12aWV3LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi90YWItcHJvY2Vzcy12aWV3LmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgVGFiUHJvY2Vzc1ZpZXdDb21wb25lbnQgZXh0ZW5kcyBSZXBvcnRWaWV3QmFzZUNvbXBvbmVudDxUYWJQcm9jZXNzVmlld1NldHRpbmc+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBAVmlld0NoaWxkKFRhYkxpc3RDb21wb25lbnQpIHRhYkxpc3Q6IFRhYkxpc3RDb21wb25lbnQ7XG4gICAgZmllbGRUaXRsZTogc3RyaW5nO1xuICAgIGZpZWxkSWNvbjogc3RyaW5nO1xuICAgIGZpZWxkU3RhdGU6IHN0cmluZztcbiAgICBtb2RlOiBzdHJpbmc7XG4gICAgYXJyb3dSaWdodDogc3RyaW5nO1xuICAgIGZpZWxkU3VidGl0bGU6IHN0cmluZztcbiAgICBkZWZhdWx0SWNvbjogc3RyaW5nO1xuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuYXJyb3dSaWdodCA9IHRoaXMucnRsID8gJ25hdmlnYXRpb24tbGVmdC1hcnJvdycgOiAnbmF2aWdhdGlvbi1yaWdodC1hcnJvdyc7XG4gICAgICAgIHRoaXMuZmllbGRUaXRsZSA9IHRoaXMudmlld1NldHRpbmcuRmllbGRUaXRsZTtcbiAgICAgICAgdGhpcy5maWVsZFN1YnRpdGxlID0gdGhpcy52aWV3U2V0dGluZy5GaWVsZFN1YnRpdGxlO1xuICAgICAgICB0aGlzLmZpZWxkSWNvbiA9IHRoaXMudmlld1NldHRpbmcuRmllbGRJY29uO1xuICAgICAgICB0aGlzLmRlZmF1bHRJY29uID0gdGhpcy52aWV3U2V0dGluZy5EZWZhdWx0SWNvbjtcbiAgICAgICAgdGhpcy5fdWx2TWFpblNlcnZpY2UubW9EYXRhTGlzdCQucGlwZSh0YWtlVW50aWwodGhpcy5fb25EZXN0cm95JCkpLnN1YnNjcmliZSgobW9EYXRhTGlzdCkgPT4ge1xuICAgICAgICAgICAgaWYgKG1vRGF0YUxpc3QpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBzZWxlY3RlZEluZGV4ID0gbW9EYXRhTGlzdC5maW5kSW5kZXgoKGMpID0+IGMuJElzQ2hlY2tlZCk7XG4gICAgICAgICAgICAgICAgaWYgKHRoaXMudGFiTGlzdCAmJiBzZWxlY3RlZEluZGV4ID4gLTEpIHtcbiAgICAgICAgICAgICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLnRhYkxpc3QudGFiUGFuZWxzLnRvQXJyYXkoKVtzZWxlY3RlZEluZGV4XS5vcGVuKHRydWUpLCAwKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBvblRhYkNoYW5nZTIoZTogTWV0YW9iamVjdERhdGFNb2RlbCk6IHZvaWQge1xuICAgICAgICBjb25zdCBpbmRleCA9IHRoaXMubW9EYXRhTGlzdC5maW5kSW5kZXgoKGMpID0+IGMuSWQgPT09IGUuSWQpO1xuICAgICAgICBjb25zdCBtbyA9IHRoaXMubW9EYXRhTGlzdFtpbmRleF07XG4gICAgICAgIGlmIChtby4kSXNDaGVja2VkKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgc3VwZXIub25Sb3dDaGVjayh7IG1vLCBpbmRleCB9KTtcbiAgICB9XG4gICAgb25UYWJDaGFuZ2UoZTogVGFiUGFuZWxDb21wb25lbnQpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgaW5kZXggPSB0aGlzLm1vRGF0YUxpc3QuZmluZEluZGV4KChjKSA9PiBjLklkID09PSBlLmlkKTtcbiAgICAgICAgY29uc3QgbW8gPSB0aGlzLm1vRGF0YUxpc3RbaW5kZXhdO1xuICAgICAgICBzdXBlci5vblJvd0NoZWNrKHsgbW8sIGluZGV4IH0pO1xuICAgIH1cbn1cbiIsIjxmZC10YWItbGlzdCBtb2RlPVwicHJvY2Vzc1wiPlxuICAgIDxmZC10YWJcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbW9EYXRhTGlzdDsgbGV0IGluZGV4ID0gaW5kZXg7IGxldCBsYXN0ID0gbGFzdFwiXG4gICAgICAgIFtpZF09XCJpdGVtLklkXCJcbiAgICAgICAgW2FjdGl2ZV09XCJpdGVtLiRJc0NoZWNrZWRcIlxuICAgID5cbiAgICAgICAgPG5nLXRlbXBsYXRlIGZkLXRhYi10aXRsZS10ZW1wbGF0ZT5cbiAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uVGFiQ2hhbmdlMihpdGVtKVwiXG4gICAgICAgICAgICAgICAgZmQtdGFiLWljb25cbiAgICAgICAgICAgICAgICBbaWNvbl09XCIoZmllbGRJY29uIHwgcnZhbDogaXRlbTphbGxDb2x1bW5zKSA/IChmaWVsZEljb24gfCBydmFsOiBpdGVtOmFsbENvbHVtbnMpIDogZGVmYXVsdEljb25cIlxuICAgICAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgICAgIDxkaXYgZmQtdGFiLXByb2Nlc3MgKGNsaWNrKT1cIm9uVGFiQ2hhbmdlMihpdGVtKVwiPlxuICAgICAgICAgICAgICAgIDxzcGFuIGZkLXRhYi1sYWJlbD57eyBmaWVsZFRpdGxlIHwgcnZhbDogaXRlbTphbGxDb2x1bW5zIH19PC9zcGFuPlxuICAgICAgICAgICAgICAgIDxzcGFuIGZkLXRhYi1sYWJlbD57eyBmaWVsZFN1YnRpdGxlIHwgcnZhbDogaXRlbTphbGxDb2x1bW5zIH19PC9zcGFuPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgPC9mZC10YWI+XG48L2ZkLXRhYi1saXN0PlxuIl19