@ng-nest/ui 16.0.1 → 16.0.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/carousel/carousel.component.d.ts +2 -0
- package/core/config/config.d.ts +2 -0
- package/esm2022/carousel/carousel.component.mjs +8 -2
- package/esm2022/core/config/config.mjs +1 -1
- package/esm2022/input/input.component.mjs +45 -8
- package/esm2022/slider/slider.component.mjs +27 -5
- package/esm2022/slider/slider.property.mjs +7 -2
- package/esm2022/statistic/countdown.component.mjs +8 -2
- package/esm2022/tabs/tabs.component.mjs +3 -3
- package/esm2022/tabs/tabs.property.mjs +7 -2
- package/fesm2022/ng-nest-ui-carousel.mjs +7 -2
- package/fesm2022/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-input.mjs +44 -7
- package/fesm2022/ng-nest-ui-input.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-slider.mjs +32 -5
- package/fesm2022/ng-nest-ui-slider.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-statistic.mjs +7 -2
- package/fesm2022/ng-nest-ui-statistic.mjs.map +1 -1
- package/fesm2022/ng-nest-ui-tabs.mjs +9 -4
- package/fesm2022/ng-nest-ui-tabs.mjs.map +1 -1
- package/input/input.component.d.ts +6 -0
- package/package.json +18 -18
- package/slider/slider.component.d.ts +6 -0
- package/slider/slider.property.d.ts +12 -2
- package/statistic/countdown.component.d.ts +2 -0
- package/tabs/tabs.property.d.ts +12 -2
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
2
2
|
import { XSliderPrefix, XSliderProperty } from './slider.property';
|
|
3
3
|
import { XIsChange, XResize, XIsUndefined, XIsEmpty, XSetData } from '@ng-nest/ui/core';
|
|
4
|
-
import { Subject } from 'rxjs';
|
|
5
|
-
import { takeUntil, debounceTime } from 'rxjs/operators';
|
|
4
|
+
import { Subject, of } from 'rxjs';
|
|
5
|
+
import { takeUntil, debounceTime, delay } from 'rxjs/operators';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@ng-nest/ui/core";
|
|
8
8
|
import * as i2 from "@angular/common";
|
|
@@ -36,6 +36,8 @@ class XSliderComponent extends XSliderProperty {
|
|
|
36
36
|
this.nodeClassMap = {};
|
|
37
37
|
this.showArrow = false;
|
|
38
38
|
this.activatedId = '';
|
|
39
|
+
this.hoverDelay = 200;
|
|
40
|
+
this.hoverDelayUnsub = new Subject();
|
|
39
41
|
this._offset = 0;
|
|
40
42
|
this.direction = 'right';
|
|
41
43
|
this.maxOffset = 0;
|
|
@@ -62,6 +64,8 @@ class XSliderComponent extends XSliderProperty {
|
|
|
62
64
|
this._unSubject.next();
|
|
63
65
|
this._unSubject.unsubscribe();
|
|
64
66
|
this._resizeObserver?.disconnect();
|
|
67
|
+
this.hoverDelayUnsub.next();
|
|
68
|
+
this.hoverDelayUnsub.complete();
|
|
65
69
|
}
|
|
66
70
|
ngAfterViewInit() {
|
|
67
71
|
this.setSubscribe();
|
|
@@ -89,6 +93,24 @@ class XSliderComponent extends XSliderProperty {
|
|
|
89
93
|
this.setActivated();
|
|
90
94
|
});
|
|
91
95
|
}
|
|
96
|
+
onEnter(event, node, index) {
|
|
97
|
+
if (node.disabled || this.trigger === 'click')
|
|
98
|
+
return;
|
|
99
|
+
of(true)
|
|
100
|
+
.pipe(delay(this.hoverDelay), takeUntil(this.hoverDelayUnsub))
|
|
101
|
+
.subscribe(() => {
|
|
102
|
+
if (this.timeoutHide) {
|
|
103
|
+
clearTimeout(this.timeoutHide);
|
|
104
|
+
this.timeoutHide = null;
|
|
105
|
+
}
|
|
106
|
+
this.nodeClick(event, node, index);
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
onLeave(node) {
|
|
110
|
+
if (node.disabled || this.trigger === 'click')
|
|
111
|
+
return;
|
|
112
|
+
this.hoverDelayUnsub.next();
|
|
113
|
+
}
|
|
92
114
|
nodeClick(event, node, index) {
|
|
93
115
|
if (event) {
|
|
94
116
|
event.preventDefault();
|
|
@@ -232,12 +254,12 @@ class XSliderComponent extends XSliderProperty {
|
|
|
232
254
|
return item.id;
|
|
233
255
|
}
|
|
234
256
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: XSliderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
235
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === 0\"\r\n class=\"x-slider-arrow-left\"\r\n icon=\"fto-chevron-left\"\r\n (click)=\"scrollPrev()\"\r\n ></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i5.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i6.XDropdownComponent, selector: "x-dropdown" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
257
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === 0\"\r\n class=\"x-slider-arrow-left\"\r\n icon=\"fto-chevron-left\"\r\n (click)=\"scrollPrev()\"\r\n ></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n (mouseenter)=\"onEnter($event, node, i)\"\r\n (mouseleave)=\"onLeave(node)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i5.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i6.XDropdownComponent, selector: "x-dropdown" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
236
258
|
}
|
|
237
259
|
export { XSliderComponent };
|
|
238
260
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: XSliderComponent, decorators: [{
|
|
239
261
|
type: Component,
|
|
240
|
-
args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === 0\"\r\n class=\"x-slider-arrow-left\"\r\n icon=\"fto-chevron-left\"\r\n (click)=\"scrollPrev()\"\r\n ></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
|
|
262
|
+
args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === 0\"\r\n class=\"x-slider-arrow-left\"\r\n icon=\"fto-chevron-left\"\r\n (click)=\"scrollPrev()\"\r\n ></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n (mouseenter)=\"onEnter($event, node, i)\"\r\n (mouseleave)=\"onLeave(node)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"autoShowArrow && showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
|
|
241
263
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { sliderScroll: [{
|
|
242
264
|
type: ViewChild,
|
|
243
265
|
args: ['sliderScroll']
|
|
@@ -245,4 +267,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
245
267
|
type: ViewChild,
|
|
246
268
|
args: ['sliderNodes']
|
|
247
269
|
}] } });
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService, XResizeObserver } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef<HTMLElement>;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef<HTMLElement>;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode | null;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  activatedId = '';\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: XResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  nodeClick(event: Event | null, node: XSliderNode, index: number) {\r\n    if (event) {\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    }\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.activatedId = node.id;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  dropdownClick(node: XSliderNode) {\r\n    const index = this.nodes.indexOf(node);\r\n    this.nodeClick(null, node, index);\r\n  }\r\n\r\n  scrollPrev() {\r\n    if (this.offset === 0) return;\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    if (this.offset === this.maxOffset) return;\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (\r\n      XIsUndefined(this.sliderScroll) ||\r\n      XIsUndefined(this.sliderNodes) ||\r\n      typeof this.sliderScroll.nativeElement.getBoundingClientRect !== 'function'\r\n    )\r\n      return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle!.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.ceil(maxOffset);\r\n    offset = Math.max(Math.ceil(offset), 0);\r\n    if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {\r\n      this.offset = this.maxOffset;\r\n    } else {\r\n      this.offset = Math.min(offset, this.maxOffset);\r\n    }\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n      if (this.activated) {\r\n        this.activatedId = this.activated.id;\r\n      }\r\n    } else {\r\n      this.activated = null;\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle: HTMLElement = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`)!;\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link\r\n    *ngIf=\"autoShowArrow && showArrow\"\r\n    [disabled]=\"offset === 0\"\r\n    class=\"x-slider-arrow-left\"\r\n    icon=\"fto-chevron-left\"\r\n    (click)=\"scrollPrev()\"\r\n  ></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li\r\n        *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n        [class.x-slider-activated]=\"getActivated(i)\"\r\n        [class.x-slider-disabled]=\"node.disabled\"\r\n        [title]=\"node.label\"\r\n      >\r\n        <x-link\r\n          (click)=\"nodeClick($event, node, i)\"\r\n          [ngClass]=\"nodeClassMap\"\r\n          [href]=\"showAnchor ? '#' + node.id : ''\"\r\n          [preventDefault]=\"showAnchor\"\r\n        >\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"autoShowArrow && showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n  <x-dropdown\r\n    *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n    class=\"x-slider-all\"\r\n    [data]=\"nodes\"\r\n    trigger=\"click\"\r\n    [(activatedId)]=\"activatedId\"\r\n    (nodeClick)=\"dropdownClick($event)\"\r\n    [portalMaxHeight]=\"expandMaxHeight\"\r\n  >\r\n    <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n  </x-dropdown>\r\n</div>\r\n"]}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,iBAAiB,EAIjB,uBAAuB,EAGvB,SAAS,EAIV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAe,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAa,SAAS,EAAE,OAAO,EAAa,YAAY,EAAE,QAAQ,EAAE,QAAQ,EAAmC,MAAM,kBAAkB,CAAC;AAC/I,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAEhE,MAOa,gBAAiB,SAAQ,eAAe;IAanD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IACD,IAAI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,YAAY,IAAI,CAAC,GAAG,KAAK,IAAI,CAAC,OAAO,KAAK,CAAC;QAC5D,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAGD,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IAC3C,CAAC;IACD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC;IACpD,CAAC;IAWD,YACS,QAAmB,EACnB,UAAmC,EACnC,GAAsB,EACtB,aAA6B;QAEpC,KAAK,EAAE,CAAC;QALD,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAyB;QACnC,QAAG,GAAH,GAAG,CAAmB;QACtB,kBAAa,GAAb,aAAa,CAAgB;QAxCtC,UAAK,GAAkB,EAAE,CAAC;QAE1B,mBAAc,GAAc,EAAE,CAAC;QAC/B,iBAAY,GAAc,EAAE,CAAC;QAC7B,cAAS,GAAG,KAAK,CAAC;QAClB,gBAAW,GAAG,EAAE,CAAC;QAEjB,eAAU,GAAG,GAAG,CAAC;QACjB,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC9B,YAAO,GAAW,CAAC,CAAC;QAS5B,cAAS,GAAc,OAAO,CAAC;QAC/B,cAAS,GAAW,CAAC,CAAC;QAQtB,iBAAY,GAAG;YACb,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,EAAE;YACR,GAAG,EAAE,EAAE;SACR,CAAC;QACM,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAUzC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;QACvE,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;QAClC,SAAS,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC3D,SAAS,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;QAChF,SAAS,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;QACtF,SAAS,CAAC,cAAc,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,YAAY,EAAE,cAAc,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;IACnI,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QAC9B,IAAI,CAAC,eAAe,EAAE,UAAU,EAAE,CAAC;QACnC,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,GAAG,aAAa,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1E,IAAI,CAAC,cAAc,CAAC,aAAa,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3E,IAAI,CAAC,YAAY,GAAG;YAClB,CAAC,aAAa,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC;YAC9D,CAAC,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;SAC9C,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,GAAc,EAAE,MAAoB,EAAE,MAAM,GAAG,aAAa;QACpE,GAAG,CAAC,GAAG,MAAM,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC,GAAG,KAAK,CAAC;QACjD,GAAG,CAAC,GAAG,MAAM,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC,GAAG,IAAI,CAAC;QAC/C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;QACV,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;aACrE,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAClD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,cAAc,CAAC;YACxC,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,KAAmB,EAAE,IAAiB,EAAE,KAAa;QAC3D,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,KAAK,OAAO;YAAE,OAAO;QACtD,EAAE,CAAC,IAAI,CAAC;aACL,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aAC7D,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aACzB;YACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,KAAK,CAAC,CAAA;QACpC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,IAAiB;QACvB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,KAAK,OAAO;YAAE,OAAO;QACtD,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC;IAED,SAAS,CAAC,KAAmB,EAAE,IAAiB,EAAE,KAAa;QAC7D,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;SACzB;QACD,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,aAAa,CAAC,IAAiB;QAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7E,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;QAClC,IAAI,CAAC,aAAa;YAAE,OAAO;QAC3B,MAAM,MAAM,GAAG,aAAa,GAAG,UAAU,CAAC,CAAC,CAAC,aAAa,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS;YAAE,OAAO;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7E,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;QAClC,IAAI,UAAU,GAAG,aAAa,IAAI,UAAU;YAAE,OAAO;QACrD,MAAM,MAAM,GAAG,UAAU,GAAG,aAAa,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,GAAG,UAAU,CAAC;QAClH,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,YAAY,CAAC,KAAa,EAAE,MAAc;QACxC,MAAM,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;QAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;QACrG,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,YAAY;QACV,IACE,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;YAC/B,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC;YAC9B,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,qBAAqB,KAAK,UAAU;YAE3E,OAAO;QACT,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,qBAAqB,EAAE,CAAC;QAC5E,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,qBAAqB,EAAE,CAAC;QAChF,IAAI,SAAS,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACnI,SAAS,GAAG,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAChG,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,aAAa,CAAC,gBAAgB,SAAS,GAAG,CAAC,CAAC;QAC1F,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO;QAC9B,MAAM,QAAQ,GAAG,OAAQ,CAAC,qBAAqB,EAAE,CAAC;QAClD,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;QAClC,IAAI,MAAM,GAAG,aAAa,CAAC;QAC3B,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE;YACzB,SAAS,GAAG,eAAe,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;YACrD,IAAI,QAAQ,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,EAAE;gBACnC,MAAM,GAAG,aAAa,GAAG,CAAC,UAAU,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;aAC5D;YACD,IAAI,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,EAAE;gBACrC,MAAM,GAAG,aAAa,GAAG,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;aAC5D;SACF;aAAM;YACL,SAAS,GAAG,eAAe,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;YACvD,IAAI,QAAQ,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,EAAE;gBACjC,MAAM,GAAG,aAAa,GAAG,CAAC,UAAU,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;aAC1D;YACD,IAAI,QAAQ,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,EAAE;gBACvC,MAAM,GAAG,aAAa,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;aAChE;SACF;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;YAC7D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC;SAC9B;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;SAChD;IACH,CAAC;IAED,WAAW;QACT,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACtE,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7E,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,GAAG,UAAU,CAAC;QAC7D,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,GAAG,aAAa,aAAa,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;YAC9D,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;gBACnB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACjB;YACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC1B;IACH,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;YACzD,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;aACtC;SACF;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC;YAAE,OAAO;QAC3C,MAAM,SAAS,GAAgB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,gBAAgB,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC;QACjI,IAAI,CAAC,SAAS;YAAE,OAAO;QACvB,IAAI,CAAC,YAAY,GAAG;YAClB,KAAK,EAAE,GAAG,SAAS,CAAC,WAAW,IAAI;YACnC,MAAM,EAAE,GAAG,SAAS,CAAC,YAAY,IAAI;YACrC,IAAI,EAAE,GAAG,SAAS,CAAC,UAAU,IAAI;YACjC,GAAG,EAAE,GAAG,SAAS,CAAC,SAAS,IAAI;SAChC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAEO,OAAO;QACb,QAAQ,CAAc,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAChE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,OAAO,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,KAAK,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,MAAc,EAAE,IAAiB;QAC3C,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;iIApQU,gBAAgB;qHAAhB,gBAAgB,uSC3B7B,q/DAoDA;;SDzBa,gBAAgB;2FAAhB,gBAAgB;kBAP5B,SAAS;+BACE,GAAG,aAAa,EAAE,iBAGb,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;sLAGpB,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBACC,WAAW;sBAApC,SAAS;uBAAC,aAAa","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService, XResizeObserver } from '@ng-nest/ui/core';\r\nimport { Subject, of } from 'rxjs';\r\nimport { takeUntil, debounceTime, delay } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef<HTMLElement>;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef<HTMLElement>;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode | null;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  activatedId = '';\r\n  timeoutHide: any;\r\n  hoverDelay = 200;\r\n  hoverDelayUnsub = new Subject<void>();\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: XResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n    this.hoverDelayUnsub.next();\r\n    this.hoverDelayUnsub.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  onEnter(event: Event | null, node: XSliderNode, index: number) {\r\n    if (node.disabled || this.trigger === 'click') return;\r\n    of(true)\r\n      .pipe(delay(this.hoverDelay), takeUntil(this.hoverDelayUnsub))\r\n      .subscribe(() => {\r\n        if (this.timeoutHide) {\r\n          clearTimeout(this.timeoutHide);\r\n          this.timeoutHide = null;\r\n        }\r\n        this.nodeClick(event, node, index)\r\n      });\r\n  }\r\n\r\n  onLeave(node: XSliderNode) {\r\n    if (node.disabled || this.trigger === 'click') return;\r\n    this.hoverDelayUnsub.next();\r\n  }\r\n\r\n  nodeClick(event: Event | null, node: XSliderNode, index: number) {\r\n    if (event) {\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    }\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.activatedId = node.id;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  dropdownClick(node: XSliderNode) {\r\n    const index = this.nodes.indexOf(node);\r\n    this.nodeClick(null, node, index);\r\n  }\r\n\r\n  scrollPrev() {\r\n    if (this.offset === 0) return;\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    if (this.offset === this.maxOffset) return;\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (\r\n      XIsUndefined(this.sliderScroll) ||\r\n      XIsUndefined(this.sliderNodes) ||\r\n      typeof this.sliderScroll.nativeElement.getBoundingClientRect !== 'function'\r\n    )\r\n      return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle!.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.ceil(maxOffset);\r\n    offset = Math.max(Math.ceil(offset), 0);\r\n    if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {\r\n      this.offset = this.maxOffset;\r\n    } else {\r\n      this.offset = Math.min(offset, this.maxOffset);\r\n    }\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n      if (this.activated) {\r\n        this.activatedId = this.activated.id;\r\n      }\r\n    } else {\r\n      this.activated = null;\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle: HTMLElement = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`)!;\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link\r\n    *ngIf=\"autoShowArrow && showArrow\"\r\n    [disabled]=\"offset === 0\"\r\n    class=\"x-slider-arrow-left\"\r\n    icon=\"fto-chevron-left\"\r\n    (click)=\"scrollPrev()\"\r\n  ></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li\r\n        *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n        [class.x-slider-activated]=\"getActivated(i)\"\r\n        [class.x-slider-disabled]=\"node.disabled\"\r\n        [title]=\"node.label\"\r\n      >\r\n        <x-link\r\n          (click)=\"nodeClick($event, node, i)\"\r\n          (mouseenter)=\"onEnter($event, node, i)\"\r\n          (mouseleave)=\"onLeave(node)\"\r\n          [ngClass]=\"nodeClassMap\"\r\n          [href]=\"showAnchor ? '#' + node.id : ''\"\r\n          [preventDefault]=\"showAnchor\"\r\n        >\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"autoShowArrow && showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n  <x-dropdown\r\n    *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n    class=\"x-slider-all\"\r\n    [data]=\"nodes\"\r\n    trigger=\"click\"\r\n    [(activatedId)]=\"activatedId\"\r\n    (nodeClick)=\"dropdownClick($event)\"\r\n    [portalMaxHeight]=\"expandMaxHeight\"\r\n  >\r\n    <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n  </x-dropdown>\r\n</div>\r\n"]}
|
|
@@ -52,7 +52,7 @@ class XSliderProperty extends XProperty {
|
|
|
52
52
|
this.nodeChange = new EventEmitter();
|
|
53
53
|
}
|
|
54
54
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: XSliderProperty, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
55
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: XSliderProperty, selector: "x-slider-property", inputs: { data: "data", animated: "animated", activatedIndex: "activatedIndex", layout: "layout", justify: "justify", nodeJustify: "nodeJustify", nodeTpl: "nodeTpl", size: "size", showExpand: "showExpand", autoShowArrow: "autoShowArrow", expandMaxHeight: "expandMaxHeight", showAnchor: "showAnchor" }, outputs: { indexChange: "indexChange", nodeChange: "nodeChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
|
55
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: XSliderProperty, selector: "x-slider-property", inputs: { data: "data", animated: "animated", activatedIndex: "activatedIndex", trigger: "trigger", layout: "layout", justify: "justify", nodeJustify: "nodeJustify", nodeTpl: "nodeTpl", size: "size", showExpand: "showExpand", autoShowArrow: "autoShowArrow", expandMaxHeight: "expandMaxHeight", showAnchor: "showAnchor" }, outputs: { indexChange: "indexChange", nodeChange: "nodeChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
|
56
56
|
}
|
|
57
57
|
__decorate([
|
|
58
58
|
XDataConvert()
|
|
@@ -64,6 +64,9 @@ __decorate([
|
|
|
64
64
|
__decorate([
|
|
65
65
|
XInputNumber()
|
|
66
66
|
], XSliderProperty.prototype, "activatedIndex", void 0);
|
|
67
|
+
__decorate([
|
|
68
|
+
XWithConfig(X_CONFIG_NAME, 'click')
|
|
69
|
+
], XSliderProperty.prototype, "trigger", void 0);
|
|
67
70
|
__decorate([
|
|
68
71
|
XWithConfig(X_CONFIG_NAME, 'medium')
|
|
69
72
|
], XSliderProperty.prototype, "size", void 0);
|
|
@@ -91,6 +94,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
91
94
|
type: Input
|
|
92
95
|
}], activatedIndex: [{
|
|
93
96
|
type: Input
|
|
97
|
+
}], trigger: [{
|
|
98
|
+
type: Input
|
|
94
99
|
}], layout: [{
|
|
95
100
|
type: Input
|
|
96
101
|
}], justify: [{
|
|
@@ -114,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
114
119
|
}], nodeChange: [{
|
|
115
120
|
type: Output
|
|
116
121
|
}] } });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLnByb3BlcnR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc2xpZGVyL3NsaWRlci5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUdMLFNBQVMsRUFFVCxZQUFZLEVBQ1osYUFBYSxFQUNiLFlBQVksRUFLWixXQUFXLEVBRVosTUFBTSxrQkFBa0IsQ0FBQztBQUMxQixPQUFPLEVBQWUsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVwRjs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLFVBQVUsQ0FBQztBQUN4QyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUM7QUFFL0I7O0dBRUc7QUFDSCxNQUNhLGVBQWdCLFNBQVEsU0FBUztJQUQ5Qzs7UUFFRTs7O1dBR0c7UUFDc0IsU0FBSSxHQUF1QixFQUFFLENBQUM7UUFNdkQ7OztXQUdHO1FBQ3NCLG1CQUFjLEdBQVksQ0FBQyxDQUFDO1FBTXJEOzs7V0FHRztRQUNNLFdBQU0sR0FBbUIsS0FBSyxDQUFDO1FBQ3hDOzs7V0FHRztRQUNNLFlBQU8sR0FBYyxPQUFPLENBQUM7UUFDdEM7OztXQUdHO1FBQ00sZ0JBQVcsR0FBYyxRQUFRLENBQUM7UUErQjNDOzs7V0FHRztRQUNPLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUNuRDs7O1dBR0c7UUFDTyxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWUsQ0FBQztLQUN4RDtpSUE1RVksZUFBZTtxSEFBZixlQUFlLHFkQURrQyxFQUFFOztBQU1yQztJQUFmLFlBQVksRUFBRTs2Q0FBK0I7QUFLZTtJQUE1RCxXQUFXLENBQVcsYUFBYSxFQUFFLElBQUksQ0FBQztJQUFFLGFBQWEsRUFBRTtpREFBcUI7QUFLakU7SUFBZixZQUFZLEVBQUU7dURBQTZCO0FBS1M7SUFBcEQsV0FBVyxDQUFpQixhQUFhLEVBQUUsT0FBTyxDQUFDO2dEQUEwQjtBQXlCakM7SUFBNUMsV0FBVyxDQUFRLGFBQWEsRUFBRSxRQUFRLENBQUM7NkNBQWM7QUFLSTtJQUE3RCxXQUFXLENBQVcsYUFBYSxFQUFFLEtBQUssQ0FBQztJQUFFLGFBQWEsRUFBRTttREFBdUI7QUFLdkI7SUFBNUQsV0FBVyxDQUFXLGFBQWEsRUFBRSxJQUFJLENBQUM7SUFBRSxhQUFhLEVBQUU7c0RBQTBCO0FBS3pDO0lBQTVDLFdBQVcsQ0FBUyxhQUFhLEVBQUUsT0FBTyxDQUFDO3dEQUEwQjtBQUtyRDtJQUFoQixhQUFhLEVBQUU7bURBQXVCO1NBakVyQyxlQUFlOzJGQUFmLGVBQWU7a0JBRDNCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsR0FBRyxhQUFhLFdBQVcsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFOzhCQU12QyxJQUFJO3NCQUE1QixLQUFLO2dCQUtnRSxRQUFRO3NCQUE3RSxLQUFLO2dCQUttQixjQUFjO3NCQUF0QyxLQUFLO2dCQUt3RCxPQUFPO3NCQUFwRSxLQUFLO2dCQUtHLE1BQU07c0JBQWQsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS0csV0FBVztzQkFBbkIsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBS2dELElBQUk7c0JBQXpELEtBQUs7Z0JBS2lFLFVBQVU7c0JBQWhGLEtBQUs7Z0JBS2dFLGFBQWE7c0JBQWxGLEtBQUs7Z0JBS2dELGVBQWU7c0JBQXBFLEtBQUs7Z0JBS29CLFVBQVU7c0JBQW5DLEtBQUs7Z0JBS0ksV0FBVztzQkFBcEIsTUFBTTtnQkFLRyxVQUFVO3NCQUFuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBYRGF0YSxcclxuICBYVGVtcGxhdGUsXHJcbiAgWFByb3BlcnR5LFxyXG4gIFhJZGVudGl0eVByb3BlcnR5LFxyXG4gIFhEYXRhQ29udmVydCxcclxuICBYSW5wdXRCb29sZWFuLFxyXG4gIFhJbnB1dE51bWJlcixcclxuICBYSnVzdGlmeSxcclxuICBYU2l6ZSxcclxuICBYTnVtYmVyLFxyXG4gIFhCb29sZWFuLFxyXG4gIFhXaXRoQ29uZmlnLFxyXG4gIFhUcmlnZ2VyXHJcbn0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcbmltcG9ydCB7IFRlbXBsYXRlUmVmLCBJbnB1dCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIFNsaWRlclxyXG4gKiBAc2VsZWN0b3IgeC1zbGlkZXJcclxuICogQGRlY29yYXRvciBjb21wb25lbnRcclxuICovXHJcbmV4cG9ydCBjb25zdCBYU2xpZGVyUHJlZml4ID0gJ3gtc2xpZGVyJztcclxuY29uc3QgWF9DT05GSUdfTkFNRSA9ICdzbGlkZXInO1xyXG5cclxuLyoqXHJcbiAqIFNsaWRlciBQcm9wZXJ0eVxyXG4gKi9cclxuQENvbXBvbmVudCh7IHNlbGVjdG9yOiBgJHtYU2xpZGVyUHJlZml4fS1wcm9wZXJ0eWAsIHRlbXBsYXRlOiAnJyB9KVxyXG5leHBvcnQgY2xhc3MgWFNsaWRlclByb3BlcnR5IGV4dGVuZHMgWFByb3BlcnR5IHtcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K55pWw5o2uXHJcbiAgICogQGVuX1VTIE5vZGUgZGF0YVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYRGF0YUNvbnZlcnQoKSBkYXRhOiBYRGF0YTxYU2xpZGVyTm9kZT4gPSBbXTtcclxuICAvKipcclxuICAgKiBAemhfQ04g5ruR5Yqo5Yqo55S7XHJcbiAgICogQGVuX1VTIFNsaWRpbmcgYW5pbWF0aW9uXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FLCB0cnVlKSBAWElucHV0Qm9vbGVhbigpIGFuaW1hdGVkPzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOW9k+WJjea/gOa0u+eahOe0ouW8lVxyXG4gICAqIEBlbl9VUyBDdXJyZW50bHkgYWN0aXZlIGluZGV4XHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhJbnB1dE51bWJlcigpIGFjdGl2YXRlZEluZGV4OiBYTnVtYmVyID0gMDtcclxuICAvKipcclxuICAgKiBAemhfQ04g6Kem5Y+R5pa55byPXHJcbiAgICogQGVuX1VTIFRyaWdnZXIgbW9kZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYV2l0aENvbmZpZzxYU2xpZGVyVHJpZ2dlcj4oWF9DT05GSUdfTkFNRSwgJ2NsaWNrJykgdHJpZ2dlciE6IFhTbGlkZXJUcmlnZ2VyO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmjpLliJfmlrnlvI9cclxuICAgKiBAZW5fVVMgQXJyYW5nZW1lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBsYXlvdXQ/OiBYU2xpZGVyTGF5b3V0ID0gJ3Jvdyc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWvuem9kOaWueW8j1xyXG4gICAqIEBlbl9VUyBBbGlnbm1lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBqdXN0aWZ5PzogWEp1c3RpZnkgPSAnc3RhcnQnO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoioLngrnmloflrZflr7npvZDmlrnlvI9cclxuICAgKiBAZW5fVVMgTm9kZSB0ZXh0IGFsaWdubWVudFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIG5vZGVKdXN0aWZ5PzogWEp1c3RpZnkgPSAnY2VudGVyJztcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K56Ieq5a6a5LmJ5qih5p2/XHJcbiAgICogQGVuX1VTIE5vZGUgY3VzdG9tIHRlbXBsYXRlXHJcbiAgICovXHJcbiAgQElucHV0KCkgbm9kZVRwbCE6IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWwuuWvuFxyXG4gICAqIEBlbl9VUyBTaXplXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhTaXplPihYX0NPTkZJR19OQU1FLCAnbWVkaXVtJykgc2l6ZT86IFhTaXplO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoioLngrnmmL7npLrkuI3kuIvnmoTml7blgJnmmL7npLrlsZXlvIDmiYDmnInnmoTmjInpkq7vvIzmjpLliJfmlrnlvI/kuLogcm93IOeahOaXtuWAmeeUn+aViFxyXG4gICAqIEBlbl9VUyBXaGVuIHRoZSBub2RlIGlzIG5vdCBkaXNwbGF5ZWQsIGRpc3BsYXkgYWxsIHRoZSBidXR0b25zLCBhbmQgdGhlIGFycmFuZ2VtZW50IGlzIGVmZmVjdGl2ZSB3aGVuIHRoZSBhcnJhbmdlbWVudCBpcyByb3dcclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WEJvb2xlYW4+KFhfQ09ORklHX05BTUUsIGZhbHNlKSBAWElucHV0Qm9vbGVhbigpIHNob3dFeHBhbmQ/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g6IqC54K55pi+56S65LiN5LiL55qE5pe25YCZ5pi+56S65bem5Y+zL+S4iuS4i+eahOeureWktFxyXG4gICAqIEBlbl9VUyDoioLngrnmmL7npLrkuI3kuIvnmoTml7blgJnmmL7npLrlt6blj7Mv5LiK5LiL55qE566t5aS0XHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FLCB0cnVlKSBAWElucHV0Qm9vbGVhbigpIGF1dG9TaG93QXJyb3c/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5bGV5byA5omA5pyJ5by55qGG55qE5pyA5aSn6auY5bqmXHJcbiAgICogQGVuX1VTIEV4cGFuZCB0aGUgbWF4aW11bSBoZWlnaHQgb2YgYWxsIGJvbWIgZnJhbWVzXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPHN0cmluZz4oWF9DT05GSUdfTkFNRSwgJzE1cmVtJykgZXhwYW5kTWF4SGVpZ2h0Pzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmmL7npLrmj4/ngrlcclxuICAgKiBAZW5fVVMgU2hvdyBhbmNob3JcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0Qm9vbGVhbigpIHNob3dBbmNob3I/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g5r+A5rS757Si5byV5Y+Y5YyW5LqL5Lu2XHJcbiAgICogQGVuX1VTIEFjdGl2YXRlIGluZGV4IGNoYW5nZSBldmVudFxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSBpbmRleENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmv4DmtLvoioLngrnmlLnlj5jkuovku7ZcclxuICAgKiBAZW5fVVMgQWN0aXZhdGUgbm9kZSBjaGFuZ2UgZXZlbnRcclxuICAgKi9cclxuICBAT3V0cHV0KCkgbm9kZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8WFNsaWRlck5vZGU+KCk7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04gU2xpZGVyIOaVsOaNruWvueixoVxyXG4gKiBAZW5fVVMgU2xpZGVyIGRhdGEgb2JqZWN0XHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFhTbGlkZXJOb2RlIGV4dGVuZHMgWElkZW50aXR5UHJvcGVydHkge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmoIfpopjvvIzmlK/mjIHmqKHmnb9cclxuICAgKiBAZW5fVVMgVGl0bGUsIHN1cHBvcnQgdGVtcGxhdGVcclxuICAgKi9cclxuICBsYWJlbD86IFhUZW1wbGF0ZTtcclxuICAvKipcclxuICAgKiBAemhfQ04g56aB55So6IqC54K5XHJcbiAgICogQGVuX1VTIE5vZGUgZGlzYWJsZWRcclxuICAgKi9cclxuICBkaXNhYmxlZD86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g6Kem5Y+R5pa55byPXHJcbiAqIEBlbl9VUyBUcmlnZ2VyIG1ldGhvZFxyXG4gKi9cclxuZXhwb3J0IHR5cGUgWFNsaWRlclRyaWdnZXIgPSBYVHJpZ2dlcjtcclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g5biD5bGA5pa55byPXHJcbiAqIEBlbl9VUyBMYXlvdXRcclxuICovXHJcbmV4cG9ydCB0eXBlIFhTbGlkZXJMYXlvdXQgPSAncm93JyB8ICdjb2x1bW4nO1xyXG4iXX0=
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, inject, PLATFORM_ID } from '@angular/core';
|
|
2
2
|
import { XCountdownPrefix, XCountdownProperty } from './statistic.property';
|
|
3
3
|
import { interval } from 'rxjs';
|
|
4
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@ng-nest/ui/core";
|
|
6
7
|
import * as i2 from "./statistic.component";
|
|
@@ -12,6 +13,9 @@ class XCountdownComponent extends XCountdownProperty {
|
|
|
12
13
|
this.ngZone = ngZone;
|
|
13
14
|
this.configService = configService;
|
|
14
15
|
this.period = 1000 / 30;
|
|
16
|
+
this.platformId = inject(PLATFORM_ID);
|
|
17
|
+
this.isBrowser = true;
|
|
18
|
+
this.isBrowser = isPlatformBrowser(this.platformId);
|
|
15
19
|
}
|
|
16
20
|
ngOnInit() {
|
|
17
21
|
this.syncTimer();
|
|
@@ -37,6 +41,8 @@ class XCountdownComponent extends XCountdownProperty {
|
|
|
37
41
|
}
|
|
38
42
|
}
|
|
39
43
|
startTimer() {
|
|
44
|
+
if (!this.isBrowser)
|
|
45
|
+
return;
|
|
40
46
|
this.ngZone.runOutsideAngular(() => {
|
|
41
47
|
this.stopTimer();
|
|
42
48
|
this._updater = interval(this.period).subscribe(() => {
|
|
@@ -66,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
66
72
|
type: Component,
|
|
67
73
|
args: [{ selector: `${XCountdownPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"x-countdown\">\r\n <x-statistic\r\n [value]=\"diff | xTimeRange: format\"\r\n [valueStyle]=\"valueStyle\"\r\n [prefix]=\"prefix\"\r\n [suffix]=\"suffix\"\r\n [label]=\"label\"\r\n ></x-statistic>\r\n</div>\r\n" }]
|
|
68
74
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1.XConfigService }]; } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRkb3duLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3N0YXRpc3RpYy9jb3VudGRvd24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc3RhdGlzdGljL2NvdW50ZG93bi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUVULGlCQUFpQixFQUVqQix1QkFBdUIsRUFJdkIsTUFBTSxFQUNOLFdBQVcsRUFDWixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM1RSxPQUFPLEVBQUUsUUFBUSxFQUFnQixNQUFNLE1BQU0sQ0FBQztBQUU5QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7QUFFcEQsTUFPYSxtQkFBb0IsU0FBUSxrQkFBa0I7SUFPekQsWUFBb0IsR0FBc0IsRUFBVSxNQUFjLEVBQVMsYUFBNkI7UUFDdEcsS0FBSyxFQUFFLENBQUM7UUFEVSxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUFVLFdBQU0sR0FBTixNQUFNLENBQVE7UUFBUyxrQkFBYSxHQUFiLGFBQWEsQ0FBZ0I7UUFMeEcsV0FBTSxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7UUFHbkIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqQyxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBR2YsSUFBSSxDQUFDLFNBQVMsR0FBRyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQzFCLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQzFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLEVBQUU7Z0JBQzFCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQzthQUNsQjtTQUNGO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQzlCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztTQUNuQjthQUFNO1lBQ0wsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1NBQ2xCO0lBQ0gsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVM7WUFBRSxPQUFPO1FBQzVCLElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFO1lBQ2pDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDbkQsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO2dCQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzNCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsU0FBUztRQUNQLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1NBQ3RCO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbkQsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRTtZQUNuQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDakIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNwQjtJQUNILENBQUM7aUlBOURVLG1CQUFtQjtxSEFBbkIsbUJBQW1CLCtGQ3hCaEMsaVBBU0E7O1NEZWEsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBUC9CLFNBQVM7K0JBQ0UsR0FBRyxnQkFBZ0IsRUFBRSxpQkFHaEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIE9uSW5pdCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIE9uQ2hhbmdlcyxcclxuICBOZ1pvbmUsXHJcbiAgaW5qZWN0LFxyXG4gIFBMQVRGT1JNX0lEXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFhDb3VudGRvd25QcmVmaXgsIFhDb3VudGRvd25Qcm9wZXJ0eSB9IGZyb20gJy4vc3RhdGlzdGljLnByb3BlcnR5JztcclxuaW1wb3J0IHsgaW50ZXJ2YWwsIFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBYQ29uZmlnU2VydmljZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBpc1BsYXRmb3JtQnJvd3NlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogYCR7WENvdW50ZG93blByZWZpeH1gLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3VudGRvd24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvdW50ZG93bi5jb21wb25lbnQuc2NzcyddLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFhDb3VudGRvd25Db21wb25lbnQgZXh0ZW5kcyBYQ291bnRkb3duUHJvcGVydHkgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgZGlmZiE6IG51bWJlcjtcclxuICBwZXJpb2QgPSAxMDAwIC8gMzA7XHJcbiAgcHJpdmF0ZSBfdGFyZ2V0ITogbnVtYmVyO1xyXG4gIHByaXZhdGUgX3VwZGF0ZXIhOiBTdWJzY3JpcHRpb24gfCBudWxsO1xyXG4gIHBsYXRmb3JtSWQgPSBpbmplY3QoUExBVEZPUk1fSUQpO1xyXG4gIGlzQnJvd3NlciA9IHRydWU7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmLCBwcml2YXRlIG5nWm9uZTogTmdab25lLCBwdWJsaWMgY29uZmlnU2VydmljZTogWENvbmZpZ1NlcnZpY2UpIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgICB0aGlzLmlzQnJvd3NlciA9IGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCk7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuc3luY1RpbWVyKCk7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICBjb25zdCB7IHZhbHVlIH0gPSBjaGFuZ2VzO1xyXG4gICAgaWYgKHZhbHVlKSB7XHJcbiAgICAgIHRoaXMuX3RhcmdldCA9IE51bWJlcih2YWx1ZS5jdXJyZW50VmFsdWUpO1xyXG4gICAgICBpZiAoIXZhbHVlLmlzRmlyc3RDaGFuZ2UoKSkge1xyXG4gICAgICAgIHRoaXMuc3luY1RpbWVyKCk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5zdG9wVGltZXIoKTtcclxuICB9XHJcblxyXG4gIHN5bmNUaW1lcigpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLl90YXJnZXQgPj0gRGF0ZS5ub3coKSkge1xyXG4gICAgICB0aGlzLnN0YXJ0VGltZXIoKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuc3RvcFRpbWVyKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBzdGFydFRpbWVyKCk6IHZvaWQge1xyXG4gICAgaWYgKCF0aGlzLmlzQnJvd3NlcikgcmV0dXJuO1xyXG4gICAgdGhpcy5uZ1pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xyXG4gICAgICB0aGlzLnN0b3BUaW1lcigpO1xyXG4gICAgICB0aGlzLl91cGRhdGVyID0gaW50ZXJ2YWwodGhpcy5wZXJpb2QpLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgdGhpcy51cGRhdGVWYWx1ZSgpO1xyXG4gICAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgfSk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHN0b3BUaW1lcigpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLl91cGRhdGVyKSB7XHJcbiAgICAgIHRoaXMuX3VwZGF0ZXIudW5zdWJzY3JpYmUoKTtcclxuICAgICAgdGhpcy5fdXBkYXRlciA9IG51bGw7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICB1cGRhdGVWYWx1ZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuZGlmZiA9IE1hdGgubWF4KHRoaXMuX3RhcmdldCAtIERhdGUubm93KCksIDApO1xyXG4gICAgaWYgKHRoaXMuZGlmZiA9PT0gMCkge1xyXG4gICAgICB0aGlzLnN0b3BUaW1lcigpO1xyXG4gICAgICB0aGlzLmZpbmlzaC5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJ4LWNvdW50ZG93blwiPlxyXG4gIDx4LXN0YXRpc3RpY1xyXG4gICAgW3ZhbHVlXT1cImRpZmYgfCB4VGltZVJhbmdlOiBmb3JtYXRcIlxyXG4gICAgW3ZhbHVlU3R5bGVdPVwidmFsdWVTdHlsZVwiXHJcbiAgICBbcHJlZml4XT1cInByZWZpeFwiXHJcbiAgICBbc3VmZml4XT1cInN1ZmZpeFwiXHJcbiAgICBbbGFiZWxdPVwibGFiZWxcIlxyXG4gID48L3gtc3RhdGlzdGljPlxyXG48L2Rpdj5cclxuIl19
|