igniteui-angular 18.2.0-alpha.1 → 18.2.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/data-operations/filtering-condition.mjs +16 -3
- package/esm2022/lib/grids/filtering/grid-filtering.service.mjs +2 -2
- package/esm2022/lib/query-builder/public_api.mjs +2 -2
- package/esm2022/lib/query-builder/query-builder-tree.component.mjs +26 -20
- package/esm2022/lib/query-builder/query-builder.component.mjs +36 -2
- package/esm2022/lib/query-builder/query-builder.directives.mjs +3 -3
- package/fesm2022/igniteui-angular.mjs +79 -26
- package/fesm2022/igniteui-angular.mjs.map +1 -1
- package/lib/data-operations/filtering-condition.d.ts +14 -4
- package/lib/query-builder/query-builder-tree.component.d.ts +1 -1
- package/lib/query-builder/query-builder.component.d.ts +12 -1
- package/lib/query-builder/query-builder.directives.d.ts +2 -2
- package/package.json +1 -1
|
@@ -22,6 +22,40 @@ import * as i1 from "../icon/icon.service";
|
|
|
22
22
|
* ```
|
|
23
23
|
*/
|
|
24
24
|
export class IgxQueryBuilderComponent {
|
|
25
|
+
// /**
|
|
26
|
+
// * Returns the fields.
|
|
27
|
+
// */
|
|
28
|
+
// public get fields(): FieldType[] {
|
|
29
|
+
// return this._fields;
|
|
30
|
+
// }
|
|
31
|
+
// /**
|
|
32
|
+
// * Sets the fields.
|
|
33
|
+
// */
|
|
34
|
+
// @Input()
|
|
35
|
+
// public set fields(fields: FieldType[]) {
|
|
36
|
+
// this._fields = fields;
|
|
37
|
+
// if (this._fields) {
|
|
38
|
+
// this.registerSVGIcons();
|
|
39
|
+
// this._fields.forEach(field => {
|
|
40
|
+
// this.setFilters(field);
|
|
41
|
+
// this.setFormat(field);
|
|
42
|
+
// });
|
|
43
|
+
// }
|
|
44
|
+
// }
|
|
45
|
+
/**
|
|
46
|
+
* Returns the expression tree.
|
|
47
|
+
*/
|
|
48
|
+
get expressionTree() {
|
|
49
|
+
return this._expressionTree;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Sets the expression tree.
|
|
53
|
+
*/
|
|
54
|
+
set expressionTree(expressionTree) {
|
|
55
|
+
if (JSON.stringify(expressionTree) !== JSON.stringify(this._expressionTree)) {
|
|
56
|
+
this._expressionTree = expressionTree;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
25
59
|
/**
|
|
26
60
|
* Sets the resource strings.
|
|
27
61
|
* By default it uses EN resources.
|
|
@@ -103,7 +137,7 @@ export class IgxQueryBuilderComponent {
|
|
|
103
137
|
this.queryTree.setAddButtonFocus();
|
|
104
138
|
}
|
|
105
139
|
onExpressionTreeChange(tree) {
|
|
106
|
-
this.
|
|
140
|
+
this._expressionTree = tree;
|
|
107
141
|
this.expressionTreeChange.emit();
|
|
108
142
|
}
|
|
109
143
|
registerSVGIcons() {
|
|
@@ -188,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
|
|
|
188
222
|
type: ViewChild,
|
|
189
223
|
args: [IgxQueryBuilderTreeComponent]
|
|
190
224
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/query-builder/query-builder.component.ts","../../../../../projects/igniteui-angular/src/lib/query-builder/query-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ContentChild, EventEmitter, Output, TemplateRef } from '@angular/core';\nimport { NgIf, NgTemplateOutlet} from '@angular/common';\nimport {\n    Component, Input, ViewChild, ElementRef, OnDestroy, HostBinding\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { IQueryBuilderResourceStrings, QueryBuilderResourceStringsEN } from '../core/i18n/query-builder-resources';\nimport { IExpressionTree } from '../data-operations/filtering-expressions-tree';\nimport { IgxOverlayOutletDirective } from '../directives/toggle/toggle.directive';\nimport { EntityType } from '../grids/common/grid.interface';\nimport { IgxQueryBuilderHeaderComponent } from './query-builder-header.component';\nimport { getCurrentResourceStrings } from '../core/i18n/resources';\nimport { IgxQueryBuilderTreeComponent } from './query-builder-tree.component';\nimport { IgxIconService } from '../icon/icon.service';\nimport { editor } from '@igniteui/material-icons-extended';\nimport { IgxQueryBuilderSearchValueTemplateDirective } from './query-builder.directives';\n\n/**\n * A component used for operating with complex filters by creating or editing conditions\n * and grouping them using AND/OR logic.\n * It is used internally in the Advanced Filtering of the Grid.\n *\n * @example\n * ```html\n * <igx-query-builder [fields]=\"this.fields\">\n * </igx-query-builder>\n * ```\n */\n@Component({\n    selector: 'igx-query-builder',\n    templateUrl: './query-builder.component.html',\n    standalone: true,\n    imports: [NgIf, IgxQueryBuilderHeaderComponent, IgxQueryBuilderTreeComponent, NgTemplateOutlet, IgxQueryBuilderSearchValueTemplateDirective]\n})\nexport class IgxQueryBuilderComponent implements OnDestroy {\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-query-builder')\n    public cssClass = 'igx-query-builder';\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('style.display')\n    public display = 'block';\n\n    @Input()\n    public entities: EntityType[];\n\n    // /**\n    // * Returns the fields.\n    // */\n    // public get fields(): FieldType[] {\n    //     return this._fields;\n    // }\n\n    // /**\n    //  * Sets the fields.\n    //  */\n    // @Input()\n    // public set fields(fields: FieldType[]) {\n    //     this._fields = fields;\n\n    //     if (this._fields) {\n    //         this.registerSVGIcons();\n\n    //         this._fields.forEach(field => {\n    //             this.setFilters(field);\n    //             this.setFormat(field);\n    //         });\n    //     }\n    // }\n\n\n    @Input()\n    public expressionTree: IExpressionTree;\n\n    /**\n     * Gets the `locale` of the query builder.\n     * If not set, defaults to application's locale.\n     */\n    @Input()\n    public locale: string;\n\n    /**\n     * Sets the resource strings.\n     * By default it uses EN resources.\n     */\n    @Input()\n    public set resourceStrings(value: IQueryBuilderResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * Returns the resource strings.\n     */\n    public get resourceStrings(): IQueryBuilderResourceStrings {\n        return this._resourceStrings;\n    }\n\n    /**\n     * Event fired as the expression tree is changed.\n     *\n     * ```html\n     *  <igx-query-builder (expressionTreeChange)='onExpressionTreeChange()'></igx-query-builder>\n     * ```\n     */\n    @Output()\n    public expressionTreeChange = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxQueryBuilderHeaderComponent)\n    public headerContent: IgxQueryBuilderHeaderComponent;\n\n    @ContentChild(IgxQueryBuilderSearchValueTemplateDirective, { read: TemplateRef })\n    public searchValueTemplate: TemplateRef<any>;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild(IgxQueryBuilderTreeComponent)\n    public queryTree: IgxQueryBuilderTreeComponent;\n\n    private destroy$ = new Subject<any>();\n    private _resourceStrings = getCurrentResourceStrings(QueryBuilderResourceStringsEN);\n\n    constructor(protected iconService: IgxIconService) {\n        this.registerSVGIcons();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public setPickerOutlet(outlet?: IgxOverlayOutletDirective | ElementRef) {\n        this.queryTree.setPickerOutlet(outlet);\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public get isContextMenuVisible(): boolean {\n        return this.queryTree.isContextMenuVisible;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public clearSelection() {\n        this.queryTree.clearSelection();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public exitOperandEdit() {\n        this.queryTree.exitOperandEdit();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public setAddButtonFocus() {\n        this.queryTree.setAddButtonFocus();\n    }\n\n    public onExpressionTreeChange(tree: IExpressionTree) {\n        this.expressionTree = tree;\n        this.expressionTreeChange.emit();\n    }\n\n    private registerSVGIcons(): void {\n        const editorIcons = editor as any[];\n\n        editorIcons.forEach((icon) => {\n            this.iconService.addSvgIconFromText(icon.name, icon.value, 'imx-icons');\n            this.iconService.addIconRef(icon.name, 'default', {\n                name: icon.name,\n                family: 'imx-icons'\n            });\n        });\n\n        const inIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M560-280H120v-400h720v120h-80v-40H200v240h360v80Zm-360-80v-240 240Zm560 200v-120H640v-80h120v-120h80v120h120v80H840v120h-80Z\"/></svg>';\n        this.iconService.addSvgIconFromText('in', inIcon, 'imx-icons');\n        this.iconService.addIconRef('in', 'default', {\n            name: 'in',\n            family: 'imx-icons'\n        });\n\n        const notInIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M560-280H120v-400h720v120h-80v-40H200v240h360v80Zm-360-80v-240 240Zm440 104 84-84-84-84 56-56 84 84 84-84 56 56-83 84 83 84-56 56-84-83-84 83-56-56Z\"/></svg>';\n        this.iconService.addSvgIconFromText('not-in', notInIcon, 'imx-icons');\n        this.iconService.addIconRef('not-in', 'default', {\n            name: 'not-in',\n            family: 'imx-icons'\n        });\n\n        this.iconService.addIconRef('add', 'default', {\n            name: 'add',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('close', 'default', {\n            name: 'close',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('check', 'default', {\n            name: 'check',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('delete', 'default', {\n            name: 'delete',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('edit', 'default', {\n            name: 'edit',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('unfold_less', 'default', {\n            name: 'unfold_less',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('unfold_more', 'default', {\n            name: 'unfold_more',\n            family: 'material',\n        });\n    }\n}\n\n","<igx-query-builder-header\n    *ngIf=\"!headerContent\"\n    [title]=\"this.resourceStrings.igx_query_builder_title\"\n>\n</igx-query-builder-header>\n\n<ng-content select=\"igx-query-builder-header\"></ng-content>\n\n<igx-query-builder-tree\n    [entities]=\"this.entities\"\n    [expressionTree]=\"this.expressionTree\"\n    [locale]=\"this.locale\"\n    [resourceStrings]=\"this.resourceStrings\"\n    (expressionTreeChange)=\"onExpressionTreeChange($event)\"\n    [searchValueTemplate]=\"searchValueTemplate\">\n</igx-query-builder-tree>\n\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/query-builder/query-builder.component.ts","../../../../../projects/igniteui-angular/src/lib/query-builder/query-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ContentChild, EventEmitter, Output, TemplateRef } from '@angular/core';\nimport { NgIf, NgTemplateOutlet} from '@angular/common';\nimport {\n    Component, Input, ViewChild, ElementRef, OnDestroy, HostBinding\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { IQueryBuilderResourceStrings, QueryBuilderResourceStringsEN } from '../core/i18n/query-builder-resources';\nimport { IExpressionTree } from '../data-operations/filtering-expressions-tree';\nimport { IgxOverlayOutletDirective } from '../directives/toggle/toggle.directive';\nimport { EntityType } from '../grids/common/grid.interface';\nimport { IgxQueryBuilderHeaderComponent } from './query-builder-header.component';\nimport { getCurrentResourceStrings } from '../core/i18n/resources';\nimport { IgxQueryBuilderTreeComponent } from './query-builder-tree.component';\nimport { IgxIconService } from '../icon/icon.service';\nimport { editor } from '@igniteui/material-icons-extended';\nimport { IgxQueryBuilderSearchValueTemplateDirective } from './query-builder.directives';\n\n/**\n * A component used for operating with complex filters by creating or editing conditions\n * and grouping them using AND/OR logic.\n * It is used internally in the Advanced Filtering of the Grid.\n *\n * @example\n * ```html\n * <igx-query-builder [fields]=\"this.fields\">\n * </igx-query-builder>\n * ```\n */\n@Component({\n    selector: 'igx-query-builder',\n    templateUrl: './query-builder.component.html',\n    standalone: true,\n    imports: [NgIf, IgxQueryBuilderHeaderComponent, IgxQueryBuilderTreeComponent, NgTemplateOutlet, IgxQueryBuilderSearchValueTemplateDirective]\n})\nexport class IgxQueryBuilderComponent implements OnDestroy {\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-query-builder')\n    public cssClass = 'igx-query-builder';\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('style.display')\n    public display = 'block';\n\n    @Input()\n    public entities: EntityType[];\n\n    // /**\n    // * Returns the fields.\n    // */\n    // public get fields(): FieldType[] {\n    //     return this._fields;\n    // }\n\n    // /**\n    //  * Sets the fields.\n    //  */\n    // @Input()\n    // public set fields(fields: FieldType[]) {\n    //     this._fields = fields;\n\n    //     if (this._fields) {\n    //         this.registerSVGIcons();\n\n    //         this._fields.forEach(field => {\n    //             this.setFilters(field);\n    //             this.setFormat(field);\n    //         });\n    //     }\n    // }\n\n    /**\n    * Returns the expression tree.\n    */\n    public get expressionTree(): IExpressionTree {\n        return this._expressionTree;\n    }\n\n    /**\n     * Sets the expression tree.\n     */\n    @Input()\n    public set expressionTree(expressionTree: IExpressionTree) {\n        if (JSON.stringify(expressionTree) !== JSON.stringify(this._expressionTree)) {\n            this._expressionTree = expressionTree;\n        }\n    }\n\n    /**\n     * Gets the `locale` of the query builder.\n     * If not set, defaults to application's locale.\n     */\n    @Input()\n    public locale: string;\n\n    /**\n     * Sets the resource strings.\n     * By default it uses EN resources.\n     */\n    @Input()\n    public set resourceStrings(value: IQueryBuilderResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * Returns the resource strings.\n     */\n    public get resourceStrings(): IQueryBuilderResourceStrings {\n        return this._resourceStrings;\n    }\n\n    /**\n     * Event fired as the expression tree is changed.\n     *\n     * ```html\n     *  <igx-query-builder (expressionTreeChange)='onExpressionTreeChange()'></igx-query-builder>\n     * ```\n     */\n    @Output()\n    public expressionTreeChange = new EventEmitter();\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxQueryBuilderHeaderComponent)\n    public headerContent: IgxQueryBuilderHeaderComponent;\n\n    /**\n     * @hidden @internal\n     */\n    @ContentChild(IgxQueryBuilderSearchValueTemplateDirective, { read: TemplateRef })\n    public searchValueTemplate: TemplateRef<any>;\n\n    /**\n     * @hidden @internal\n     */\n    @ViewChild(IgxQueryBuilderTreeComponent)\n    public queryTree: IgxQueryBuilderTreeComponent;\n\n    private destroy$ = new Subject<any>();\n    private _resourceStrings = getCurrentResourceStrings(QueryBuilderResourceStringsEN);\n    private _expressionTree: IExpressionTree;\n\n    constructor(protected iconService: IgxIconService) {\n        this.registerSVGIcons();\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public setPickerOutlet(outlet?: IgxOverlayOutletDirective | ElementRef) {\n        this.queryTree.setPickerOutlet(outlet);\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public get isContextMenuVisible(): boolean {\n        return this.queryTree.isContextMenuVisible;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public clearSelection() {\n        this.queryTree.clearSelection();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public exitOperandEdit() {\n        this.queryTree.exitOperandEdit();\n    }\n\n    /**\n     * @hidden @internal\n     *\n     * used by the grid\n     */\n    public setAddButtonFocus() {\n        this.queryTree.setAddButtonFocus();\n    }\n\n    public onExpressionTreeChange(tree: IExpressionTree) {\n        this._expressionTree = tree;\n        this.expressionTreeChange.emit();\n    }\n\n    private registerSVGIcons(): void {\n        const editorIcons = editor as any[];\n\n        editorIcons.forEach((icon) => {\n            this.iconService.addSvgIconFromText(icon.name, icon.value, 'imx-icons');\n            this.iconService.addIconRef(icon.name, 'default', {\n                name: icon.name,\n                family: 'imx-icons'\n            });\n        });\n\n        const inIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M560-280H120v-400h720v120h-80v-40H200v240h360v80Zm-360-80v-240 240Zm560 200v-120H640v-80h120v-120h80v120h120v80H840v120h-80Z\"/></svg>';\n        this.iconService.addSvgIconFromText('in', inIcon, 'imx-icons');\n        this.iconService.addIconRef('in', 'default', {\n            name: 'in',\n            family: 'imx-icons'\n        });\n\n        const notInIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M560-280H120v-400h720v120h-80v-40H200v240h360v80Zm-360-80v-240 240Zm440 104 84-84-84-84 56-56 84 84 84-84 56 56-83 84 83 84-56 56-84-83-84 83-56-56Z\"/></svg>';\n        this.iconService.addSvgIconFromText('not-in', notInIcon, 'imx-icons');\n        this.iconService.addIconRef('not-in', 'default', {\n            name: 'not-in',\n            family: 'imx-icons'\n        });\n\n        this.iconService.addIconRef('add', 'default', {\n            name: 'add',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('close', 'default', {\n            name: 'close',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('check', 'default', {\n            name: 'check',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('delete', 'default', {\n            name: 'delete',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('edit', 'default', {\n            name: 'edit',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('unfold_less', 'default', {\n            name: 'unfold_less',\n            family: 'material',\n        });\n\n        this.iconService.addIconRef('unfold_more', 'default', {\n            name: 'unfold_more',\n            family: 'material',\n        });\n    }\n}\n\n","<igx-query-builder-header\n    *ngIf=\"!headerContent\"\n    [title]=\"this.resourceStrings.igx_query_builder_title\"\n>\n</igx-query-builder-header>\n\n<ng-content select=\"igx-query-builder-header\"></ng-content>\n\n<igx-query-builder-tree\n    [entities]=\"this.entities\"\n    [expressionTree]=\"this.expressionTree\"\n    [locale]=\"this.locale\"\n    [resourceStrings]=\"this.resourceStrings\"\n    (expressionTreeChange)=\"onExpressionTreeChange($event)\"\n    [searchValueTemplate]=\"searchValueTemplate\">\n</igx-query-builder-tree>\n\n"]}
|
|
@@ -9,8 +9,8 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
*
|
|
10
10
|
* @example
|
|
11
11
|
* <igx-query-builder>
|
|
12
|
-
* <ng-template igxQueryBuilderSearchValue let-
|
|
13
|
-
* <
|
|
12
|
+
* <ng-template igxQueryBuilderSearchValue let-expression="expression">
|
|
13
|
+
* <input type="text" required [(ngModel)]="expression.searchVal"/>
|
|
14
14
|
* </ng-template>
|
|
15
15
|
* </igx-query-builder>
|
|
16
16
|
*/
|
|
@@ -28,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
|
|
|
28
28
|
standalone: true
|
|
29
29
|
}]
|
|
30
30
|
}], ctorParameters: () => [{ type: i0.TemplateRef }] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktYnVpbGRlci5kaXJlY3RpdmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaWduaXRldWktYW5ndWxhci9zcmMvbGliL3F1ZXJ5LWJ1aWxkZXIvcXVlcnktYnVpbGRlci5kaXJlY3RpdmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWUsTUFBTSxlQUFlLENBQUM7O0FBRXZEOzs7Ozs7Ozs7Ozs7O0dBYUc7QUFLSCxNQUFNLE9BQU8sMkNBQTJDO0lBQ3BELFlBQW1CLFFBQTBCO1FBQTFCLGFBQVEsR0FBUixRQUFRLENBQWtCO0lBQUksQ0FBQzs4R0FEekMsMkNBQTJDO2tHQUEzQywyQ0FBMkM7OzJGQUEzQywyQ0FBMkM7a0JBSnZELFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDhCQUE4QjtvQkFDeEMsVUFBVSxFQUFFLElBQUk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIERlZmluZXMgdGhlIGN1c3RvbSB0ZW1wbGF0ZSB0aGF0IHdpbGwgYmUgdXNlZCBmb3IgdGhlIHNlYXJjaCB2YWx1ZSBpbnB1dCBvZiBjb25kaXRpb24gaW4gZWRpdCBtb2RlXG4gKiBcbiAqIEBpZ3hNb2R1bGUgSWd4UXVlcnlCdWlsZGVyTW9kdWxlXG4gKiBAaWd4S2V5d29yZHMgcXVlcnkgYnVpbGRlciwgcXVlcnkgYnVpbGRlciBzZWFyY2ggdmFsdWVcbiAqIEBpZ3hHcm91cCBEYXRhIGVudHJ5IGFuZCBkaXNwbGF5XG4gKlxuICogQGV4YW1wbGVcbiAqIDxpZ3gtcXVlcnktYnVpbGRlcj5cbiAqICAgICAgPG5nLXRlbXBsYXRlIGlneFF1ZXJ5QnVpbGRlclNlYXJjaFZhbHVlIGxldC1leHByZXNzaW9uPVwiZXhwcmVzc2lvblwiPlxuICogICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgcmVxdWlyZWQgWyhuZ01vZGVsKV09XCJleHByZXNzaW9uLnNlYXJjaFZhbFwiLz5cbiAqICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAqICA8L2lneC1xdWVyeS1idWlsZGVyPlxuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tpZ3hRdWVyeUJ1aWxkZXJTZWFyY2hWYWx1ZV0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgSWd4UXVlcnlCdWlsZGVyU2VhcmNoVmFsdWVUZW1wbGF0ZURpcmVjdGl2ZSB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7IH1cbn1cbiJdfQ==
|