@eui/mobile-core 18.0.3-snapshot-1744692867885 → 18.0.3-snapshot-1744978457758
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/docs/components/EuimToolbarComponent.html +45 -2
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.mjs +5 -3
- package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar.component.mjs +16 -9
- package/fesm2022/eui-mobile-core.mjs +70 -61
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.d.ts.map +1 -1
- package/lib/components/layout/euim-toolbar/euim-toolbar.component.d.ts +3 -0
- package/lib/components/layout/euim-toolbar/euim-toolbar.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -53,8 +53,10 @@ export class EuimSidebarContentComponent {
|
|
|
53
53
|
});
|
|
54
54
|
}
|
|
55
55
|
filterMenuItems(items, searchPhrase) {
|
|
56
|
-
return items.filter(
|
|
57
|
-
|
|
56
|
+
return items.filter(component => {
|
|
57
|
+
const labelMatch = component.label?.toLowerCase().includes(searchPhrase);
|
|
58
|
+
const typeMatch = component.type?.toLowerCase().includes(searchPhrase);
|
|
59
|
+
return labelMatch || typeMatch;
|
|
58
60
|
});
|
|
59
61
|
}
|
|
60
62
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimSidebarContentComponent, deps: [{ token: i1.I18nService }, { token: i1.EuiAppShellService }, { token: i2.MenuController }, { token: i2.NavController }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -81,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
81
83
|
type: ViewChild,
|
|
82
84
|
args: [IonSearchbar, { static: false }]
|
|
83
85
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-sidebar-content.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.ts","../../../../../../../src/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ViewChild, Output, EventEmitter, Component, HostBinding, Input, OnInit, booleanAttribute } from '@angular/core';\nimport { I18nService, EuiAppShellService } from '@eui/core';\nimport { NavController, MenuController, IonSearchbar } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\n\nexport type IconColor = 'primary' | 'default' | 'info' | 'success' | 'warning' | 'danger' | 'dark' | 'white' | 'accent' | 'secondary';\n@Component({\n    selector: 'euim-sidebar-content',\n    templateUrl: './euim-sidebar-content.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EuimSidebarContentComponent implements OnInit {\n    @HostBinding() className = 'euim-sidebar-content';\n    @Input() sidebarItems: MenuItem[] = [];\n    @Input() ionMenuId = 'main';\n    @Input({ transform: booleanAttribute })\n    hasSearchbar: BooleanInput = false;\n    @Input({ transform: booleanAttribute })\n    isSearchbarSticky: BooleanInput = false;\n    @Output() sidebarItemsFilter = new EventEmitter<MenuItem[]>();\n    @ViewChild(IonSearchbar, { static: false }) searchbar: IonSearchbar;\n\n    protected filteredItems: MenuItem[] = [];\n    protected query ='';\n\n    constructor(private i18nService: I18nService,\n        public asService: EuiAppShellService,\n        private menuCtrl: MenuController,\n        private navCtrl: NavController) {\n            i18nService.init().subscribe();\n    }\n\n    ngOnInit(): void {\n        this.sortSidebarItems();\n\n        if (this.hasSearchbar) {\n            this.filteredItems = [...this.sidebarItems];\n            this.sidebarItemsFilter.emit(this.filteredItems);\n        }\n    }\n\n    handleInput(event: CustomEvent): void {\n        this.query = event.detail.value.toLowerCase();\n        this.filteredItems = this.filterMenuItems(this.sidebarItems, this.query);\n        this.sidebarItemsFilter.emit(this.filteredItems);\n\n        if (this.query === '') {\n            this.sidebarItemsFilter.emit(this.sidebarItems);\n        }\n    }\n\n    closeMenu(): void {\n        if (!this.hasSearchbar) return;\n\n        this.menuCtrl.close().then(() => {\n            this.sidebarItemsFilter.emit(this.sidebarItems);\n            this.query = '';\n            this.searchbar.value = '';\n        });\n    }\n\n    protected sortSidebarItems(): void {\n        this.sidebarItems.sort((a, b) => {\n            if (a.group === b.group) {\n                return a.label.localeCompare(b.label);\n            }\n            return a.group - b.group;\n        });\n    }\n    protected filterMenuItems(items, searchPhrase: string): MenuItem[] {\n        return items.filter(component => {\n            const labelMatch = component.label?.toLowerCase().includes(searchPhrase);\n            const typeMatch = component.type?.toLowerCase().includes(searchPhrase);\n\n            return labelMatch || typeMatch;\n        });\n    }\n}\n\ninterface MenuItem {\n    icon?: string;\n    iconColor?: IconColor;\n    label: string;\n    url?: string;\n    isSection?: boolean;\n    section?: string;\n    group?: number;\n    groupHeader?: string;\n}\n\n","<ion-list class=\"euim-sidebar-content__list\">\n    @if (hasSearchbar) {\n        <div class=\"euim-sidebar-content__searchbar\" [ngClass]=\"{ 'euim-sidebar-content__searchbar--sticky': isSearchbarSticky }\">\n            <ion-searchbar (ionInput)=\"handleInput($event)\"></ion-searchbar>\n        </div>\n    }\n    <ion-menu-toggle auto-hide=\"true\" (click)=\"closeMenu()\" menu=\"{{ionMenuId}}\">\n        <ng-content></ng-content>\n    </ion-menu-toggle>\n</ion-list>\n\n"]}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { Component, ChangeDetectionStrategy, EventEmitter, HostBinding, Input, Output, ViewEncapsulation, booleanAttribute, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular
|
|
4
|
-
import * as i2 from "@
|
|
3
|
+
import * as i1 from "@ionic/angular";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
5
|
import * as i3 from "../euim-language-selector/euim-language-selector.component";
|
|
6
6
|
export class EuimToolbarComponent {
|
|
7
|
-
constructor() {
|
|
7
|
+
constructor(navCtrl) {
|
|
8
|
+
this.navCtrl = navCtrl;
|
|
8
9
|
this.hasBackButton = true;
|
|
9
|
-
this.backButtonDefaultHref = '
|
|
10
|
+
this.backButtonDefaultHref = '';
|
|
10
11
|
this.ionMenuId = 'main';
|
|
11
12
|
this.hasSidebarTrigger = false;
|
|
12
13
|
this.hasLanguageSelector = false;
|
|
@@ -20,14 +21,20 @@ export class EuimToolbarComponent {
|
|
|
20
21
|
}
|
|
21
22
|
onBackButtonClick(event) {
|
|
22
23
|
this.backButtonClick.emit(event);
|
|
24
|
+
if (window.history.length > 1) {
|
|
25
|
+
this.navCtrl.back();
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
this.navCtrl.navigateBack('/');
|
|
29
|
+
}
|
|
23
30
|
}
|
|
24
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
25
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: EuimToolbarComponent, selector: "euim-toolbar", inputs: { hasBackButton: ["hasBackButton", "hasBackButton", booleanAttribute], backButtonDefaultHref: "backButtonDefaultHref", ionMenuId: "ionMenuId", hasSidebarTrigger: ["hasSidebarTrigger", "hasSidebarTrigger", booleanAttribute], hasLanguageSelector: ["hasLanguageSelector", "hasLanguageSelector", booleanAttribute] }, outputs: { backButtonClick: "backButtonClick" }, host: { properties: { "className": "this.className" } }, ngImport: i0, template: "<ion-buttons slot=\"start\">\n <ion-menu-button *ngIf=\"hasSidebarTrigger\" [menu]=\"ionMenuId\"></ion-menu-button>\n <ion-back-button (
|
|
31
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimToolbarComponent, deps: [{ token: i1.NavController }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
32
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: EuimToolbarComponent, selector: "euim-toolbar", inputs: { hasBackButton: ["hasBackButton", "hasBackButton", booleanAttribute], backButtonDefaultHref: "backButtonDefaultHref", ionMenuId: "ionMenuId", hasSidebarTrigger: ["hasSidebarTrigger", "hasSidebarTrigger", booleanAttribute], hasLanguageSelector: ["hasLanguageSelector", "hasLanguageSelector", booleanAttribute] }, outputs: { backButtonClick: "backButtonClick" }, host: { properties: { "className": "this.className" } }, ngImport: i0, template: "<ion-buttons slot=\"start\">\n <ion-menu-button *ngIf=\"hasSidebarTrigger\" [menu]=\"ionMenuId\"></ion-menu-button>\n <ion-back-button (click)=\"onBackButtonClick($event)\"\n *ngIf=\"hasBackButton\"\n defaultHref=\"{{backButtonDefaultHref}}\"></ion-back-button>\n <ng-content></ng-content>\n</ion-buttons>\n<ion-title class=\"euim-toolbar__title-container\">\n <ng-content select=\"euim-toolbar-title\"></ng-content>\n</ion-title>\n<ion-buttons slot=\"end\">\n <ng-content select=\"euim-toolbar-action-items\"></ng-content>\n <ng-container *ngIf=\"hasLanguageSelector\">\n <euim-language-selector></euim-language-selector>\n </ng-container>\n</ion-buttons>\n", styles: [".euim-toolbar{display:flex;align-items:center}.euim-toolbar__title-container{text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:flex;align-items:center;padding-inline:var(--eui-s-s)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i1.IonMenuButton, selector: "ion-menu-button", inputs: ["autoHide", "color", "disabled", "menu", "mode", "type"] }, { kind: "component", type: i1.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: i1.IonBackButton, selector: "ion-back-button" }, { kind: "component", type: i3.EuimLanguageSelectorComponent, selector: "euim-language-selector", inputs: ["hasSearchbar"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
26
33
|
}
|
|
27
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimToolbarComponent, decorators: [{
|
|
28
35
|
type: Component,
|
|
29
|
-
args: [{ selector: 'euim-toolbar', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-buttons slot=\"start\">\n <ion-menu-button *ngIf=\"hasSidebarTrigger\" [menu]=\"ionMenuId\"></ion-menu-button>\n <ion-back-button (
|
|
30
|
-
}], propDecorators: { hasBackButton: [{
|
|
36
|
+
args: [{ selector: 'euim-toolbar', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-buttons slot=\"start\">\n <ion-menu-button *ngIf=\"hasSidebarTrigger\" [menu]=\"ionMenuId\"></ion-menu-button>\n <ion-back-button (click)=\"onBackButtonClick($event)\"\n *ngIf=\"hasBackButton\"\n defaultHref=\"{{backButtonDefaultHref}}\"></ion-back-button>\n <ng-content></ng-content>\n</ion-buttons>\n<ion-title class=\"euim-toolbar__title-container\">\n <ng-content select=\"euim-toolbar-title\"></ng-content>\n</ion-title>\n<ion-buttons slot=\"end\">\n <ng-content select=\"euim-toolbar-action-items\"></ng-content>\n <ng-container *ngIf=\"hasLanguageSelector\">\n <euim-language-selector></euim-language-selector>\n </ng-container>\n</ion-buttons>\n", styles: [".euim-toolbar{display:flex;align-items:center}.euim-toolbar__title-container{text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:flex;align-items:center;padding-inline:var(--eui-s-s)}\n"] }]
|
|
37
|
+
}], ctorParameters: () => [{ type: i1.NavController }], propDecorators: { hasBackButton: [{
|
|
31
38
|
type: Input,
|
|
32
39
|
args: [{ transform: booleanAttribute }]
|
|
33
40
|
}], backButtonDefaultHref: [{
|
|
@@ -45,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
45
52
|
}], className: [{
|
|
46
53
|
type: HostBinding
|
|
47
54
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9sYXlvdXQvZXVpbS10b29sYmFyL2V1aW0tdG9vbGJhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2V1aW0tdG9vbGJhci9ldWltLXRvb2xiYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsWUFBWSxFQUNaLFdBQVcsRUFDWCxLQUFLLEVBRUwsTUFBTSxFQUNOLGlCQUFpQixFQUNqQixnQkFBZ0IsR0FDbkIsTUFBTSxlQUFlLENBQUM7Ozs7O0FBVXZCLE1BQU0sT0FBTyxvQkFBb0I7SUFjN0IsWUFBb0IsT0FBc0I7UUFBdEIsWUFBTyxHQUFQLE9BQU8sQ0FBZTtRQVgxQyxrQkFBYSxHQUFHLElBQUksQ0FBQztRQUNaLDBCQUFxQixHQUFHLEVBQUUsQ0FBQztRQUMzQixjQUFTLEdBQUcsTUFBTSxDQUFDO1FBRTVCLHNCQUFpQixHQUFHLEtBQUssQ0FBQztRQUUxQix3QkFBbUIsR0FBRyxLQUFLLENBQUM7UUFFbEIsb0JBQWUsR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUVyRCxjQUFTLEdBQUcsY0FBYyxDQUFDO0lBQ0csQ0FBQztJQUU5QyxRQUFRO1FBQ0osSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztRQUMvQixDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQVk7UUFDMUIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFakMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3hCLENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkMsQ0FBQztJQUNMLENBQUM7a0lBOUJRLG9CQUFvQjtzSEFBcEIsb0JBQW9CLHdGQUVULGdCQUFnQix5SUFJaEIsZ0JBQWdCLHVFQUVoQixnQkFBZ0IsdUlDNUJ4Qyx3dEJBZ0JBOzs0RkRJYSxvQkFBb0I7a0JBUGhDLFNBQVM7K0JBQ0ksY0FBYyxpQkFHVCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNO2tGQUsvQyxhQUFhO3NCQURaLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBRTdCLHFCQUFxQjtzQkFBN0IsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVOLGlCQUFpQjtzQkFEaEIsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFHdEMsbUJBQW1CO3NCQURsQixLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUc1QixlQUFlO3NCQUF4QixNQUFNO2dCQUVRLFNBQVM7c0JBQXZCLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbXBvbmVudCxcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSW5wdXQsXG4gICAgT25Jbml0LFxuICAgIE91dHB1dCxcbiAgICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgICBib29sZWFuQXR0cmlidXRlLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5hdkNvbnRyb2xsZXIgfSBmcm9tICdAaW9uaWMvYW5ndWxhcic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXVpbS10b29sYmFyJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2V1aW0tdG9vbGJhci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc3R5bGVzL19pbmRleC5zY3NzJ10sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbVRvb2xiYXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgaGFzQmFja0J1dHRvbiA9IHRydWU7XG4gICAgQElucHV0KCkgYmFja0J1dHRvbkRlZmF1bHRIcmVmID0gJyc7XG4gICAgQElucHV0KCkgaW9uTWVudUlkID0gJ21haW4nO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KVxuICAgIGhhc1NpZGViYXJUcmlnZ2VyID0gZmFsc2U7XG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgaGFzTGFuZ3VhZ2VTZWxlY3RvciA9IGZhbHNlO1xuXG4gICAgQE91dHB1dCgpIGJhY2tCdXR0b25DbGljazogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIEBIb3N0QmluZGluZygpIGNsYXNzTmFtZSA9ICdldWltLXRvb2xiYXInO1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmF2Q3RybDogTmF2Q29udHJvbGxlcikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5oYXNTaWRlYmFyVHJpZ2dlcikge1xuICAgICAgICAgICAgdGhpcy5oYXNCYWNrQnV0dG9uID0gZmFsc2U7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBvbkJhY2tCdXR0b25DbGljayhldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5iYWNrQnV0dG9uQ2xpY2suZW1pdChldmVudCk7XG5cbiAgICAgICAgaWYgKHdpbmRvdy5oaXN0b3J5Lmxlbmd0aCA+IDEpIHtcbiAgICAgICAgICAgIHRoaXMubmF2Q3RybC5iYWNrKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5hdkN0cmwubmF2aWdhdGVCYWNrKCcvJyk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8aW9uLWJ1dHRvbnMgc2xvdD1cInN0YXJ0XCI+XG4gICAgPGlvbi1tZW51LWJ1dHRvbiAqbmdJZj1cImhhc1NpZGViYXJUcmlnZ2VyXCIgW21lbnVdPVwiaW9uTWVudUlkXCI+PC9pb24tbWVudS1idXR0b24+XG4gICAgPGlvbi1iYWNrLWJ1dHRvbiAoY2xpY2spPVwib25CYWNrQnV0dG9uQ2xpY2soJGV2ZW50KVwiXG4gICAgICAgICAgICAgICAgICAgICAqbmdJZj1cImhhc0JhY2tCdXR0b25cIlxuICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdEhyZWY9XCJ7e2JhY2tCdXR0b25EZWZhdWx0SHJlZn19XCI+PC9pb24tYmFjay1idXR0b24+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9pb24tYnV0dG9ucz5cbjxpb24tdGl0bGUgY2xhc3M9XCJldWltLXRvb2xiYXJfX3RpdGxlLWNvbnRhaW5lclwiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImV1aW0tdG9vbGJhci10aXRsZVwiPjwvbmctY29udGVudD5cbjwvaW9uLXRpdGxlPlxuPGlvbi1idXR0b25zIHNsb3Q9XCJlbmRcIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJldWltLXRvb2xiYXItYWN0aW9uLWl0ZW1zXCI+PC9uZy1jb250ZW50PlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJoYXNMYW5ndWFnZVNlbGVjdG9yXCI+XG4gICAgICAgIDxldWltLWxhbmd1YWdlLXNlbGVjdG9yPjwvZXVpbS1sYW5ndWFnZS1zZWxlY3Rvcj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbjwvaW9uLWJ1dHRvbnM+XG4iXX0=
|