@fundamental-ngx/core 0.46.1-rc.3 → 0.46.1-rc.5
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/carousel/carousel-item/carousel-item.component.d.ts +1 -1
- package/carousel/carousel.component.d.ts +7 -15
- package/esm2022/carousel/carousel-item/carousel-item.component.mjs +3 -3
- package/esm2022/carousel/carousel.component.mjs +40 -37
- package/esm2022/list/list-navigation-item/list-navigation-item.component.mjs +15 -8
- package/esm2022/vertical-navigation/vertical-navigation.component.mjs +38 -13
- package/fesm2022/fundamental-ngx-core-carousel.mjs +37 -34
- package/fesm2022/fundamental-ngx-core-carousel.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-core-list.mjs +14 -7
- package/fesm2022/fundamental-ngx-core-list.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-core-vertical-navigation.mjs +37 -12
- package/fesm2022/fundamental-ngx-core-vertical-navigation.mjs.map +1 -1
- package/fundamental-ngx-core-v0.46.1-rc.5.tgz +0 -0
- package/list/list-navigation-item/list-navigation-item.component.d.ts +4 -2
- package/package.json +3 -3
- package/schematics/add-dependencies/index.js +4 -4
- package/vertical-navigation/vertical-navigation.component.d.ts +17 -8
- package/fundamental-ngx-core-v0.46.1-rc.3.tgz +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ElementRef } from '@angular/core';
|
|
2
|
-
import { CarouselItemInterface } from '../carousel.service';
|
|
3
2
|
import { Nullable } from '@fundamental-ngx/cdk/utils';
|
|
3
|
+
import { CarouselItemInterface } from '../carousel.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export type Visibility = 'visible' | 'hidden';
|
|
6
6
|
export declare class CarouselItemComponent implements CarouselItemInterface {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, OnInit, QueryList, Renderer2, SimpleChanges } from '@angular/core';
|
|
2
1
|
import { Direction } from '@angular/cdk/bidi';
|
|
2
|
+
import { AfterContentInit, AfterViewChecked, AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnInit, QueryList, Renderer2, SimpleChanges } from '@angular/core';
|
|
3
3
|
import { RtlService } from '@fundamental-ngx/cdk/utils';
|
|
4
4
|
import { CarouselItemComponent } from './carousel-item/carousel-item.component';
|
|
5
|
-
import { FdCarouselResourceStrings } from './i18n/carousel-resources';
|
|
6
5
|
import { CarouselService } from './carousel.service';
|
|
6
|
+
import { FdCarouselResourceStrings } from './i18n/carousel-resources';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export type PageIndicatorsOrientation = 'bottom' | 'top';
|
|
9
9
|
export type CarouselBackgroundOptions = 'translucent' | 'transparent' | 'solid';
|
|
@@ -21,7 +21,7 @@ declare class CarouselActiveSlides {
|
|
|
21
21
|
readonly slideDirection: string;
|
|
22
22
|
constructor(activeItems: CarouselItemComponent[], slideDirection: string);
|
|
23
23
|
}
|
|
24
|
-
export declare class CarouselComponent implements OnInit, AfterContentInit, AfterViewInit, AfterViewChecked, OnChanges
|
|
24
|
+
export declare class CarouselComponent implements OnInit, AfterContentInit, AfterViewInit, AfterViewChecked, OnChanges {
|
|
25
25
|
private readonly _elementRef;
|
|
26
26
|
private readonly _renderer;
|
|
27
27
|
private readonly _changeDetectorRef;
|
|
@@ -101,10 +101,6 @@ export declare class CarouselComponent implements OnInit, AfterContentInit, Afte
|
|
|
101
101
|
/** @hidden */
|
|
102
102
|
get _contentSizePx(): string;
|
|
103
103
|
/** @hidden */
|
|
104
|
-
private _rightNavigationBtnLabel;
|
|
105
|
-
/** @hidden */
|
|
106
|
-
private _leftNavigationBtnLabel;
|
|
107
|
-
/** @hidden */
|
|
108
104
|
private _visibleSlidesCount;
|
|
109
105
|
/** @hidden */
|
|
110
106
|
private _visibleSlidesNumericCount;
|
|
@@ -118,11 +114,13 @@ export declare class CarouselComponent implements OnInit, AfterContentInit, Afte
|
|
|
118
114
|
private _previousVisibleSlidesCount;
|
|
119
115
|
/** @hidden */
|
|
120
116
|
private _slideSwiped;
|
|
121
|
-
/** @hidden
|
|
122
|
-
private readonly
|
|
117
|
+
/** @hidden */
|
|
118
|
+
private readonly _destroyRef;
|
|
123
119
|
/** @hidden */
|
|
124
120
|
constructor(_elementRef: ElementRef<HTMLElement>, _renderer: Renderer2, _changeDetectorRef: ChangeDetectorRef, _carouselService: CarouselService, _zone: NgZone, _rtlService: RtlService);
|
|
125
121
|
/** @hidden */
|
|
122
|
+
handleKeyboardEvent(event: KeyboardEvent): void;
|
|
123
|
+
/** @hidden */
|
|
126
124
|
ngOnInit(): void;
|
|
127
125
|
/** @hidden */
|
|
128
126
|
ngOnChanges(changes: SimpleChanges): void;
|
|
@@ -133,8 +131,6 @@ export declare class CarouselComponent implements OnInit, AfterContentInit, Afte
|
|
|
133
131
|
/** @hidden */
|
|
134
132
|
ngAfterViewChecked(): void;
|
|
135
133
|
/** @hidden */
|
|
136
|
-
ngOnDestroy(): void;
|
|
137
|
-
/** @hidden */
|
|
138
134
|
get _showNavigationButtonInPageIndicatorContainer(): boolean;
|
|
139
135
|
/** @hidden */
|
|
140
136
|
get _showNavigationButtonInContent(): boolean;
|
|
@@ -148,10 +144,6 @@ export declare class CarouselComponent implements OnInit, AfterContentInit, Afte
|
|
|
148
144
|
_focus(): void;
|
|
149
145
|
/** get value for rtl */
|
|
150
146
|
_isRtl(): boolean;
|
|
151
|
-
/** @hidden */
|
|
152
|
-
onKeydownArrowRight(event: KeyboardEvent): void;
|
|
153
|
-
/** @hidden */
|
|
154
|
-
onKeydownArrowLeft(event: KeyboardEvent): void;
|
|
155
147
|
/** Transitions to the previous slide in the carousel. */
|
|
156
148
|
previous(): void;
|
|
157
149
|
/** Transitions to the next slide in the carousel. */
|
|
@@ -41,11 +41,11 @@ export class CarouselItemComponent {
|
|
|
41
41
|
return this.element.getBoundingClientRect().height || this.initialHeight;
|
|
42
42
|
}
|
|
43
43
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.7", ngImport: i0, type: CarouselItemComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.7", type: CarouselItemComponent, isStandalone: true, selector: "fd-carousel-item", inputs: { id: "id", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", ariaDescribedBy: "ariaDescribedBy", loading: "loading", title: "title", initialHeight: "initialHeight", initialWidth: "initialWidth", value: "value" }, host: { properties: { "attr.id": "this.id", "attr.aria-label": "this.ariaLabel", "attr.aria-labelledby": "this.ariaLabelledBy", "attr.aria-describedby": "this.ariaDescribedBy", "attr.title": "this.title", "class.fd-carousel__item": "this.carouselItem", "class.fd-carousel__item--active": "this.carouselItemActive", "style.visibility": "this._visibility" } }, ngImport: i0, template: "<fd-busy-indicator [loading]=\"loading\">\n <ng-content></ng-content>\n</fd-busy-indicator>\n", dependencies: [{ kind: "component", type: BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.7", type: CarouselItemComponent, isStandalone: true, selector: "fd-carousel-item", inputs: { id: "id", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", ariaDescribedBy: "ariaDescribedBy", loading: "loading", title: "title", initialHeight: "initialHeight", initialWidth: "initialWidth", value: "value" }, host: { properties: { "attr.id": "this.id", "attr.aria-label": "this.ariaLabel", "attr.aria-labelledby": "this.ariaLabelledBy", "attr.aria-describedby": "this.ariaDescribedBy", "attr.title": "this.title", "class.fd-carousel__item": "this.carouselItem", "class.fd-carousel__item--active": "this.carouselItemActive", "style.visibility": "this._visibility" } }, ngImport: i0, template: "<fd-busy-indicator [loading]=\"loading\" [style.max-width.%]=\"100\">\n <ng-content></ng-content>\n</fd-busy-indicator>\n", styles: [".fd-carousel__slides{min-width:initial!important}.fd-carousel__item--active{display:flex;max-width:100%}\n"], dependencies: [{ kind: "component", type: BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
45
45
|
}
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.7", ngImport: i0, type: CarouselItemComponent, decorators: [{
|
|
47
47
|
type: Component,
|
|
48
|
-
args: [{ selector: 'fd-carousel-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [BusyIndicatorComponent], template: "<fd-busy-indicator [loading]=\"loading\">\n <ng-content></ng-content>\n</fd-busy-indicator>\n" }]
|
|
48
|
+
args: [{ selector: 'fd-carousel-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [BusyIndicatorComponent], template: "<fd-busy-indicator [loading]=\"loading\" [style.max-width.%]=\"100\">\n <ng-content></ng-content>\n</fd-busy-indicator>\n", styles: [".fd-carousel__slides{min-width:initial!important}.fd-carousel__item--active{display:flex;max-width:100%}\n"] }]
|
|
49
49
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { id: [{
|
|
50
50
|
type: Input
|
|
51
51
|
}, {
|
|
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.7", ngImpor
|
|
|
89
89
|
type: HostBinding,
|
|
90
90
|
args: ['style.visibility']
|
|
91
91
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fyb3VzZWwtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9jYXJvdXNlbC9jYXJvdXNlbC1pdGVtL2Nhcm91c2VsLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvY2Fyb3VzZWwvY2Fyb3VzZWwtaXRlbS9jYXJvdXNlbC1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdEgsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBSzlFLElBQUksbUJBQW1CLEdBQUcsQ0FBQyxDQUFDO0FBcUI1QixNQUFNLE9BQU8scUJBQXFCO0lBd0Q5QixjQUFjO0lBQ2QsSUFBSSxVQUFVLENBQUMsVUFBc0I7UUFDakMsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUM7SUFDbEMsQ0FBQztJQUVELElBQUksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBRUQsY0FBYztJQUNkLFlBQTZCLFdBQW9DO1FBQXBDLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQWpFakUsZ0NBQWdDO1FBR2hDLE9BQUUsR0FBRyxvQkFBb0IsbUJBQW1CLEVBQUUsRUFBRSxDQUFDO1FBaUJqRDs7V0FFRztRQUVILFlBQU8sR0FBRyxLQUFLLENBQUM7UUFFaEIscUNBQXFDO1FBR3JDLFVBQUssR0FBRyxJQUFJLENBQUM7UUFjYixjQUFjO1FBRWQsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFFcEIsY0FBYztRQUVkLHVCQUFrQixHQUFHLElBQUksQ0FBQztRQUUxQiw2REFBNkQ7UUFFN0QsZ0JBQVcsR0FBZSxTQUFTLENBQUM7SUFZZ0MsQ0FBQztJQUVyRSxzQkFBc0I7SUFDdEIsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQztJQUMxQyxDQUFDO0lBRUQsdUJBQXVCO0lBQ3ZCLFFBQVE7UUFDSixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzRSxDQUFDO0lBRUQsd0JBQXdCO0lBQ3hCLFNBQVM7UUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM3RSxDQUFDOzhHQWpGUSxxQkFBcUI7a0dBQXJCLHFCQUFxQix5cEJDNUJsQyw4SEFHQSxvS0R1QmMsc0JBQXNCOzsyRkFFdkIscUJBQXFCO2tCQW5CakMsU0FBUzsrQkFDSSxrQkFBa0IsbUJBYVgsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxjQUN6QixJQUFJLFdBQ1AsQ0FBQyxzQkFBc0IsQ0FBQztpR0FNakMsRUFBRTtzQkFGRCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLFNBQVM7Z0JBTXRCLFNBQVM7c0JBRlIsS0FBSzs7c0JBQ0wsV0FBVzt1QkFBQyxpQkFBaUI7Z0JBTTlCLGNBQWM7c0JBRmIsS0FBSzs7c0JBQ0wsV0FBVzt1QkFBQyxzQkFBc0I7Z0JBTW5DLGVBQWU7c0JBRmQsS0FBSzs7c0JBQ0wsV0FBVzt1QkFBQyx1QkFBdUI7Z0JBT3BDLE9BQU87c0JBRE4sS0FBSztnQkFNTixLQUFLO3NCQUZKLEtBQUs7O3NCQUNMLFdBQVc7dUJBQUMsWUFBWTtnQkFLekIsYUFBYTtzQkFEWixLQUFLO2dCQUtOLFlBQVk7c0JBRFgsS0FBSztnQkFLTixLQUFLO3NCQURKLEtBQUs7Z0JBS04sWUFBWTtzQkFEWCxXQUFXO3VCQUFDLHlCQUF5QjtnQkFLdEMsa0JBQWtCO3NCQURqQixXQUFXO3VCQUFDLGlDQUFpQztnQkFLOUMsV0FBVztzQkFEVixXQUFXO3VCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEhvc3RCaW5kaW5nLCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE51bGxhYmxlIH0gZnJvbSAnQGZ1bmRhbWVudGFsLW5neC9jZGsvdXRpbHMnO1xuaW1wb3J0IHsgQnVzeUluZGljYXRvckNvbXBvbmVudCB9IGZyb20gJ0BmdW5kYW1lbnRhbC1uZ3gvY29yZS9idXN5LWluZGljYXRvcic7XG5pbXBvcnQgeyBDYXJvdXNlbEl0ZW1JbnRlcmZhY2UgfSBmcm9tICcuLi9jYXJvdXNlbC5zZXJ2aWNlJztcblxuZXhwb3J0IHR5cGUgVmlzaWJpbGl0eSA9ICd2aXNpYmxlJyB8ICdoaWRkZW4nO1xuXG5sZXQgY2Fyb3VzZWxJdGVtQ291bnRlciA9IDA7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZmQtY2Fyb3VzZWwtaXRlbScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Nhcm91c2VsLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlczogW1xuICAgICAgICBgXG4gICAgICAgICAgICAuZmQtY2Fyb3VzZWxfX3NsaWRlcyB7XG4gICAgICAgICAgICAgICAgbWluLXdpZHRoOiBpbml0aWFsICFpbXBvcnRhbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAuZmQtY2Fyb3VzZWxfX2l0ZW0tLWFjdGl2ZSB7XG4gICAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgICBtYXgtd2lkdGg6IDEwMCU7XG4gICAgICAgICAgICB9XG4gICAgICAgIGBcbiAgICBdLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQnVzeUluZGljYXRvckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQ2Fyb3VzZWxJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgQ2Fyb3VzZWxJdGVtSW50ZXJmYWNlIHtcbiAgICAvKiogSWQgb2YgdGhlIENhcm91c2VsIGl0ZW1zLiAqL1xuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmlkJylcbiAgICBpZCA9IGBmZC1jYXJvdXNlbC1pdGVtLSR7Y2Fyb3VzZWxJdGVtQ291bnRlcisrfWA7XG5cbiAgICAvKiogU2V0cyBhcmlhLWxhYmVsIGF0dHJpYnV0ZSBmb3IgY2Fyb3VzZWwgaXRlbSAqL1xuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtbGFiZWwnKVxuICAgIGFyaWFMYWJlbDogTnVsbGFibGU8c3RyaW5nPjtcblxuICAgIC8qKiBTZXRzIGFyaWEtbGFiZWxsZWRieSBhdHRyaWJ1dGUgZm9yIGNhcm91c2VsIGl0ZW0gKi9cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLWxhYmVsbGVkYnknKVxuICAgIGFyaWFMYWJlbGxlZEJ5OiBOdWxsYWJsZTxzdHJpbmc+O1xuXG4gICAgLyoqIFNldHMgYXJpYS1kZXNjcmliZWRieSBhdHRyaWJ1dGUgZm9yIGNhcm91c2VsIGl0ZW0gKi9cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLWRlc2NyaWJlZGJ5JylcbiAgICBhcmlhRGVzY3JpYmVkQnk6IE51bGxhYmxlPHN0cmluZz47XG5cbiAgICAvKipcbiAgICAgKiBMb2FkaW5nIGluZGljYXRvciB3aGVuIGl0ZW0gaXMgbm90IHlldCBsb2FkZWRcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIGxvYWRpbmcgPSBmYWxzZTtcblxuICAgIC8qKiBTZXRzIHRvb2x0aXAgZm9yIGNhcm91c2VsIGl0ZW0gKi9cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnYXR0ci50aXRsZScpXG4gICAgdGl0bGUgPSBudWxsO1xuXG4gICAgLyoqIEluaXRpYWwgaGVpZ2h0IHZhbHVlLCBuZWVkZWQgd2hlbiBjYXJvdXNlbCBpcyBpbnNpZGUgcG9wb3ZlciAqL1xuICAgIEBJbnB1dCgpXG4gICAgaW5pdGlhbEhlaWdodDogbnVtYmVyO1xuXG4gICAgLyoqIEluaXRpYWwgaGVpZ2h0IHZhbHVlLCBuZWVkZWQgd2hlbiBjYXJvdXNlbCBpcyBpbnNpZGUgcG9wb3ZlciAqL1xuICAgIEBJbnB1dCgpXG4gICAgaW5pdGlhbFdpZHRoOiBudW1iZXI7XG5cbiAgICAvKiogVmFsdWUgb2YgY2Fyb3VzZWwgaXRlbSAqL1xuICAgIEBJbnB1dCgpXG4gICAgdmFsdWU6IGFueTtcblxuICAgIC8qKiBAaGlkZGVuICovXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy5mZC1jYXJvdXNlbF9faXRlbScpXG4gICAgY2Fyb3VzZWxJdGVtID0gdHJ1ZTtcblxuICAgIC8qKiBAaGlkZGVuICovXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy5mZC1jYXJvdXNlbF9faXRlbS0tYWN0aXZlJylcbiAgICBjYXJvdXNlbEl0ZW1BY3RpdmUgPSB0cnVlO1xuXG4gICAgLyoqIEBoaWRkZW4gSGlkZS9zaG93IHNsaWRlLCB1c2VmdWwgZm9yIG1hbmFnaW5nIHRhYiBvcmRlciAqL1xuICAgIEBIb3N0QmluZGluZygnc3R5bGUudmlzaWJpbGl0eScpXG4gICAgX3Zpc2liaWxpdHk6IFZpc2liaWxpdHkgPSAndmlzaWJsZSc7XG5cbiAgICAvKiogQGhpZGRlbiAqL1xuICAgIHNldCB2aXNpYmlsaXR5KHZpc2liaWxpdHk6IFZpc2liaWxpdHkpIHtcbiAgICAgICAgdGhpcy5fdmlzaWJpbGl0eSA9IHZpc2liaWxpdHk7XG4gICAgfVxuXG4gICAgZ2V0IHZpc2liaWxpdHkoKTogVmlzaWJpbGl0eSB7XG4gICAgICAgIHJldHVybiB0aGlzLl92aXNpYmlsaXR5O1xuICAgIH1cblxuICAgIC8qKiBAaGlkZGVuICovXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBfZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHt9XG5cbiAgICAvKiogTmF0aXZlIGVsZW1lbnQgICovXG4gICAgZ2V0IGVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xuICAgICAgICByZXR1cm4gdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICAgIH1cblxuICAgIC8qKiBXaWR0aCBvZiBlbGVtZW50ICovXG4gICAgZ2V0V2lkdGgoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKS53aWR0aCB8fCB0aGlzLmluaXRpYWxXaWR0aDtcbiAgICB9XG5cbiAgICAvKiogSGVpZ2h0IG9mIGVsZW1lbnQgKi9cbiAgICBnZXRIZWlnaHQoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKS5oZWlnaHQgfHwgdGhpcy5pbml0aWFsSGVpZ2h0O1xuICAgIH1cbn1cbiIsIjxmZC1idXN5LWluZGljYXRvciBbbG9hZGluZ109XCJsb2FkaW5nXCIgW3N0eWxlLm1heC13aWR0aC4lXT1cIjEwMFwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZmQtYnVzeS1pbmRpY2F0b3I+XG4iXX0=
|