ngx-edge-slider 2.0.1 → 2.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/component/simple-slider.component.mjs +55 -14
- package/esm2022/lib/engine/slider-engine.service.mjs +10 -7
- package/esm2022/lib/models/slider-config.model.mjs +8 -1
- package/esm2022/lib/ngx-edge-slider.module.mjs +2 -2
- package/esm2022/lib/plugins/autoplay/autoplay.plugin.mjs +47 -0
- package/esm2022/lib/plugins/draggable/draggable.plugin.mjs +47 -22
- package/esm2022/lib/plugins/pagination/pagination.plugin.mjs +1 -1
- package/esm2022/public-api.mjs +10 -6
- package/fesm2022/ngx-edge-slider.mjs +115 -43
- package/fesm2022/ngx-edge-slider.mjs.map +1 -1
- package/lib/component/simple-slider.component.d.ts +13 -2
- package/lib/engine/slider-engine.service.d.ts +2 -1
- package/lib/plugins/autoplay/autoplay.plugin.d.ts +18 -0
- package/lib/plugins/draggable/draggable.plugin.d.ts +6 -3
- package/lib/plugins/pagination/pagination.plugin.d.ts +1 -2
- package/package.json +1 -1
- package/public-api.d.ts +9 -2
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Component, ChangeDetectionStrategy, Input, EventEmitter, Output, ViewChild, } from "@angular/core";
|
|
1
|
+
import { Component, ChangeDetectionStrategy, Input, EventEmitter, Output, ViewChild, ViewEncapsulation, } from "@angular/core";
|
|
2
2
|
import { Subject, takeUntil } from "rxjs";
|
|
3
3
|
import { SliderEngine } from "../engine/slider-engine.service";
|
|
4
4
|
import { SliderStore } from "../store/slider-store.service";
|
|
5
|
-
import { SliderAutoplayPlugin } from "../plugins/autoplay.plugin";
|
|
5
|
+
import { SliderAutoplayPlugin } from "../plugins/autoplay/autoplay.plugin";
|
|
6
6
|
import { SliderDraggablePlugin } from "../plugins/draggable/draggable.plugin";
|
|
7
7
|
import { SliderNavigationPlugin } from "../plugins/navigation/navigation.plugin";
|
|
8
8
|
import { SliderPaginationPlugin } from "../plugins/pagination/pagination.plugin";
|
|
@@ -14,7 +14,7 @@ import * as i2 from "../store/slider-store.service";
|
|
|
14
14
|
import * as i3 from "../plugins/draggable/draggable.plugin";
|
|
15
15
|
import * as i4 from "../plugins/pagination/pagination.plugin";
|
|
16
16
|
import * as i5 from "../plugins/navigation/navigation.plugin";
|
|
17
|
-
import * as i6 from "../plugins/autoplay.plugin";
|
|
17
|
+
import * as i6 from "../plugins/autoplay/autoplay.plugin";
|
|
18
18
|
import * as i7 from "../plugins/thumbs/thumbs-scroll.plugin";
|
|
19
19
|
import * as i8 from "@angular/common";
|
|
20
20
|
export class SimpleSliderComponent {
|
|
@@ -56,7 +56,7 @@ export class SimpleSliderComponent {
|
|
|
56
56
|
}
|
|
57
57
|
});
|
|
58
58
|
this.lastSlidesRef = this.config?.slides ?? null;
|
|
59
|
-
this.
|
|
59
|
+
this.resolvePlugins(this.config);
|
|
60
60
|
}
|
|
61
61
|
ngAfterViewInit() {
|
|
62
62
|
if (this.sliderHost?.nativeElement) {
|
|
@@ -94,8 +94,47 @@ export class SimpleSliderComponent {
|
|
|
94
94
|
selectSlide(index) {
|
|
95
95
|
this.engine.selectSlide(index);
|
|
96
96
|
}
|
|
97
|
+
onRecalculate() {
|
|
98
|
+
this.engine.recalculate();
|
|
99
|
+
}
|
|
100
|
+
// Navigation
|
|
101
|
+
/** Expose navigation observables safely */
|
|
102
|
+
get canPrev$() {
|
|
103
|
+
if (!this.navigation) {
|
|
104
|
+
console.warn("Navigation plugin is not enabled.");
|
|
105
|
+
return null;
|
|
106
|
+
}
|
|
107
|
+
return this.navigation.canPrev$;
|
|
108
|
+
}
|
|
109
|
+
get canNext$() {
|
|
110
|
+
if (!this.navigation) {
|
|
111
|
+
console.warn("Navigation plugin is not enabled.");
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
return this.navigation.canNext$;
|
|
115
|
+
}
|
|
116
|
+
/** Expose next/prev methods */
|
|
117
|
+
next() {
|
|
118
|
+
this.navigation?.next();
|
|
119
|
+
}
|
|
120
|
+
prev() {
|
|
121
|
+
this.navigation?.prev();
|
|
122
|
+
}
|
|
123
|
+
/** Expose pagination observable */
|
|
124
|
+
get pager$() {
|
|
125
|
+
if (!this.pagination) {
|
|
126
|
+
console.warn("Pagination plugin is not enabled for this slider.");
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
return this.pagination.pager$;
|
|
130
|
+
}
|
|
131
|
+
/** Expose a goToSlide method */
|
|
132
|
+
goToSlide(index) {
|
|
133
|
+
this.pagination.goToSlide(index);
|
|
134
|
+
}
|
|
97
135
|
// Handle Pointers
|
|
98
136
|
onPointerDown(event) {
|
|
137
|
+
console.log("down");
|
|
99
138
|
this.dragStartX = event.clientX;
|
|
100
139
|
this.dragStartY = event.clientY;
|
|
101
140
|
this.isDraggingPointer = false;
|
|
@@ -103,6 +142,7 @@ export class SimpleSliderComponent {
|
|
|
103
142
|
this.engine.handleDragStart(event);
|
|
104
143
|
}
|
|
105
144
|
onPointerMove(event) {
|
|
145
|
+
console.log("move");
|
|
106
146
|
const dx = Math.abs(event.clientX - this.dragStartX);
|
|
107
147
|
const dy = Math.abs(event.clientY - this.dragStartY);
|
|
108
148
|
if (!this.isDraggingPointer && (dx > 5 || dy > 5)) {
|
|
@@ -117,6 +157,7 @@ export class SimpleSliderComponent {
|
|
|
117
157
|
onPointerUp(event) {
|
|
118
158
|
if (!event)
|
|
119
159
|
return;
|
|
160
|
+
console.log("up");
|
|
120
161
|
if (!this.isDraggingPointer) {
|
|
121
162
|
const target = event.target;
|
|
122
163
|
// Only select the slide if click is not on an interactive child
|
|
@@ -138,18 +179,18 @@ export class SimpleSliderComponent {
|
|
|
138
179
|
}
|
|
139
180
|
resolvePlugins(config) {
|
|
140
181
|
const runtimePlugins = [];
|
|
141
|
-
const cfg = config.plugins;
|
|
142
|
-
if (cfg
|
|
182
|
+
const cfg = config.plugins ?? {}; // <-- safe fallback
|
|
183
|
+
if (cfg.draggable)
|
|
143
184
|
runtimePlugins.push(this.draggable);
|
|
144
|
-
if (cfg
|
|
185
|
+
if (cfg.pagination)
|
|
145
186
|
runtimePlugins.push(this.pagination);
|
|
146
|
-
if (cfg
|
|
187
|
+
if (cfg.navigation)
|
|
147
188
|
runtimePlugins.push(this.navigation);
|
|
148
|
-
if (cfg
|
|
189
|
+
if (cfg.autoplay) {
|
|
149
190
|
this.autoplay.setConfig(cfg.autoplay);
|
|
150
191
|
runtimePlugins.push(this.autoplay);
|
|
151
192
|
}
|
|
152
|
-
if (cfg
|
|
193
|
+
if (cfg.thumbs)
|
|
153
194
|
runtimePlugins.push(this.thumbs);
|
|
154
195
|
this.engine.init({ ...config, plugins: undefined }, runtimePlugins);
|
|
155
196
|
}
|
|
@@ -162,11 +203,11 @@ export class SimpleSliderComponent {
|
|
|
162
203
|
SliderNavigationPlugin,
|
|
163
204
|
SliderAutoplayPlugin,
|
|
164
205
|
SliderThumbsScrollPlugin,
|
|
165
|
-
], viewQueries: [{ propertyName: "sliderHost", first: true, predicate: ["sliderHost"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"state$ | async as state\">\r\n <div\r\n class=\"slider\"\r\n #sliderHost\r\n [class.slider-vertical]=\"state.vertical\"\r\n [class.slider-draggable]=\"state.isDragging\"\r\n [class.slider--main]=\"!config.isThumbs\"\r\n [class.slider--thumbs]=\"config.isThumbs\"\r\n *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n (pointerdown)=\"onPointerDown($event)\"\r\n (pointermove)=\"onPointerMove($event)\"\r\n (pointerup)=\"onPointerUp($event)\"\r\n (pointercancel)=\"onPointerUp($event)\">\r\n <div\r\n class=\"slider__wrapper\"\r\n [ngStyle]=\"{\r\n transform: state.translate,\r\n transition:
|
|
206
|
+
], viewQueries: [{ propertyName: "sliderHost", first: true, predicate: ["sliderHost"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"state$ | async as state\">\r\n <div\r\n class=\"slider\"\r\n #sliderHost\r\n [class.slider-vertical]=\"state.vertical\"\r\n [class.slider-draggable]=\"state.isDragging\"\r\n [class.slider--main]=\"!config.isThumbs\"\r\n [class.slider--thumbs]=\"config.isThumbs\"\r\n *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n (pointerdown)=\"onPointerDown($event)\"\r\n (pointermove)=\"onPointerMove($event)\"\r\n (pointerup)=\"onPointerUp($event)\"\r\n (pointercancel)=\"onPointerUp($event)\">\r\n <div\r\n class=\"slider__wrapper\"\r\n [ngStyle]=\"{\r\n transform: state.translate,\r\n transition: draggable.isDraggingPointer ? 'none' : 'transform 0.3s ease',\r\n display: 'flex',\r\n 'flex-direction': state.vertical ? 'column' : 'row',\r\n 'justify-content': state.visibleSlides?.length < state.slidesPerView ? 'center' : 'flex-start',\r\n gap: (state.slidesPerView > 1 ? state.gap || 0 : 0) + 'px',\r\n }\">\r\n <div\r\n *ngFor=\"let slide of state.visibleSlides; let i = index\"\r\n class=\"slide\"\r\n [attr.data-index]=\"i\"\r\n [class.slide--current]=\"state.selectedSlide === i\"\r\n [style.flex]=\"\r\n !config.isThumbs\r\n ? '0 0 calc(' +\r\n 100 / state.slidesPerView +\r\n '% - ' +\r\n ((state.gap || 0) * (state.slidesPerView - 1)) / state.slidesPerView +\r\n 'px)'\r\n : '0 0 ' + thumbSize + 'px'\r\n \"\r\n [style.width]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n [style.height]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n (click)=\"engine.selectSlide(i)\">\r\n <ng-container\r\n *ngTemplateOutlet=\"slideTemplate ? slideTemplate : defaultSlideTemplate; context: { slide: slide, index: i }\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [".slider-main-product{display:inline-flex;height:520px}.slider-main{width:100%;height:600px;justify-content:center;display:flex}@media (max-width: 577px){.slider-main{height:100%;display:block}}.slider--main{height:100%;overflow:hidden}.slider--main .slider__wrapper{display:flex;will-change:transform}.slider--main .slider__wrapper .slide{flex:0 0 100%}.slider--main .slider__wrapper .slide .slide-content,.slider--main .slider__wrapper .slide picture{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.slider--main .slider__wrapper .slide .slide-content .drag-handle,.slider--main .slider__wrapper .slide picture .drag-handle{width:100%;height:100%;cursor:grab;z-index:10;pointer-events:all}.slider--main .slider__wrapper .slide .slide-content img,.slider--main .slider__wrapper .slide picture img{max-width:100%;max-height:100%;object-fit:contain;display:block;transform-origin:center;transform:translateZ(0);pointer-events:none}.slider--thumbs{margin-top:24px;margin-bottom:36px;height:70px!important}.slider--thumbs .slider__wrapper{display:flex;gap:8px;will-change:transform;transform:translateZ(0)}.slider--thumbs .slide{flex:0 0 auto;pointer-events:auto}.slider--thumbs .slide .slide-content{width:54px;height:68px;display:flex;align-items:center;justify-content:center;border:1px solid #ebebeb;cursor:pointer}.slider--thumbs .slide .slide-content img{max-width:100%;max-height:100%;object-fit:contain;display:block;transform:scale(.9)}.slider--thumbs .slide .slide-content.slide--current{border-color:#212121}.slider{width:100%;height:100%;overflow:hidden;position:relative;touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-webkit-tap-highlight-color:transparent}.slider.slider-can-drag{cursor:grab}.slider.slider-is-dragging{cursor:grabbing}.slider.slider-dragged{box-shadow:0 0 10px #0000001a}.slider.slider-drag-prevent-click{pointer-events:none}.slider .slider__wrapper{display:flex;transition:transform .3s cubic-bezier(.25,.46,.45,.84);will-change:transform;transform:none;width:auto;height:100%}.slider .slide{display:flex;align-items:center;justify-content:center;height:100%;overflow:hidden;flex-shrink:0;position:relative;transition:transform .3s cubic-bezier(.25,.46,.45,.84)}@media (min-width: 1441px){.slider--thumbs .slide{flex:0 0 20%}}@media (max-width: 1024px){.slider--thumbs .slide{flex:0 0 33.333%}}@media (max-width: 1023px){.slider--thumbs .slide{flex:0 0 50%}}.slider-arrow-next,.slider-arrow-prev{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:#fffc no-repeat center center;cursor:pointer;z-index:10}.slider-arrow-next.next,.slider-arrow-prev.next{right:10px}.slider-arrow-next.prev,.slider-arrow-prev.prev{left:10px}.thumbs-wrapper{position:relative}.thumb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:48px;height:48px;background:#ffffffe6 url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='4.51 0.01 10.99 19.97'%3E%3Cpath fill='%23000' d='m4.508 18.968 1.006 1.006 9.983-9.984L5.514.005 4.508 1.011l8.984 8.984-8.984 8.973Z'/%3E%3C/svg%3E\") no-repeat center center/11px 18px;font-size:36px;line-height:56px;opacity:0;pointer-events:none;transition:opacity .2s ease}.thumb-nav.activeArrow{opacity:1;pointer-events:all}.thumb-nav--left{left:-73px;transform:translateY(-50%) rotate(180deg)!important}.thumb-nav--right{right:-65px}.slider-pagination .thumb-dots-wrapper{display:flex;align-items:center;justify-content:center;gap:7px}.slider-pagination .thumb-dots-wrapper .thumb-dot{display:inline-block;width:4px;height:4px;margin:0 0 0 8px;border-radius:50%;background:#b3b3b3}.slider-pagination .thumb-dots-wrapper .thumb-dot.active,.slider-pagination .thumb-dots-wrapper .thumb-dot:hover{background:#212121;border:1px solid #212121}.slider-pagination .thumb-dots-wrapper .thumb-dot.hidden{opacity:0;pointer-events:none}.navigation-slider{position:relative}.navigation-slider app-simple-slider{pointer-events:auto;position:relative;z-index:1}.navigation-slider .nav-btn{pointer-events:auto;position:absolute;z-index:10;border:0;cursor:pointer;width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:transparent;box-shadow:unset;font-size:32px;line-height:1;transition:transform .15s ease,opacity .15s ease}.navigation-slider .nav-btn:hover{transform:translateY(-1px)}.navigation-slider .nav-btn.is-hidden{color:#a0a0a58d;pointer-events:none}.navigation-slider.nav--top-left .nav-btn--prev{top:12px;left:12px}.navigation-slider.nav--top-left .nav-btn--next{top:12px;left:56px}.navigation-slider.nav--center-sides .nav-btn--prev{top:50%;left:10px;transform:translateY(-50%)}.navigation-slider.nav--center-sides .nav-btn--next{top:50%;right:10px;transform:translateY(-50%)}.navigation-slider.nav--center-sides .nav-btn:hover{transform:translateY(-50%) translateY(-1px)}.navigation-slider.nav--top-right-compact .nav-btn--next{top:-50px;right:0}.navigation-slider.nav--top-right-compact .nav-btn--prev{top:-50px;right:60px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i8.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
166
207
|
}
|
|
167
208
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SimpleSliderComponent, decorators: [{
|
|
168
209
|
type: Component,
|
|
169
|
-
args: [{ selector: "app-simple-slider", changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule], providers: [
|
|
210
|
+
args: [{ selector: "app-simple-slider", changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule], providers: [
|
|
170
211
|
SliderEngine,
|
|
171
212
|
SliderStore,
|
|
172
213
|
SliderDraggablePlugin,
|
|
@@ -174,7 +215,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
174
215
|
SliderNavigationPlugin,
|
|
175
216
|
SliderAutoplayPlugin,
|
|
176
217
|
SliderThumbsScrollPlugin,
|
|
177
|
-
], template: "<ng-container *ngIf=\"state$ | async as state\">\r\n <div\r\n class=\"slider\"\r\n #sliderHost\r\n [class.slider-vertical]=\"state.vertical\"\r\n [class.slider-draggable]=\"state.isDragging\"\r\n [class.slider--main]=\"!config.isThumbs\"\r\n [class.slider--thumbs]=\"config.isThumbs\"\r\n *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n (pointerdown)=\"onPointerDown($event)\"\r\n (pointermove)=\"onPointerMove($event)\"\r\n (pointerup)=\"onPointerUp($event)\"\r\n (pointercancel)=\"onPointerUp($event)\">\r\n <div\r\n class=\"slider__wrapper\"\r\n [ngStyle]=\"{\r\n transform: state.translate,\r\n transition:
|
|
218
|
+
], template: "<ng-container *ngIf=\"state$ | async as state\">\r\n <div\r\n class=\"slider\"\r\n #sliderHost\r\n [class.slider-vertical]=\"state.vertical\"\r\n [class.slider-draggable]=\"state.isDragging\"\r\n [class.slider--main]=\"!config.isThumbs\"\r\n [class.slider--thumbs]=\"config.isThumbs\"\r\n *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n (pointerdown)=\"onPointerDown($event)\"\r\n (pointermove)=\"onPointerMove($event)\"\r\n (pointerup)=\"onPointerUp($event)\"\r\n (pointercancel)=\"onPointerUp($event)\">\r\n <div\r\n class=\"slider__wrapper\"\r\n [ngStyle]=\"{\r\n transform: state.translate,\r\n transition: draggable.isDraggingPointer ? 'none' : 'transform 0.3s ease',\r\n display: 'flex',\r\n 'flex-direction': state.vertical ? 'column' : 'row',\r\n 'justify-content': state.visibleSlides?.length < state.slidesPerView ? 'center' : 'flex-start',\r\n gap: (state.slidesPerView > 1 ? state.gap || 0 : 0) + 'px',\r\n }\">\r\n <div\r\n *ngFor=\"let slide of state.visibleSlides; let i = index\"\r\n class=\"slide\"\r\n [attr.data-index]=\"i\"\r\n [class.slide--current]=\"state.selectedSlide === i\"\r\n [style.flex]=\"\r\n !config.isThumbs\r\n ? '0 0 calc(' +\r\n 100 / state.slidesPerView +\r\n '% - ' +\r\n ((state.gap || 0) * (state.slidesPerView - 1)) / state.slidesPerView +\r\n 'px)'\r\n : '0 0 ' + thumbSize + 'px'\r\n \"\r\n [style.width]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n [style.height]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n (click)=\"engine.selectSlide(i)\">\r\n <ng-container\r\n *ngTemplateOutlet=\"slideTemplate ? slideTemplate : defaultSlideTemplate; context: { slide: slide, index: i }\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [".slider-main-product{display:inline-flex;height:520px}.slider-main{width:100%;height:600px;justify-content:center;display:flex}@media (max-width: 577px){.slider-main{height:100%;display:block}}.slider--main{height:100%;overflow:hidden}.slider--main .slider__wrapper{display:flex;will-change:transform}.slider--main .slider__wrapper .slide{flex:0 0 100%}.slider--main .slider__wrapper .slide .slide-content,.slider--main .slider__wrapper .slide picture{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.slider--main .slider__wrapper .slide .slide-content .drag-handle,.slider--main .slider__wrapper .slide picture .drag-handle{width:100%;height:100%;cursor:grab;z-index:10;pointer-events:all}.slider--main .slider__wrapper .slide .slide-content img,.slider--main .slider__wrapper .slide picture img{max-width:100%;max-height:100%;object-fit:contain;display:block;transform-origin:center;transform:translateZ(0);pointer-events:none}.slider--thumbs{margin-top:24px;margin-bottom:36px;height:70px!important}.slider--thumbs .slider__wrapper{display:flex;gap:8px;will-change:transform;transform:translateZ(0)}.slider--thumbs .slide{flex:0 0 auto;pointer-events:auto}.slider--thumbs .slide .slide-content{width:54px;height:68px;display:flex;align-items:center;justify-content:center;border:1px solid #ebebeb;cursor:pointer}.slider--thumbs .slide .slide-content img{max-width:100%;max-height:100%;object-fit:contain;display:block;transform:scale(.9)}.slider--thumbs .slide .slide-content.slide--current{border-color:#212121}.slider{width:100%;height:100%;overflow:hidden;position:relative;touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-webkit-tap-highlight-color:transparent}.slider.slider-can-drag{cursor:grab}.slider.slider-is-dragging{cursor:grabbing}.slider.slider-dragged{box-shadow:0 0 10px #0000001a}.slider.slider-drag-prevent-click{pointer-events:none}.slider .slider__wrapper{display:flex;transition:transform .3s cubic-bezier(.25,.46,.45,.84);will-change:transform;transform:none;width:auto;height:100%}.slider .slide{display:flex;align-items:center;justify-content:center;height:100%;overflow:hidden;flex-shrink:0;position:relative;transition:transform .3s cubic-bezier(.25,.46,.45,.84)}@media (min-width: 1441px){.slider--thumbs .slide{flex:0 0 20%}}@media (max-width: 1024px){.slider--thumbs .slide{flex:0 0 33.333%}}@media (max-width: 1023px){.slider--thumbs .slide{flex:0 0 50%}}.slider-arrow-next,.slider-arrow-prev{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:#fffc no-repeat center center;cursor:pointer;z-index:10}.slider-arrow-next.next,.slider-arrow-prev.next{right:10px}.slider-arrow-next.prev,.slider-arrow-prev.prev{left:10px}.thumbs-wrapper{position:relative}.thumb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:48px;height:48px;background:#ffffffe6 url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='4.51 0.01 10.99 19.97'%3E%3Cpath fill='%23000' d='m4.508 18.968 1.006 1.006 9.983-9.984L5.514.005 4.508 1.011l8.984 8.984-8.984 8.973Z'/%3E%3C/svg%3E\") no-repeat center center/11px 18px;font-size:36px;line-height:56px;opacity:0;pointer-events:none;transition:opacity .2s ease}.thumb-nav.activeArrow{opacity:1;pointer-events:all}.thumb-nav--left{left:-73px;transform:translateY(-50%) rotate(180deg)!important}.thumb-nav--right{right:-65px}.slider-pagination .thumb-dots-wrapper{display:flex;align-items:center;justify-content:center;gap:7px}.slider-pagination .thumb-dots-wrapper .thumb-dot{display:inline-block;width:4px;height:4px;margin:0 0 0 8px;border-radius:50%;background:#b3b3b3}.slider-pagination .thumb-dots-wrapper .thumb-dot.active,.slider-pagination .thumb-dots-wrapper .thumb-dot:hover{background:#212121;border:1px solid #212121}.slider-pagination .thumb-dots-wrapper .thumb-dot.hidden{opacity:0;pointer-events:none}.navigation-slider{position:relative}.navigation-slider app-simple-slider{pointer-events:auto;position:relative;z-index:1}.navigation-slider .nav-btn{pointer-events:auto;position:absolute;z-index:10;border:0;cursor:pointer;width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:transparent;box-shadow:unset;font-size:32px;line-height:1;transition:transform .15s ease,opacity .15s ease}.navigation-slider .nav-btn:hover{transform:translateY(-1px)}.navigation-slider .nav-btn.is-hidden{color:#a0a0a58d;pointer-events:none}.navigation-slider.nav--top-left .nav-btn--prev{top:12px;left:12px}.navigation-slider.nav--top-left .nav-btn--next{top:12px;left:56px}.navigation-slider.nav--center-sides .nav-btn--prev{top:50%;left:10px;transform:translateY(-50%)}.navigation-slider.nav--center-sides .nav-btn--next{top:50%;right:10px;transform:translateY(-50%)}.navigation-slider.nav--center-sides .nav-btn:hover{transform:translateY(-50%) translateY(-1px)}.navigation-slider.nav--top-right-compact .nav-btn--next{top:-50px;right:0}.navigation-slider.nav--top-right-compact .nav-btn--prev{top:-50px;right:60px}\n"] }]
|
|
178
219
|
}], ctorParameters: () => [{ type: i1.SliderEngine }, { type: i2.SliderStore }, { type: i3.SliderDraggablePlugin }, { type: i4.SliderPaginationPlugin }, { type: i5.SliderNavigationPlugin }, { type: i6.SliderAutoplayPlugin }, { type: i7.SliderThumbsScrollPlugin }], propDecorators: { config: [{
|
|
179
220
|
type: Input
|
|
180
221
|
}], slideTemplate: [{
|
|
@@ -189,4 +230,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
189
230
|
type: ViewChild,
|
|
190
231
|
args: ["sliderHost", { static: false }]
|
|
191
232
|
}] } });
|
|
192
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-slider.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-edge-slider/src/lib/component/simple-slider.component.ts","../../../../../projects/ngx-edge-slider/src/lib/component/simple-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  OnInit,\r\n  TemplateRef,\r\n  Input,\r\n  EventEmitter,\r\n  Output,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  OnDestroy,\r\n  ViewChild,\r\n  ElementRef,\r\n  AfterViewInit,\r\n} from \"@angular/core\";\r\nimport { SliderViewState } from \"../models/slider-state.model\";\r\nimport { Observable, Subject, takeUntil } from \"rxjs\";\r\nimport { SliderConfig } from \"../models/slider-config.model\";\r\nimport { SliderEngine } from \"../engine/slider-engine.service\";\r\nimport { SliderStore } from \"../store/slider-store.service\";\r\nimport { SliderAutoplayPlugin } from \"../plugins/autoplay.plugin\";\r\nimport { SliderDraggablePlugin } from \"../plugins/draggable/draggable.plugin\";\r\nimport { SliderNavigationPlugin } from \"../plugins/navigation/navigation.plugin\";\r\nimport { SliderPaginationPlugin } from \"../plugins/pagination/pagination.plugin\";\r\nimport { SliderThumbsScrollPlugin } from \"../plugins/thumbs/thumbs-scroll.plugin\";\r\nimport { SliderPlugin } from \"../plugins/slider-plugin\";\r\nimport { CommonModule } from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: \"app-simple-slider\",\r\n  templateUrl: \"./simple-slider.component.html\",\r\n  styleUrl: \"./simple-slider.component.scss\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [CommonModule],\r\n  providers: [\r\n    SliderEngine,\r\n    SliderStore,\r\n    SliderDraggablePlugin,\r\n    SliderPaginationPlugin,\r\n    SliderNavigationPlugin,\r\n    SliderAutoplayPlugin,\r\n    SliderThumbsScrollPlugin,\r\n  ],\r\n})\r\nexport class SimpleSliderComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n  @Input() config: SliderConfig;\r\n  @Input() slideTemplate?: TemplateRef<any>;\r\n  @Input() navigationTemplate?: TemplateRef<any>;\r\n  @Input() paginationTemplate?: TemplateRef<any>;\r\n  @Output() slideChange = new EventEmitter<number>();\r\n\r\n  private isDraggingPointer = false;\r\n  private dragStartX = 0;\r\n  private dragStartY = 0;\r\n  private lastIndex = -1;\r\n  private lastSlidesRef: any[] | null = null;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  state$: Observable<SliderViewState>;\r\n  @ViewChild(\"sliderHost\", { static: false }) sliderHost?: ElementRef<HTMLElement>;\r\n\r\n  constructor(\r\n    private engine: SliderEngine,\r\n    private store: SliderStore,\r\n    private draggable: SliderDraggablePlugin,\r\n    private pagination: SliderPaginationPlugin,\r\n    private navigation: SliderNavigationPlugin,\r\n    private autoplay: SliderAutoplayPlugin,\r\n    private thumbs: SliderThumbsScrollPlugin,\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.state$ = this.store.view$;\r\n\r\n    this.state$.pipe(takeUntil(this.destroy$)).subscribe((state) => {\r\n      if (state.currentSlide !== this.lastIndex) {\r\n        this.lastIndex = state.currentSlide;\r\n        this.slideChange.emit(state.currentSlide);\r\n      }\r\n    });\r\n    this.lastSlidesRef = this.config?.slides ?? null;\r\n    this.engine.init({ ...this.config, plugins: this.config.plugins });\r\n  }\r\n  ngAfterViewInit() {\r\n    if (this.sliderHost?.nativeElement) {\r\n      this.engine.attachContainer(this.sliderHost.nativeElement);\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (!changes[\"config\"] || !this.config) return;\r\n\r\n    const newSlidesRef = this.config.slides ?? null;\r\n\r\n    if (newSlidesRef !== this.lastSlidesRef) {\r\n      this.lastSlidesRef = newSlidesRef;\r\n      this.engine.destroy();\r\n      this.resolvePlugins(this.config);\r\n    }\r\n  }\r\n  ngOnDestroy() {\r\n    this.destroySlider();\r\n  }\r\n\r\n  public goTo(index: number) {\r\n    this.engine.selectSlide(index); // add this line\r\n    //this.slideChange.emit(index);\r\n  }\r\n\r\n  destroySlider() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    this.engine.destroy();\r\n  } // destroys plugins and clears store\r\n\r\n  onNext() {\r\n    this.engine.next();\r\n  }\r\n  onPrevious() {\r\n    this.engine.previous();\r\n  }\r\n  selectSlide(index: number) {\r\n    this.engine.selectSlide(index);\r\n  }\r\n\r\n  // Handle Pointers\r\n\r\n  onPointerDown(event: PointerEvent) {\r\n    this.dragStartX = event.clientX;\r\n    this.dragStartY = event.clientY;\r\n    this.isDraggingPointer = false;\r\n\r\n    // Do not capture yet; wait until movement exceeds threshold\r\n    this.engine.handleDragStart(event);\r\n  }\r\n\r\n  onPointerMove(event: PointerEvent) {\r\n    const dx = Math.abs(event.clientX - this.dragStartX);\r\n    const dy = Math.abs(event.clientY - this.dragStartY);\r\n\r\n    if (!this.isDraggingPointer && (dx > 5 || dy > 5)) {\r\n      this.isDraggingPointer = true;\r\n\r\n      // Now start capturing pointer so dragging works outside the slider bounds\r\n      (event.currentTarget as HTMLElement).setPointerCapture(event.pointerId);\r\n    }\r\n\r\n    if (this.isDraggingPointer) {\r\n      this.engine.handleDragMove(event);\r\n    }\r\n  }\r\n\r\n  onPointerUp(event: PointerEvent) {\r\n    if (!event) return;\r\n\r\n    if (!this.isDraggingPointer) {\r\n      const target = event.target as HTMLElement;\r\n\r\n      // Only select the slide if click is not on an interactive child\r\n      const slideEl = target.closest(\".slide\");\r\n      if (slideEl && !target.closest(\"button, video, a\")) {\r\n        const indexAttr = slideEl.getAttribute(\"data-index\");\r\n        const index = indexAttr ? parseInt(indexAttr, 10) : null;\r\n        if (index !== null) this.engine.selectSlide(index);\r\n      }\r\n    }\r\n\r\n    this.engine.handleDragEnd();\r\n    this.isDraggingPointer = false;\r\n\r\n    // Release pointer capture if it was captured\r\n    try {\r\n      (event.currentTarget as HTMLElement).releasePointerCapture(event.pointerId);\r\n    } catch {}\r\n  }\r\n\r\n  private resolvePlugins(config: SliderConfig) {\r\n    const runtimePlugins: SliderPlugin[] = [];\r\n\r\n    const cfg = config.plugins;\r\n\r\n    if (cfg?.draggable) runtimePlugins.push(this.draggable);\r\n    if (cfg?.pagination) runtimePlugins.push(this.pagination);\r\n    if (cfg?.navigation) runtimePlugins.push(this.navigation);\r\n\r\n    if (cfg?.autoplay) {\r\n      this.autoplay.setConfig(cfg.autoplay);\r\n      runtimePlugins.push(this.autoplay);\r\n    }\r\n\r\n    if (cfg?.thumbs) runtimePlugins.push(this.thumbs);\r\n\r\n    this.engine.init({ ...config, plugins: undefined }, runtimePlugins);\r\n  }\r\n}\r\n","<ng-container *ngIf=\"state$ | async as state\">\r\n  <div\r\n    class=\"slider\"\r\n    #sliderHost\r\n    [class.slider-vertical]=\"state.vertical\"\r\n    [class.slider-draggable]=\"state.isDragging\"\r\n    [class.slider--main]=\"!config.isThumbs\"\r\n    [class.slider--thumbs]=\"config.isThumbs\"\r\n    *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n    (pointerdown)=\"onPointerDown($event)\"\r\n    (pointermove)=\"onPointerMove($event)\"\r\n    (pointerup)=\"onPointerUp($event)\"\r\n    (pointercancel)=\"onPointerUp($event)\">\r\n    <div\r\n      class=\"slider__wrapper\"\r\n      [ngStyle]=\"{\r\n        transform: state.translate,\r\n        transition: state.transition,\r\n        display: 'flex',\r\n        'flex-direction': state.vertical ? 'column' : 'row',\r\n        'justify-content': state.visibleSlides?.length < state.slidesPerView ? 'center' : 'flex-start',\r\n        gap: (state.slidesPerView > 1 ? state.gap || 0 : 0) + 'px',\r\n      }\">\r\n      <div\r\n        *ngFor=\"let slide of state.visibleSlides; let i = index\"\r\n        class=\"slide\"\r\n        [attr.data-index]=\"i\"\r\n        [class.slide--current]=\"state.selectedSlide === i\"\r\n        [style.flex]=\"\r\n          !config.isThumbs\r\n            ? '0 0 calc(' +\r\n              100 / state.slidesPerView +\r\n              '% - ' +\r\n              ((state.gap || 0) * (state.slidesPerView - 1)) / state.slidesPerView +\r\n              'px)'\r\n            : '0 0 ' + thumbSize + 'px'\r\n        \"\r\n        [style.width]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n        [style.height]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n        (click)=\"engine.selectSlide(i)\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"slideTemplate ? slideTemplate : defaultSlideTemplate; context: { slide: slide, index: i }\"></ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n"]}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-slider.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-edge-slider/src/lib/component/simple-slider.component.ts","../../../../../projects/ngx-edge-slider/src/lib/component/simple-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  OnInit,\r\n  TemplateRef,\r\n  Input,\r\n  EventEmitter,\r\n  Output,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  OnDestroy,\r\n  ViewChild,\r\n  ElementRef,\r\n  AfterViewInit,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { SliderViewState } from \"../models/slider-state.model\";\r\nimport { Observable, Subject, takeUntil } from \"rxjs\";\r\nimport { SliderConfig } from \"../models/slider-config.model\";\r\nimport { SliderEngine } from \"../engine/slider-engine.service\";\r\nimport { SliderStore } from \"../store/slider-store.service\";\r\nimport { SliderAutoplayPlugin } from \"../plugins/autoplay/autoplay.plugin\";\r\nimport { SliderDraggablePlugin } from \"../plugins/draggable/draggable.plugin\";\r\nimport { SliderNavigationPlugin } from \"../plugins/navigation/navigation.plugin\";\r\nimport { Pager, SliderPaginationPlugin } from \"../plugins/pagination/pagination.plugin\";\r\nimport { SliderThumbsScrollPlugin } from \"../plugins/thumbs/thumbs-scroll.plugin\";\r\nimport { SliderPlugin } from \"../plugins/slider-plugin\";\r\nimport { CommonModule } from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: \"app-simple-slider\",\r\n  templateUrl: \"./simple-slider.component.html\",\r\n  styleUrl: \"./simple-slider.component.scss\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  standalone: true,\r\n  imports: [CommonModule],\r\n  providers: [\r\n    SliderEngine,\r\n    SliderStore,\r\n    SliderDraggablePlugin,\r\n    SliderPaginationPlugin,\r\n    SliderNavigationPlugin,\r\n    SliderAutoplayPlugin,\r\n    SliderThumbsScrollPlugin,\r\n  ],\r\n})\r\nexport class SimpleSliderComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n  @Input() config: SliderConfig;\r\n  @Input() slideTemplate?: TemplateRef<any>;\r\n  @Input() navigationTemplate?: TemplateRef<any>;\r\n  @Input() paginationTemplate?: TemplateRef<any>;\r\n  @Output() slideChange = new EventEmitter<number>();\r\n\r\n  private isDraggingPointer = false;\r\n  private dragStartX = 0;\r\n  private dragStartY = 0;\r\n  private lastIndex = -1;\r\n  private lastSlidesRef: any[] | null = null;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  state$: Observable<SliderViewState>;\r\n  @ViewChild(\"sliderHost\", { static: false }) sliderHost?: ElementRef<HTMLElement>;\r\n\r\n  constructor(\r\n    private engine: SliderEngine,\r\n    private store: SliderStore,\r\n    private draggable: SliderDraggablePlugin,\r\n    private pagination: SliderPaginationPlugin,\r\n    private navigation: SliderNavigationPlugin,\r\n    private autoplay: SliderAutoplayPlugin,\r\n    private thumbs: SliderThumbsScrollPlugin,\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.state$ = this.store.view$;\r\n\r\n    this.state$.pipe(takeUntil(this.destroy$)).subscribe((state) => {\r\n      if (state.currentSlide !== this.lastIndex) {\r\n        this.lastIndex = state.currentSlide;\r\n        this.slideChange.emit(state.currentSlide);\r\n      }\r\n    });\r\n    this.lastSlidesRef = this.config?.slides ?? null;\r\n    this.resolvePlugins(this.config);\r\n  }\r\n  ngAfterViewInit() {\r\n    if (this.sliderHost?.nativeElement) {\r\n      this.engine.attachContainer(this.sliderHost.nativeElement);\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (!changes[\"config\"] || !this.config) return;\r\n\r\n    const newSlidesRef = this.config.slides ?? null;\r\n\r\n    if (newSlidesRef !== this.lastSlidesRef) {\r\n      this.lastSlidesRef = newSlidesRef;\r\n      this.engine.destroy();\r\n      this.resolvePlugins(this.config);\r\n    }\r\n  }\r\n  ngOnDestroy() {\r\n    this.destroySlider();\r\n  }\r\n\r\n  public goTo(index: number) {\r\n    this.engine.selectSlide(index); // add this line\r\n    //this.slideChange.emit(index);\r\n  }\r\n\r\n  destroySlider() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    this.engine.destroy();\r\n  } // destroys plugins and clears store\r\n\r\n  onNext() {\r\n    this.engine.next();\r\n  }\r\n  onPrevious() {\r\n    this.engine.previous();\r\n  }\r\n  selectSlide(index: number) {\r\n    this.engine.selectSlide(index);\r\n  }\r\n  onRecalculate() {\r\n    this.engine.recalculate();\r\n  }\r\n  // Navigation\r\n  /** Expose navigation observables safely */\r\n  get canPrev$(): Observable<boolean> | null {\r\n    if (!this.navigation) {\r\n      console.warn(\"Navigation plugin is not enabled.\");\r\n      return null;\r\n    }\r\n    return this.navigation.canPrev$;\r\n  }\r\n\r\n  get canNext$(): Observable<boolean> | null {\r\n    if (!this.navigation) {\r\n      console.warn(\"Navigation plugin is not enabled.\");\r\n      return null;\r\n    }\r\n    return this.navigation.canNext$;\r\n  }\r\n\r\n  /** Expose next/prev methods */\r\n  public next() {\r\n    this.navigation?.next();\r\n  }\r\n\r\n  public prev() {\r\n    this.navigation?.prev();\r\n  }\r\n\r\n  /** Expose pagination observable */\r\n  get pager$(): Observable<Pager | null> | null {\r\n    if (!this.pagination) {\r\n      console.warn(\"Pagination plugin is not enabled for this slider.\");\r\n      return null;\r\n    }\r\n    return this.pagination.pager$;\r\n  }\r\n\r\n  /** Expose a goToSlide method */\r\n  public goToSlide(index: number) {\r\n    this.pagination.goToSlide(index);\r\n  }\r\n\r\n  // Handle Pointers\r\n\r\n  onPointerDown(event: PointerEvent) {\r\n    console.log(\"down\");\r\n    this.dragStartX = event.clientX;\r\n    this.dragStartY = event.clientY;\r\n    this.isDraggingPointer = false;\r\n\r\n    // Do not capture yet; wait until movement exceeds threshold\r\n    this.engine.handleDragStart(event);\r\n  }\r\n\r\n  onPointerMove(event: PointerEvent) {\r\n    console.log(\"move\");\r\n    const dx = Math.abs(event.clientX - this.dragStartX);\r\n    const dy = Math.abs(event.clientY - this.dragStartY);\r\n\r\n    if (!this.isDraggingPointer && (dx > 5 || dy > 5)) {\r\n      this.isDraggingPointer = true;\r\n\r\n      // Now start capturing pointer so dragging works outside the slider bounds\r\n      (event.currentTarget as HTMLElement).setPointerCapture(event.pointerId);\r\n    }\r\n\r\n    if (this.isDraggingPointer) {\r\n      this.engine.handleDragMove(event);\r\n    }\r\n  }\r\n\r\n  onPointerUp(event: PointerEvent) {\r\n    if (!event) return;\r\n\r\n    console.log(\"up\");\r\n    if (!this.isDraggingPointer) {\r\n      const target = event.target as HTMLElement;\r\n\r\n      // Only select the slide if click is not on an interactive child\r\n      const slideEl = target.closest(\".slide\");\r\n      if (slideEl && !target.closest(\"button, video, a\")) {\r\n        const indexAttr = slideEl.getAttribute(\"data-index\");\r\n        const index = indexAttr ? parseInt(indexAttr, 10) : null;\r\n        if (index !== null) this.engine.selectSlide(index);\r\n      }\r\n    }\r\n\r\n    this.engine.handleDragEnd();\r\n    this.isDraggingPointer = false;\r\n\r\n    // Release pointer capture if it was captured\r\n    try {\r\n      (event.currentTarget as HTMLElement).releasePointerCapture(event.pointerId);\r\n    } catch {}\r\n  }\r\n\r\n  private resolvePlugins(config: SliderConfig) {\r\n    const runtimePlugins: SliderPlugin[] = [];\r\n\r\n    const cfg = config.plugins ?? {}; // <-- safe fallback\r\n\r\n    if (cfg.draggable) runtimePlugins.push(this.draggable);\r\n    if (cfg.pagination) runtimePlugins.push(this.pagination);\r\n    if (cfg.navigation) runtimePlugins.push(this.navigation);\r\n\r\n    if (cfg.autoplay) {\r\n      this.autoplay.setConfig(cfg.autoplay);\r\n      runtimePlugins.push(this.autoplay);\r\n    }\r\n\r\n    if (cfg.thumbs) runtimePlugins.push(this.thumbs);\r\n\r\n    this.engine.init({ ...config, plugins: undefined }, runtimePlugins);\r\n  }\r\n}\r\n","<ng-container *ngIf=\"state$ | async as state\">\r\n  <div\r\n    class=\"slider\"\r\n    #sliderHost\r\n    [class.slider-vertical]=\"state.vertical\"\r\n    [class.slider-draggable]=\"state.isDragging\"\r\n    [class.slider--main]=\"!config.isThumbs\"\r\n    [class.slider--thumbs]=\"config.isThumbs\"\r\n    *ngIf=\"state.visibleSlides?.length > 0 && state.isVisible\"\r\n    (pointerdown)=\"onPointerDown($event)\"\r\n    (pointermove)=\"onPointerMove($event)\"\r\n    (pointerup)=\"onPointerUp($event)\"\r\n    (pointercancel)=\"onPointerUp($event)\">\r\n    <div\r\n      class=\"slider__wrapper\"\r\n      [ngStyle]=\"{\r\n        transform: state.translate,\r\n        transition: draggable.isDraggingPointer ? 'none' : 'transform 0.3s ease',\r\n        display: 'flex',\r\n        'flex-direction': state.vertical ? 'column' : 'row',\r\n        'justify-content': state.visibleSlides?.length < state.slidesPerView ? 'center' : 'flex-start',\r\n        gap: (state.slidesPerView > 1 ? state.gap || 0 : 0) + 'px',\r\n      }\">\r\n      <div\r\n        *ngFor=\"let slide of state.visibleSlides; let i = index\"\r\n        class=\"slide\"\r\n        [attr.data-index]=\"i\"\r\n        [class.slide--current]=\"state.selectedSlide === i\"\r\n        [style.flex]=\"\r\n          !config.isThumbs\r\n            ? '0 0 calc(' +\r\n              100 / state.slidesPerView +\r\n              '% - ' +\r\n              ((state.gap || 0) * (state.slidesPerView - 1)) / state.slidesPerView +\r\n              'px)'\r\n            : '0 0 ' + thumbSize + 'px'\r\n        \"\r\n        [style.width]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n        [style.height]=\"config.isThumbs ? thumbSize + 'px' : null\"\r\n        (click)=\"engine.selectSlide(i)\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"slideTemplate ? slideTemplate : defaultSlideTemplate; context: { slide: slide, index: i }\"></ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n"]}
|
|
@@ -19,12 +19,10 @@ export class SliderEngine {
|
|
|
19
19
|
}
|
|
20
20
|
/* ---------------- Public API ---------------- */
|
|
21
21
|
init(config, plugins = []) {
|
|
22
|
-
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
22
|
+
this.config = { ...DEFAULT_CONFIG, ...config, plugins: { ...(config.plugins ?? {}) } };
|
|
23
23
|
this.plugins = plugins;
|
|
24
24
|
this.plugins.forEach((p) => p.init?.(this));
|
|
25
|
-
// Viewport signals (fallback + orientation support)
|
|
26
25
|
this.setupViewportSignals();
|
|
27
|
-
// Initial layout
|
|
28
26
|
this.applyBreakpoint();
|
|
29
27
|
this.clampIndicesAfterLayoutChange();
|
|
30
28
|
this.recalculate();
|
|
@@ -68,13 +66,17 @@ export class SliderEngine {
|
|
|
68
66
|
this.store.reset();
|
|
69
67
|
}
|
|
70
68
|
next() {
|
|
71
|
-
|
|
69
|
+
console.log("next");
|
|
70
|
+
this.goTo(this.store.snapshot.currentSlide + this.slideStep());
|
|
72
71
|
this.plugins.forEach((p) => p.onNext?.());
|
|
73
72
|
}
|
|
74
73
|
previous() {
|
|
75
|
-
this.
|
|
74
|
+
this.goTo(this.store.snapshot.currentSlide - this.slideStep());
|
|
76
75
|
this.plugins.forEach((p) => p.onPrevious?.());
|
|
77
76
|
}
|
|
77
|
+
getContainerEl() {
|
|
78
|
+
return this.containerEl;
|
|
79
|
+
}
|
|
78
80
|
selectSlide(index) {
|
|
79
81
|
const slidesPerView = this.store.snapshot.slidesPerView;
|
|
80
82
|
// 1️⃣ Mark selected
|
|
@@ -121,6 +123,8 @@ export class SliderEngine {
|
|
|
121
123
|
this.plugins.forEach((p) => p.onSlideClick?.(index));
|
|
122
124
|
}
|
|
123
125
|
recalculate() {
|
|
126
|
+
if (this.store.snapshot.isDragging)
|
|
127
|
+
return; // skip during drag
|
|
124
128
|
const slides = this.config.slides ?? [];
|
|
125
129
|
const maxStartIndex = this.getMaxStartIndex();
|
|
126
130
|
const current = this.store.snapshot.currentSlide;
|
|
@@ -128,7 +132,6 @@ export class SliderEngine {
|
|
|
128
132
|
visibleSlides: slides,
|
|
129
133
|
translate: this.translate(current),
|
|
130
134
|
pager: this.config.plugins.pagination ? this.buildPager() : null,
|
|
131
|
-
// ✅ add
|
|
132
135
|
maxStartIndex,
|
|
133
136
|
canPrev: current > 0,
|
|
134
137
|
canNext: current < maxStartIndex,
|
|
@@ -283,4 +286,4 @@ export class SliderEngine {
|
|
|
283
286
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SliderEngine, decorators: [{
|
|
284
287
|
type: Injectable
|
|
285
288
|
}], ctorParameters: () => [{ type: i1.SliderStore }] });
|
|
286
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-engine.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-edge-slider/src/lib/engine/slider-engine.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { fromEvent, merge, Subject, auditTime, takeUntil } from \"rxjs\";\r\nimport { SliderConfig, DEFAULT_CONFIG } from \"../models/slider-config.model\";\r\nimport { SliderViewState } from \"../models/slider-state.model\";\r\nimport { SliderPlugin } from \"../plugins/slider-plugin\";\r\nimport { SliderStore } from \"../store/slider-store.service\";\r\n\r\n@Injectable()\r\nexport class SliderEngine {\r\n  private config!: SliderConfig;\r\n  private plugins: SliderPlugin[] = [];\r\n  private syncThumbsEngine?: SliderEngine;\r\n\r\n  // RX lifecycle\r\n  private destroy$ = new Subject<void>();\r\n\r\n  // Container-based breakpoints\r\n  private containerEl?: HTMLElement;\r\n  private ro?: ResizeObserver;\r\n\r\n  private measuredSlideSizePx?: number;\r\n\r\n  constructor(private store: SliderStore) {}\r\n\r\n  /* ---------------- Public API ---------------- */\r\n\r\n  init(config: SliderConfig, plugins: SliderPlugin[] = []) {\r\n    this.config = { ...DEFAULT_CONFIG, ...config };\r\n    this.plugins = plugins;\r\n\r\n    this.plugins.forEach((p) => p.init?.(this));\r\n\r\n    // Viewport signals (fallback + orientation support)\r\n    this.setupViewportSignals();\r\n\r\n    // Initial layout\r\n    this.applyBreakpoint();\r\n    this.clampIndicesAfterLayoutChange();\r\n    this.recalculate();\r\n  }\r\n\r\n  /** Call this from the component once you have the slider host element */\r\n  attachContainer(el: HTMLElement) {\r\n    this.containerEl = el;\r\n\r\n    // Observe container size changes (robust in grids/sidebars/tabs)\r\n    this.ro?.disconnect();\r\n    this.ro = new ResizeObserver(() => {\r\n      // We reuse the same debounced layout handler\r\n      this.onLayoutSignal();\r\n    });\r\n    this.ro.observe(el);\r\n\r\n    this.measureSlideSize();\r\n    // Apply immediately based on real container width\r\n    this.onLayoutSignal();\r\n  }\r\n  private measureSlideSize() {\r\n    if (!this.containerEl) return;\r\n    const firstSlide = this.containerEl.querySelector<HTMLElement>(\".slide\");\r\n    if (!firstSlide) return;\r\n    const rect = firstSlide.getBoundingClientRect();\r\n    if (rect.width > 0) this.measuredSlideSizePx = rect.width;\r\n  }\r\n  destroy() {\r\n    // Stop Rx streams\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n\r\n    // Disconnect ResizeObserver\r\n    this.ro?.disconnect();\r\n    this.ro = undefined;\r\n    this.containerEl = undefined;\r\n\r\n    // Plugin cleanup\r\n    this.plugins.forEach((p) => p.destroy?.());\r\n    this.plugins = [];\r\n\r\n    // Reset store\r\n    this.store.reset();\r\n  }\r\n\r\n  next() {\r\n    this.goToSlide(this.store.snapshot.currentSlide + this.slideStep());\r\n    this.plugins.forEach((p) => p.onNext?.());\r\n  }\r\n\r\n  previous() {\r\n    this.goToSlide(this.store.snapshot.currentSlide - this.slideStep());\r\n    this.plugins.forEach((p) => p.onPrevious?.());\r\n  }\r\n\r\n  selectSlide(index: number) {\r\n    const slidesPerView = this.store.snapshot.slidesPerView;\r\n\r\n    // 1️⃣ Mark selected\r\n    this.store.update({ selectedSlide: index });\r\n\r\n    // 2️⃣ Calculate page start\r\n    let pageStart = Math.floor(index / slidesPerView) * slidesPerView;\r\n\r\n    // 3️⃣ Clamp to maxStartIndex\r\n    pageStart = Math.min(pageStart, this.maxStartIndex);\r\n\r\n    // 4️⃣ If synced with thumbs, also clamp to their max index\r\n    if (this.syncThumbsEngine) {\r\n      const thumbMaxIndex = this.syncThumbsEngine.getMaxStartIndex();\r\n      pageStart = Math.min(pageStart, thumbMaxIndex);\r\n    }\r\n\r\n    // 5️⃣ Move main slider\r\n    if (pageStart !== this.store.snapshot.currentSlide) {\r\n      this.goToSlide(pageStart);\r\n    }\r\n\r\n    // 6️⃣ Notify plugins\r\n    this.plugins.forEach((p) => p.onSlideClick?.(index));\r\n  }\r\n\r\n  /* ---------------- Drag ---------------- */\r\n\r\n  handleDragStart(event: PointerEvent) {\r\n    this.store.update({ isDragging: true });\r\n    this.plugins.forEach((p) => p.onDragStart?.(event));\r\n  }\r\n\r\n  handleDragMove(event: PointerEvent) {\r\n    this.plugins.forEach((p) => p.onDragMove?.(event));\r\n  }\r\n\r\n  handleDragEnd() {\r\n    this.store.update({ isDragging: false });\r\n    this.plugins.forEach((p) => p.onDragEnd?.());\r\n  }\r\n  public goTo(index: number) {\r\n    this.goToSlide(index); // reuse your existing private method\r\n  }\r\n  /* ---------------- Internals ---------------- */\r\n\r\n  private goToSlide(index: number) {\r\n    const clamped = Math.max(0, Math.min(index, this.maxStartIndex));\r\n    // console.log(\"[Engine] goToSlide index:\", index, \"clamped:\", clamped);\r\n\r\n    this.store.update({ currentSlide: clamped });\r\n    this.recalculate();\r\n\r\n    // NOTE: calling onSlideClick here is a bit semantically odd (since it’s not always a click),\r\n    // but I preserved your behavior.\r\n    this.plugins.forEach((p) => p.onSlideClick?.(index));\r\n  }\r\n\r\n  private recalculate() {\r\n    const slides = this.config.slides ?? [];\r\n    const maxStartIndex = this.getMaxStartIndex();\r\n    const current = this.store.snapshot.currentSlide;\r\n\r\n    this.store.update({\r\n      visibleSlides: slides,\r\n      translate: this.translate(current),\r\n      pager: this.config.plugins.pagination ? this.buildPager() : null,\r\n\r\n      // ✅ add\r\n      maxStartIndex,\r\n      canPrev: current > 0,\r\n      canNext: current < maxStartIndex,\r\n    });\r\n  }\r\n\r\n  private translate(index: number): string {\r\n    const axis = this.config.vertical ? \"Y\" : \"X\";\r\n\r\n    const containerSize = this.containerEl\r\n      ? this.config.vertical\r\n        ? this.containerEl.clientHeight\r\n        : this.containerEl.clientWidth\r\n      : this.config.vertical\r\n        ? window.innerHeight\r\n        : window.innerWidth;\r\n\r\n    const gap = this.store.snapshot.gap ?? 0;\r\n\r\n    const spv = this.store.snapshot.slidesPerView;\r\n    const slideSize =\r\n      this.config.isThumbs && this.measuredSlideSizePx\r\n        ? this.measuredSlideSizePx\r\n        : spv > 0\r\n          ? (containerSize - gap * (spv - 1)) / spv\r\n          : containerSize;\r\n\r\n    // move by \"pageStart * (slideSize + gap)\"\r\n    const offset = index * (slideSize + gap);\r\n\r\n    return `translate${axis}(-${offset}px)`;\r\n  }\r\n\r\n  /** Debounced layout signals for resize/orientation/container changes */\r\n  private setupViewportSignals() {\r\n    // If you want \"only after resizing stops\", replace auditTime with debounceTime(120)\r\n    const resize$ = fromEvent(window, \"resize\", { passive: true } as any);\r\n    const orientation$ = fromEvent(window, \"orientationchange\", { passive: true } as any);\r\n\r\n    merge(resize$, orientation$)\r\n      .pipe(\r\n        auditTime(80), // good compromise: responsive without over-recalc\r\n        takeUntil(this.destroy$),\r\n      )\r\n      .subscribe(() => this.onLayoutSignal());\r\n  }\r\n\r\n  private onLayoutSignal() {\r\n    const beforeSlidesPerView = this.store.snapshot.slidesPerView;\r\n    const beforeVisible = this.store.snapshot.isVisible;\r\n\r\n    this.applyBreakpoint();\r\n\r\n    const afterSlidesPerView = this.store.snapshot.slidesPerView;\r\n    const afterVisible = this.store.snapshot.isVisible;\r\n\r\n    if (beforeSlidesPerView !== afterSlidesPerView || beforeVisible !== afterVisible) {\r\n      this.clampIndicesAfterLayoutChange();\r\n    }\r\n\r\n    this.measureSlideSize();\r\n\r\n    this.recalculate();\r\n  }\r\n\r\n  private getBreakpointWidth(): number {\r\n    if (this.containerEl) {\r\n      // Prefer clientWidth (layout), fallback to rect width\r\n      return this.containerEl.clientWidth || this.containerEl.getBoundingClientRect().width || window.innerWidth;\r\n    }\r\n    return window.innerWidth;\r\n  }\r\n\r\n  private applyBreakpoint() {\r\n    const width = this.getBreakpointWidth();\r\n    const bp = this.config.breakpoints;\r\n\r\n    let override: Partial<SliderConfig> | undefined;\r\n    let device: \"mobile\" | \"tablet\" | \"desktop\" = \"desktop\";\r\n\r\n    if (width < 768) {\r\n      override = bp?.mobile;\r\n      device = \"mobile\";\r\n    } else if (width < 1024) {\r\n      override = bp?.tablet;\r\n      device = \"tablet\";\r\n    } else {\r\n      override = bp?.desktop;\r\n      device = \"desktop\";\r\n    }\r\n\r\n    // Merge overrides\r\n    this.config = { ...this.config, ...override };\r\n\r\n    this.store.update({\r\n      slidesPerView: this.config.slidesPerView,\r\n      gap: this.config.gap ?? 0, // ✅ NEW\r\n      isVisible: this.config.showOn?.[device] ?? true,\r\n    });\r\n  }\r\n\r\n  private clampIndicesAfterLayoutChange() {\r\n    const max = this.getMaxStartIndex();\r\n\r\n    const current = this.store.snapshot.currentSlide;\r\n    const selected = this.store.snapshot.selectedSlide;\r\n\r\n    const clampedCurrent = Math.max(0, Math.min(current, max));\r\n    const clampedSelected = selected === -1 ? -1 : Math.max(0, Math.min(selected, (this.config.slides?.length ?? 0) - 1));\r\n\r\n    this.store.update({\r\n      currentSlide: clampedCurrent,\r\n      selectedSlide: clampedSelected,\r\n    });\r\n  }\r\n\r\n  private buildPager() {\r\n    const totalSlides = this.config.slides.length;\r\n    const currentSlide = this.store.snapshot.selectedSlide !== -1 ? this.store.snapshot.selectedSlide : this.store.snapshot.currentSlide;\r\n\r\n    const maxVisibleDots = 5;\r\n\r\n    let start = Math.max(0, currentSlide - Math.floor(maxVisibleDots / 2));\r\n    let end = start + maxVisibleDots;\r\n\r\n    if (end > totalSlides) {\r\n      end = totalSlides;\r\n      start = Math.max(0, end - maxVisibleDots);\r\n    }\r\n\r\n    const visibleDots = Array.from({ length: end - start }, (_, i) => start + i);\r\n    const activeDotIndex = visibleDots.indexOf(currentSlide);\r\n\r\n    return {\r\n      currentPage: currentSlide,\r\n      totalPages: totalSlides,\r\n      visibleDots,\r\n      activeDotIndex,\r\n    };\r\n  }\r\n\r\n  private slideStep() {\r\n    return this.store.snapshot.slidesPerView;\r\n  }\r\n\r\n  private get maxStartIndex() {\r\n    const total = this.config.slides?.length ?? 0;\r\n    return Math.max(0, total - this.store.snapshot.slidesPerView);\r\n  }\r\n  getMaxStartIndex() {\r\n    const total = this.config.slides?.length ?? 0;\r\n    const spv = this.store.snapshot.slidesPerView || 1;\r\n    return Math.max(0, total - spv);\r\n  }\r\n  /* -------- Plugin-safe API -------- */\r\n\r\n  getState() {\r\n    return this.store.snapshot;\r\n  }\r\n\r\n  getStateObservable() {\r\n    return this.store.view$;\r\n  }\r\n\r\n  setState(patch: Partial<SliderViewState>) {\r\n    this.store.update(patch);\r\n  }\r\n\r\n  getConfig() {\r\n    return this.config;\r\n  }\r\n\r\n  /** Link this slider to thumbs */\r\n  syncWithThumbs(thumbsEngine: SliderEngine) {\r\n    this.syncThumbsEngine = thumbsEngine;\r\n  }\r\n\r\n  /* -------- Read-only helpers -------- */\r\n\r\n  getSlidesPerView(): number {\r\n    return this.store.snapshot.slidesPerView;\r\n  }\r\n\r\n  getCurrentSlide(): number {\r\n    return this.store.snapshot.currentSlide;\r\n  }\r\n\r\n  getSelectedSlide(): number {\r\n    return this.store.snapshot.selectedSlide;\r\n  }\r\n}\r\n"]}
|
|
289
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-engine.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-edge-slider/src/lib/engine/slider-engine.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { fromEvent, merge, Subject, auditTime, takeUntil } from \"rxjs\";\r\nimport { SliderConfig, DEFAULT_CONFIG } from \"../models/slider-config.model\";\r\nimport { SliderViewState } from \"../models/slider-state.model\";\r\nimport { SliderPlugin } from \"../plugins/slider-plugin\";\r\nimport { SliderStore } from \"../store/slider-store.service\";\r\n\r\n@Injectable()\r\nexport class SliderEngine {\r\n  private config!: SliderConfig;\r\n  private plugins: SliderPlugin[] = [];\r\n  private syncThumbsEngine?: SliderEngine;\r\n\r\n  // RX lifecycle\r\n  private destroy$ = new Subject<void>();\r\n\r\n  // Container-based breakpoints\r\n  private containerEl?: HTMLElement;\r\n  private ro?: ResizeObserver;\r\n\r\n  private measuredSlideSizePx?: number;\r\n\r\n  constructor(private store: SliderStore) {}\r\n\r\n  /* ---------------- Public API ---------------- */\r\n\r\n  init(config: SliderConfig, plugins: SliderPlugin[] = []) {\r\n    this.config = { ...DEFAULT_CONFIG, ...config, plugins: { ...(config.plugins ?? {}) } };\r\n    this.plugins = plugins;\r\n\r\n    this.plugins.forEach((p) => p.init?.(this));\r\n\r\n    this.setupViewportSignals();\r\n    this.applyBreakpoint();\r\n    this.clampIndicesAfterLayoutChange();\r\n    this.recalculate();\r\n  }\r\n\r\n  /** Call this from the component once you have the slider host element */\r\n  attachContainer(el: HTMLElement) {\r\n    this.containerEl = el;\r\n\r\n    // Observe container size changes (robust in grids/sidebars/tabs)\r\n    this.ro?.disconnect();\r\n    this.ro = new ResizeObserver(() => {\r\n      // We reuse the same debounced layout handler\r\n      this.onLayoutSignal();\r\n    });\r\n    this.ro.observe(el);\r\n\r\n    this.measureSlideSize();\r\n    // Apply immediately based on real container width\r\n    this.onLayoutSignal();\r\n  }\r\n  private measureSlideSize() {\r\n    if (!this.containerEl) return;\r\n    const firstSlide = this.containerEl.querySelector<HTMLElement>(\".slide\");\r\n    if (!firstSlide) return;\r\n    const rect = firstSlide.getBoundingClientRect();\r\n    if (rect.width > 0) this.measuredSlideSizePx = rect.width;\r\n  }\r\n  destroy() {\r\n    // Stop Rx streams\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n\r\n    // Disconnect ResizeObserver\r\n    this.ro?.disconnect();\r\n    this.ro = undefined;\r\n    this.containerEl = undefined;\r\n\r\n    // Plugin cleanup\r\n    this.plugins.forEach((p) => p.destroy?.());\r\n    this.plugins = [];\r\n\r\n    // Reset store\r\n    this.store.reset();\r\n  }\r\n\r\n  next() {\r\n    console.log(\"next\");\r\n    this.goTo(this.store.snapshot.currentSlide + this.slideStep());\r\n    this.plugins.forEach((p) => p.onNext?.());\r\n  }\r\n\r\n  previous() {\r\n    this.goTo(this.store.snapshot.currentSlide - this.slideStep());\r\n    this.plugins.forEach((p) => p.onPrevious?.());\r\n  }\r\n  public getContainerEl(): HTMLElement | undefined {\r\n    return this.containerEl;\r\n  }\r\n  selectSlide(index: number) {\r\n    const slidesPerView = this.store.snapshot.slidesPerView;\r\n\r\n    // 1️⃣ Mark selected\r\n    this.store.update({ selectedSlide: index });\r\n\r\n    // 2️⃣ Calculate page start\r\n    let pageStart = Math.floor(index / slidesPerView) * slidesPerView;\r\n\r\n    // 3️⃣ Clamp to maxStartIndex\r\n    pageStart = Math.min(pageStart, this.maxStartIndex);\r\n\r\n    // 4️⃣ If synced with thumbs, also clamp to their max index\r\n    if (this.syncThumbsEngine) {\r\n      const thumbMaxIndex = this.syncThumbsEngine.getMaxStartIndex();\r\n      pageStart = Math.min(pageStart, thumbMaxIndex);\r\n    }\r\n\r\n    // 5️⃣ Move main slider\r\n    if (pageStart !== this.store.snapshot.currentSlide) {\r\n      this.goToSlide(pageStart);\r\n    }\r\n\r\n    // 6️⃣ Notify plugins\r\n    this.plugins.forEach((p) => p.onSlideClick?.(index));\r\n  }\r\n\r\n  /* ---------------- Drag ---------------- */\r\n\r\n  handleDragStart(event: PointerEvent) {\r\n    this.store.update({ isDragging: true });\r\n    this.plugins.forEach((p) => p.onDragStart?.(event));\r\n  }\r\n  handleDragMove(event: PointerEvent) {\r\n    this.plugins.forEach((p) => p.onDragMove?.(event));\r\n  }\r\n  handleDragEnd() {\r\n    this.store.update({ isDragging: false });\r\n    this.plugins.forEach((p) => p.onDragEnd?.());\r\n  }\r\n  public goTo(index: number) {\r\n    this.goToSlide(index); // reuse your existing private method\r\n  }\r\n  /* ---------------- Internals ---------------- */\r\n\r\n  private goToSlide(index: number) {\r\n    const clamped = Math.max(0, Math.min(index, this.maxStartIndex));\r\n    // console.log(\"[Engine] goToSlide index:\", index, \"clamped:\", clamped);\r\n\r\n    this.store.update({ currentSlide: clamped });\r\n    this.recalculate();\r\n\r\n    // NOTE: calling onSlideClick here is a bit semantically odd (since it’s not always a click),\r\n    // but I preserved your behavior.\r\n    this.plugins.forEach((p) => p.onSlideClick?.(index));\r\n  }\r\n\r\n  public recalculate() {\r\n    if (this.store.snapshot.isDragging) return; // skip during drag\r\n    const slides = this.config.slides ?? [];\r\n    const maxStartIndex = this.getMaxStartIndex();\r\n    const current = this.store.snapshot.currentSlide;\r\n\r\n    this.store.update({\r\n      visibleSlides: slides,\r\n      translate: this.translate(current),\r\n      pager: this.config.plugins.pagination ? this.buildPager() : null,\r\n      maxStartIndex,\r\n      canPrev: current > 0,\r\n      canNext: current < maxStartIndex,\r\n    });\r\n  }\r\n\r\n  private translate(index: number): string {\r\n    const axis = this.config.vertical ? \"Y\" : \"X\";\r\n\r\n    const containerSize = this.containerEl\r\n      ? this.config.vertical\r\n        ? this.containerEl.clientHeight\r\n        : this.containerEl.clientWidth\r\n      : this.config.vertical\r\n        ? window.innerHeight\r\n        : window.innerWidth;\r\n\r\n    const gap = this.store.snapshot.gap ?? 0;\r\n\r\n    const spv = this.store.snapshot.slidesPerView;\r\n    const slideSize =\r\n      this.config.isThumbs && this.measuredSlideSizePx\r\n        ? this.measuredSlideSizePx\r\n        : spv > 0\r\n          ? (containerSize - gap * (spv - 1)) / spv\r\n          : containerSize;\r\n\r\n    // move by \"pageStart * (slideSize + gap)\"\r\n    const offset = index * (slideSize + gap);\r\n\r\n    return `translate${axis}(-${offset}px)`;\r\n  }\r\n\r\n  /** Debounced layout signals for resize/orientation/container changes */\r\n  private setupViewportSignals() {\r\n    // If you want \"only after resizing stops\", replace auditTime with debounceTime(120)\r\n    const resize$ = fromEvent(window, \"resize\", { passive: true } as any);\r\n    const orientation$ = fromEvent(window, \"orientationchange\", { passive: true } as any);\r\n\r\n    merge(resize$, orientation$)\r\n      .pipe(\r\n        auditTime(80), // good compromise: responsive without over-recalc\r\n        takeUntil(this.destroy$),\r\n      )\r\n      .subscribe(() => this.onLayoutSignal());\r\n  }\r\n\r\n  private onLayoutSignal() {\r\n    const beforeSlidesPerView = this.store.snapshot.slidesPerView;\r\n    const beforeVisible = this.store.snapshot.isVisible;\r\n\r\n    this.applyBreakpoint();\r\n\r\n    const afterSlidesPerView = this.store.snapshot.slidesPerView;\r\n    const afterVisible = this.store.snapshot.isVisible;\r\n\r\n    if (beforeSlidesPerView !== afterSlidesPerView || beforeVisible !== afterVisible) {\r\n      this.clampIndicesAfterLayoutChange();\r\n    }\r\n\r\n    this.measureSlideSize();\r\n\r\n    this.recalculate();\r\n  }\r\n\r\n  private getBreakpointWidth(): number {\r\n    if (this.containerEl) {\r\n      // Prefer clientWidth (layout), fallback to rect width\r\n      return this.containerEl.clientWidth || this.containerEl.getBoundingClientRect().width || window.innerWidth;\r\n    }\r\n    return window.innerWidth;\r\n  }\r\n\r\n  private applyBreakpoint() {\r\n    const width = this.getBreakpointWidth();\r\n    const bp = this.config.breakpoints;\r\n\r\n    let override: Partial<SliderConfig> | undefined;\r\n    let device: \"mobile\" | \"tablet\" | \"desktop\" = \"desktop\";\r\n\r\n    if (width < 768) {\r\n      override = bp?.mobile;\r\n      device = \"mobile\";\r\n    } else if (width < 1024) {\r\n      override = bp?.tablet;\r\n      device = \"tablet\";\r\n    } else {\r\n      override = bp?.desktop;\r\n      device = \"desktop\";\r\n    }\r\n\r\n    // Merge overrides\r\n    this.config = { ...this.config, ...override };\r\n\r\n    this.store.update({\r\n      slidesPerView: this.config.slidesPerView,\r\n      gap: this.config.gap ?? 0, // ✅ NEW\r\n      isVisible: this.config.showOn?.[device] ?? true,\r\n    });\r\n  }\r\n\r\n  private clampIndicesAfterLayoutChange() {\r\n    const max = this.getMaxStartIndex();\r\n\r\n    const current = this.store.snapshot.currentSlide;\r\n    const selected = this.store.snapshot.selectedSlide;\r\n\r\n    const clampedCurrent = Math.max(0, Math.min(current, max));\r\n    const clampedSelected = selected === -1 ? -1 : Math.max(0, Math.min(selected, (this.config.slides?.length ?? 0) - 1));\r\n\r\n    this.store.update({\r\n      currentSlide: clampedCurrent,\r\n      selectedSlide: clampedSelected,\r\n    });\r\n  }\r\n\r\n  private buildPager() {\r\n    const totalSlides = this.config.slides.length;\r\n    const currentSlide = this.store.snapshot.selectedSlide !== -1 ? this.store.snapshot.selectedSlide : this.store.snapshot.currentSlide;\r\n\r\n    const maxVisibleDots = 5;\r\n\r\n    let start = Math.max(0, currentSlide - Math.floor(maxVisibleDots / 2));\r\n    let end = start + maxVisibleDots;\r\n\r\n    if (end > totalSlides) {\r\n      end = totalSlides;\r\n      start = Math.max(0, end - maxVisibleDots);\r\n    }\r\n\r\n    const visibleDots = Array.from({ length: end - start }, (_, i) => start + i);\r\n    const activeDotIndex = visibleDots.indexOf(currentSlide);\r\n\r\n    return {\r\n      currentPage: currentSlide,\r\n      totalPages: totalSlides,\r\n      visibleDots,\r\n      activeDotIndex,\r\n    };\r\n  }\r\n\r\n  private slideStep() {\r\n    return this.store.snapshot.slidesPerView;\r\n  }\r\n\r\n  private get maxStartIndex() {\r\n    const total = this.config.slides?.length ?? 0;\r\n    return Math.max(0, total - this.store.snapshot.slidesPerView);\r\n  }\r\n  getMaxStartIndex() {\r\n    const total = this.config.slides?.length ?? 0;\r\n    const spv = this.store.snapshot.slidesPerView || 1;\r\n    return Math.max(0, total - spv);\r\n  }\r\n  /* -------- Plugin-safe API -------- */\r\n\r\n  getState() {\r\n    return this.store.snapshot;\r\n  }\r\n\r\n  getStateObservable() {\r\n    return this.store.view$;\r\n  }\r\n\r\n  setState(patch: Partial<SliderViewState>) {\r\n    this.store.update(patch);\r\n  }\r\n\r\n  getConfig() {\r\n    return this.config;\r\n  }\r\n\r\n  /** Link this slider to thumbs */\r\n  syncWithThumbs(thumbsEngine: SliderEngine) {\r\n    this.syncThumbsEngine = thumbsEngine;\r\n  }\r\n\r\n  /* -------- Read-only helpers -------- */\r\n\r\n  getSlidesPerView(): number {\r\n    return this.store.snapshot.slidesPerView;\r\n  }\r\n\r\n  getCurrentSlide(): number {\r\n    return this.store.snapshot.currentSlide;\r\n  }\r\n\r\n  getSelectedSlide(): number {\r\n    return this.store.snapshot.selectedSlide;\r\n  }\r\n}\r\n"]}
|
|
@@ -6,7 +6,14 @@ export const DEFAULT_CONFIG = {
|
|
|
6
6
|
vertical: false,
|
|
7
7
|
changeToClickedSlide: false,
|
|
8
8
|
isThumbs: false,
|
|
9
|
+
plugins: {
|
|
10
|
+
draggable: false,
|
|
11
|
+
pagination: false,
|
|
12
|
+
navigation: false,
|
|
13
|
+
autoplay: undefined,
|
|
14
|
+
thumbs: false,
|
|
15
|
+
},
|
|
9
16
|
gap: 0,
|
|
10
17
|
showOn: { mobile: true, tablet: true, desktop: true },
|
|
11
18
|
};
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1lZGdlLXNsaWRlci9zcmMvbGliL21vZGVscy9zbGlkZXItY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDQSxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQWlCO0lBQzFDLE1BQU0sRUFBRSxFQUFFO0lBQ1YsYUFBYSxFQUFFLENBQUM7SUFDaEIsYUFBYSxFQUFFLENBQUM7SUFDaEIsSUFBSSxFQUFFLENBQUM7SUFDUCxRQUFRLEVBQUUsS0FBSztJQUNmLG9CQUFvQixFQUFFLEtBQUs7SUFDM0IsUUFBUSxFQUFFLEtBQUs7SUFDZixPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsS0FBSztRQUNoQixVQUFVLEVBQUUsS0FBSztRQUNqQixVQUFVLEVBQUUsS0FBSztRQUNqQixRQUFRLEVBQUUsU0FBUztRQUNuQixNQUFNLEVBQUUsS0FBSztLQUNkO0lBQ0QsR0FBRyxFQUFFLENBQUM7SUFFTixNQUFNLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRTtDQUN0RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBdXRvcGxheVBsdWdpbkNvbmZpZyB7XHJcbiAgZGVsYXk/OiBudW1iZXI7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBTbGlkZXJQbHVnaW5Db25maWcge1xyXG4gIGRyYWdnYWJsZT86IGJvb2xlYW47XHJcbiAgYXV0b3BsYXk/OiB7IGRlbGF5PzogbnVtYmVyIH07XHJcbiAgbmF2aWdhdGlvbj86IGJvb2xlYW47XHJcbiAgcGFnaW5hdGlvbj86IGJvb2xlYW47XHJcbiAgdGh1bWJzPzogYm9vbGVhbjtcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIFNsaWRlckNvbmZpZyB7XHJcbiAgc2xpZGVzOiBhbnlbXTtcclxuICBzbGlkZXNQZXJWaWV3OiBudW1iZXI7XHJcbiAgc2xpZGVzVG9TbGlkZT86IG51bWJlcjtcclxuICBsb29wPzogMCB8IDEgfCAyO1xyXG4gIHZlcnRpY2FsPzogYm9vbGVhbjtcclxuICBjaGFuZ2VUb0NsaWNrZWRTbGlkZT86IGJvb2xlYW47XHJcbiAgaXNUaHVtYnM/OiBib29sZWFuO1xyXG5cclxuICAvKiogTkVXOiBnYXAgYmV0d2VlbiBzbGlkZXMgaW4gcHggKi9cclxuICBnYXA/OiBudW1iZXI7XHJcblxyXG4gIGJyZWFrcG9pbnRzPzoge1xyXG4gICAgbW9iaWxlPzogUGFydGlhbDxTbGlkZXJDb25maWc+O1xyXG4gICAgdGFibGV0PzogUGFydGlhbDxTbGlkZXJDb25maWc+O1xyXG4gICAgZGVza3RvcD86IFBhcnRpYWw8U2xpZGVyQ29uZmlnPjtcclxuICB9O1xyXG5cclxuICBwbHVnaW5zPzogU2xpZGVyUGx1Z2luQ29uZmlnO1xyXG5cclxuICBzaG93T24/OiB7XHJcbiAgICBtb2JpbGU/OiBib29sZWFuO1xyXG4gICAgdGFibGV0PzogYm9vbGVhbjtcclxuICAgIGRlc2t0b3A/OiBib29sZWFuO1xyXG4gIH07XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0NPTkZJRzogU2xpZGVyQ29uZmlnID0ge1xyXG4gIHNsaWRlczogW10sXHJcbiAgc2xpZGVzUGVyVmlldzogMSxcclxuICBzbGlkZXNUb1NsaWRlOiAxLFxyXG4gIGxvb3A6IDAsXHJcbiAgdmVydGljYWw6IGZhbHNlLFxyXG4gIGNoYW5nZVRvQ2xpY2tlZFNsaWRlOiBmYWxzZSxcclxuICBpc1RodW1iczogZmFsc2UsXHJcbiAgcGx1Z2luczoge1xyXG4gICAgZHJhZ2dhYmxlOiBmYWxzZSxcclxuICAgIHBhZ2luYXRpb246IGZhbHNlLFxyXG4gICAgbmF2aWdhdGlvbjogZmFsc2UsXHJcbiAgICBhdXRvcGxheTogdW5kZWZpbmVkLFxyXG4gICAgdGh1bWJzOiBmYWxzZSxcclxuICB9LFxyXG4gIGdhcDogMCxcclxuXHJcbiAgc2hvd09uOiB7IG1vYmlsZTogdHJ1ZSwgdGFibGV0OiB0cnVlLCBkZXNrdG9wOiB0cnVlIH0sXHJcbn07XHJcbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { NgModule } from "@angular/core";
|
|
2
|
-
import { SimpleSliderComponent } from "
|
|
2
|
+
import { SimpleSliderComponent } from "./component/simple-slider.component";
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class NgxEdgeSliderModule {
|
|
5
5
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NgxEdgeSliderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -13,4 +13,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
13
13
|
exports: [SimpleSliderComponent],
|
|
14
14
|
}]
|
|
15
15
|
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWVkZ2Utc2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1lZGdlLXNsaWRlci9zcmMvbGliL25neC1lZGdlLXNsaWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7QUFNNUUsTUFBTSxPQUFPLG1CQUFtQjt3R0FBbkIsbUJBQW1CO3lHQUFuQixtQkFBbUIsWUFIcEIscUJBQXFCLGFBQ3JCLHFCQUFxQjt5R0FFcEIsbUJBQW1CLFlBSHBCLHFCQUFxQjs7NEZBR3BCLG1CQUFtQjtrQkFKL0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDaEMsT0FBTyxFQUFFLENBQUMscUJBQXFCLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTaW1wbGVTbGlkZXJDb21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnQvc2ltcGxlLXNsaWRlci5jb21wb25lbnRcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1NpbXBsZVNsaWRlckNvbXBvbmVudF0sXHJcbiAgZXhwb3J0czogW1NpbXBsZVNsaWRlckNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOZ3hFZGdlU2xpZGVyTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SliderAutoplayPlugin {
|
|
4
|
+
engine;
|
|
5
|
+
timerId;
|
|
6
|
+
delay = 4000; // default
|
|
7
|
+
init(engine) {
|
|
8
|
+
this.engine = engine;
|
|
9
|
+
this.start();
|
|
10
|
+
}
|
|
11
|
+
setConfig(config) {
|
|
12
|
+
if (!config)
|
|
13
|
+
return;
|
|
14
|
+
if (typeof config.delay === "number") {
|
|
15
|
+
this.delay = config.delay;
|
|
16
|
+
}
|
|
17
|
+
// restart autoplay with new config
|
|
18
|
+
this.start();
|
|
19
|
+
}
|
|
20
|
+
onDragStart() {
|
|
21
|
+
this.stop();
|
|
22
|
+
}
|
|
23
|
+
onDragEnd() {
|
|
24
|
+
this.start();
|
|
25
|
+
}
|
|
26
|
+
start() {
|
|
27
|
+
this.stop();
|
|
28
|
+
this.timerId = setInterval(() => {
|
|
29
|
+
this.engine.next();
|
|
30
|
+
}, this.delay);
|
|
31
|
+
}
|
|
32
|
+
stop() {
|
|
33
|
+
if (this.timerId) {
|
|
34
|
+
clearInterval(this.timerId);
|
|
35
|
+
this.timerId = null;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
destroy() {
|
|
39
|
+
this.stop();
|
|
40
|
+
}
|
|
41
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SliderAutoplayPlugin, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
42
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SliderAutoplayPlugin });
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SliderAutoplayPlugin, decorators: [{
|
|
45
|
+
type: Injectable
|
|
46
|
+
}] });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b3BsYXkucGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWVkZ2Utc2xpZGVyL3NyYy9saWIvcGx1Z2lucy9hdXRvcGxheS9hdXRvcGxheS5wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLG9CQUFvQjtJQUN2QixNQUFNLENBQWdCO0lBQ3RCLE9BQU8sQ0FBTTtJQUNiLEtBQUssR0FBRyxJQUFJLENBQUMsQ0FBQyxVQUFVO0lBRWhDLElBQUksQ0FBQyxNQUFvQjtRQUN2QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQTZCO1FBQ3JDLElBQUksQ0FBQyxNQUFNO1lBQUUsT0FBTztRQUVwQixJQUFJLE9BQU8sTUFBTSxDQUFDLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUNyQyxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUM7UUFDNUIsQ0FBQztRQUVELG1DQUFtQztRQUNuQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2YsQ0FBQztJQUVPLEtBQUs7UUFDWCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDWixJQUFJLENBQUMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDOUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNyQixDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pCLENBQUM7SUFFTyxJQUFJO1FBQ1YsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDakIsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM1QixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUN0QixDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO3dHQTdDVSxvQkFBb0I7NEdBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFEaEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTbGlkZXJQbHVnaW4gfSBmcm9tIFwiLi4vc2xpZGVyLXBsdWdpblwiO1xyXG5pbXBvcnQgeyBTbGlkZXJFbmdpbmUgfSBmcm9tIFwiLi4vLi4vZW5naW5lL3NsaWRlci1lbmdpbmUuc2VydmljZVwiO1xyXG5pbXBvcnQgeyBBdXRvcGxheVBsdWdpbkNvbmZpZyB9IGZyb20gXCIuLi8uLi9tb2RlbHMvc2xpZGVyLWNvbmZpZy5tb2RlbFwiO1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBTbGlkZXJBdXRvcGxheVBsdWdpbiBpbXBsZW1lbnRzIFNsaWRlclBsdWdpbiB7XHJcbiAgcHJpdmF0ZSBlbmdpbmUhOiBTbGlkZXJFbmdpbmU7XHJcbiAgcHJpdmF0ZSB0aW1lcklkOiBhbnk7XHJcbiAgcHJpdmF0ZSBkZWxheSA9IDQwMDA7IC8vIGRlZmF1bHRcclxuXHJcbiAgaW5pdChlbmdpbmU6IFNsaWRlckVuZ2luZSkge1xyXG4gICAgdGhpcy5lbmdpbmUgPSBlbmdpbmU7XHJcbiAgICB0aGlzLnN0YXJ0KCk7XHJcbiAgfVxyXG5cclxuICBzZXRDb25maWcoY29uZmlnPzogQXV0b3BsYXlQbHVnaW5Db25maWcpIHtcclxuICAgIGlmICghY29uZmlnKSByZXR1cm47XHJcblxyXG4gICAgaWYgKHR5cGVvZiBjb25maWcuZGVsYXkgPT09IFwibnVtYmVyXCIpIHtcclxuICAgICAgdGhpcy5kZWxheSA9IGNvbmZpZy5kZWxheTtcclxuICAgIH1cclxuXHJcbiAgICAvLyByZXN0YXJ0IGF1dG9wbGF5IHdpdGggbmV3IGNvbmZpZ1xyXG4gICAgdGhpcy5zdGFydCgpO1xyXG4gIH1cclxuXHJcbiAgb25EcmFnU3RhcnQoKSB7XHJcbiAgICB0aGlzLnN0b3AoKTtcclxuICB9XHJcblxyXG4gIG9uRHJhZ0VuZCgpIHtcclxuICAgIHRoaXMuc3RhcnQoKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgc3RhcnQoKSB7XHJcbiAgICB0aGlzLnN0b3AoKTtcclxuICAgIHRoaXMudGltZXJJZCA9IHNldEludGVydmFsKCgpID0+IHtcclxuICAgICAgdGhpcy5lbmdpbmUubmV4dCgpO1xyXG4gICAgfSwgdGhpcy5kZWxheSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHN0b3AoKSB7XHJcbiAgICBpZiAodGhpcy50aW1lcklkKSB7XHJcbiAgICAgIGNsZWFySW50ZXJ2YWwodGhpcy50aW1lcklkKTtcclxuICAgICAgdGhpcy50aW1lcklkID0gbnVsbDtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLnN0b3AoKTtcclxuICB9XHJcbn1cclxuIl19
|