ngx-edge-slider 1.0.1 → 2.0.1
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/README.md +24 -104
- package/esm2022/lib/component/simple-slider.component.mjs +192 -0
- package/esm2022/lib/engine/slider-engine.service.mjs +286 -0
- package/esm2022/lib/models/slider-config.model.mjs +12 -0
- package/esm2022/lib/models/slider-state.model.mjs +17 -0
- package/esm2022/lib/ngx-edge-slider.module.mjs +16 -0
- package/esm2022/lib/plugins/autoplay.plugin.mjs +47 -0
- package/esm2022/lib/plugins/draggable/draggable.plugin.mjs +47 -0
- package/esm2022/lib/plugins/navigation/navigation.plugin.mjs +85 -0
- package/esm2022/lib/plugins/pagination/pagination.plugin.mjs +50 -0
- package/esm2022/lib/plugins/slider-plugin.mjs +2 -0
- package/esm2022/lib/plugins/thumbs/thumbs-scroll.plugin.mjs +38 -0
- package/esm2022/lib/safe-url.pipe.mjs +19 -0
- package/esm2022/lib/store/slider-store.service.mjs +34 -0
- package/esm2022/ngx-edge-slider.mjs +5 -0
- package/esm2022/public-api.mjs +9 -0
- package/fesm2022/ngx-edge-slider.mjs +814 -0
- package/fesm2022/ngx-edge-slider.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/component/simple-slider.component.d.ts +50 -0
- package/lib/engine/slider-engine.service.d.ts +52 -0
- package/lib/models/slider-config.model.d.ts +35 -0
- package/lib/models/slider-state.model.d.ts +22 -0
- package/lib/ngx-edge-slider.module.d.ts +7 -0
- package/lib/plugins/autoplay.plugin.d.ts +18 -0
- package/lib/plugins/draggable/draggable.plugin.d.ts +17 -0
- package/lib/plugins/navigation/navigation.plugin.d.ts +21 -0
- package/lib/plugins/pagination/pagination.plugin.d.ts +22 -0
- package/lib/plugins/slider-plugin.d.ts +11 -0
- package/lib/plugins/thumbs/thumbs-scroll.plugin.d.ts +15 -0
- package/lib/safe-url.pipe.d.ts +10 -0
- package/lib/store/slider-store.service.d.ts +11 -0
- package/ngx-edge-slider-2.0.0.tgz +0 -0
- package/package.json +19 -18
- package/public-api.d.ts +5 -0
- package/ngx-edge-slider-workspace/.editorconfig +0 -16
- package/ngx-edge-slider-workspace/.vscode/extensions.json +0 -4
- package/ngx-edge-slider-workspace/.vscode/launch.json +0 -20
- package/ngx-edge-slider-workspace/.vscode/tasks.json +0 -42
- package/ngx-edge-slider-workspace/README.md +0 -104
- package/ngx-edge-slider-workspace/angular.json +0 -140
- package/ngx-edge-slider-workspace/package-lock.json +0 -13339
- package/ngx-edge-slider-workspace/package.json +0 -39
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/README.md +0 -24
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/ng-package.json +0 -7
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/package.json +0 -12
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/assets/icons/arrow-black.svg +0 -3
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/assets/icons/arrow-gray.svg +0 -3
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.component.html +0 -78
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.component.scss +0 -344
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.component.ts +0 -610
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.interface.ts +0 -34
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.module.ts +0 -18
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/lib/ngx-edge-slider.service.ts +0 -9
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/src/public-api.ts +0 -7
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/tsconfig.lib.json +0 -14
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/tsconfig.lib.prod.json +0 -10
- package/ngx-edge-slider-workspace/projects/ngx-edge-slider/tsconfig.spec.json +0 -14
- package/ngx-edge-slider-workspace/projects/test-app/src/app/app.component.html +0 -11
- package/ngx-edge-slider-workspace/projects/test-app/src/app/app.component.scss +0 -0
- package/ngx-edge-slider-workspace/projects/test-app/src/app/app.component.spec.ts +0 -27
- package/ngx-edge-slider-workspace/projects/test-app/src/app/app.component.ts +0 -57
- package/ngx-edge-slider-workspace/projects/test-app/src/app/app.module.ts +0 -18
- package/ngx-edge-slider-workspace/projects/test-app/src/assets/.gitkeep +0 -0
- package/ngx-edge-slider-workspace/projects/test-app/src/assets/slide2_desktop_1950x.webp +0 -0
- package/ngx-edge-slider-workspace/projects/test-app/src/favicon.ico +0 -0
- package/ngx-edge-slider-workspace/projects/test-app/src/index.html +0 -13
- package/ngx-edge-slider-workspace/projects/test-app/src/main.ts +0 -7
- package/ngx-edge-slider-workspace/projects/test-app/src/styles.scss +0 -1
- package/ngx-edge-slider-workspace/projects/test-app/tsconfig.app.json +0 -14
- package/ngx-edge-slider-workspace/projects/test-app/tsconfig.spec.json +0 -14
- package/ngx-edge-slider-workspace/tsconfig.json +0 -39
package/README.md
CHANGED
|
@@ -1,104 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
loop: Number of times the slides will loop. Set to 0 for infinite looping.
|
|
26
|
-
vertical: If set to true, the slider will display slides vertically.
|
|
27
|
-
navEnabled: Enable navigation arrows.
|
|
28
|
-
navPosition: Position of the navigation arrows.
|
|
29
|
-
navHoverable: If true, navigation arrows will be visible only on hover.
|
|
30
|
-
paginationEnabled: Enable pagination dots.
|
|
31
|
-
paginationPosition: Position of the pagination dots.
|
|
32
|
-
breakpoints: Define slide configuration based on breakpoints for responsive behavior (mobile, tablet, desktop).
|
|
33
|
-
Responsive Support:
|
|
34
|
-
Configure the slider's behavior for different screen sizes using breakpoints. The library allows customization for:
|
|
35
|
-
|
|
36
|
-
Mobile (mobile): Custom slide configuration for mobile devices.
|
|
37
|
-
Tablet (tablet): Tailored configuration for tablet-sized screens.
|
|
38
|
-
Desktop (desktop): Adjustments for desktop layouts.
|
|
39
|
-
Usage Example:
|
|
40
|
-
To use the Edge Slider in your Angular 17+ application, follow the steps below:
|
|
41
|
-
|
|
42
|
-
Import the Module: First, import the EdgeSliderModule into your AppModule or the module where you want to use the slider.
|
|
43
|
-
typescript
|
|
44
|
-
Copy code
|
|
45
|
-
import { EdgeSliderModule } from '@your-username/edge-slider';
|
|
46
|
-
|
|
47
|
-
@NgModule({
|
|
48
|
-
imports: [EdgeSliderModule],
|
|
49
|
-
// other configurations...
|
|
50
|
-
})
|
|
51
|
-
export class AppModule { }
|
|
52
|
-
Component HTML: You can use the lib-ngx-edge-slider component in your template. Here's how to initialize it in your Angular component.
|
|
53
|
-
|
|
54
|
-
<!-- Initialize EdgeSlider component in your template -->
|
|
55
|
-
<lib-ngx-edge-slider *ngIf="sliderConfig.slides?.length"
|
|
56
|
-
[config]="sliderConfig"
|
|
57
|
-
id="EdgeSlider"
|
|
58
|
-
[slideTemplate]="EdgeSliderTemplate"
|
|
59
|
-
(onSlideChange)="onSlideChange($event)">
|
|
60
|
-
</lib-ngx-edge-slider>
|
|
61
|
-
|
|
62
|
-
<!-- Define the template for the slides -->
|
|
63
|
-
<ng-template #EdgeSliderTemplate let-slide="slide" let-index="currentSlide">
|
|
64
|
-
<!-- Template rendering logic here -->
|
|
65
|
-
<!-- 'slide' is our entity, and its properties can be accessed, like slide.id, slide.image -->
|
|
66
|
-
<img [src]="slide.image" alt="Slide image">
|
|
67
|
-
</ng-template>
|
|
68
|
-
|
|
69
|
-
Component TypeScript: In your component's .ts file, define the sliderConfig with the desired slide settings, and create an onSlideChange handler for capturing slide change events.
|
|
70
|
-
typescript
|
|
71
|
-
|
|
72
|
-
import { Component } from '@angular/core';
|
|
73
|
-
import { SlideConfig } from '@your-username/edge-slider'; // Import your library
|
|
74
|
-
|
|
75
|
-
@Component({
|
|
76
|
-
selector: 'app-your-component',
|
|
77
|
-
templateUrl: './your-component.component.html',
|
|
78
|
-
styleUrls: ['./your-component.component.css'],
|
|
79
|
-
})
|
|
80
|
-
export class YourComponent {
|
|
81
|
-
// Define the slider configuration
|
|
82
|
-
sliderConfig: SlideConfig = new SlideConfig({
|
|
83
|
-
slides: [
|
|
84
|
-
{ id: 1, image: 'path_to_image_1.jpg' },
|
|
85
|
-
{ id: 2, image: 'path_to_image_2.jpg' },
|
|
86
|
-
{ id: 3, image: 'path_to_image_3.jpg' },
|
|
87
|
-
],
|
|
88
|
-
autoPlay: true,
|
|
89
|
-
delay: 3000, // Set autoplay delay
|
|
90
|
-
loop: 0, // Infinite loop
|
|
91
|
-
slidesToSlide: 1,
|
|
92
|
-
slidesPerView: 1,
|
|
93
|
-
navEnabled: true, // Enable navigation
|
|
94
|
-
paginationEnabled: true, // Enable pagination dots
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
// Handle slide change event
|
|
98
|
-
onSlideChange(event: any): void {
|
|
99
|
-
console.log('Slide changed to: ', event);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
Summary
|
|
104
|
-
This package provides an easy-to-integrate, flexible Angular component for building interactive and responsive sliders. With options for autoplay, navigation, pagination, and breakpoints, it adapts to various use cases, making it a powerful tool for displaying image galleries, content carousels, and more.
|
|
1
|
+
# NgxEdgeSlider
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.2.0.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project ngx-edge-slider` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project ngx-edge-slider`.
|
|
8
|
+
> Note: Don't forget to add `--project ngx-edge-slider` or else it will be added to the default project in your `angular.json` file.
|
|
9
|
+
|
|
10
|
+
## Build
|
|
11
|
+
|
|
12
|
+
Run `ng build ngx-edge-slider` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
13
|
+
|
|
14
|
+
## Publishing
|
|
15
|
+
|
|
16
|
+
After building your library with `ng build ngx-edge-slider`, go to the dist folder `cd dist/ngx-edge-slider` and run `npm publish`.
|
|
17
|
+
|
|
18
|
+
## Running unit tests
|
|
19
|
+
|
|
20
|
+
Run `ng test ngx-edge-slider` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
21
|
+
|
|
22
|
+
## Further help
|
|
23
|
+
|
|
24
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page.
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, Input, EventEmitter, Output, ViewChild, } from "@angular/core";
|
|
2
|
+
import { Subject, takeUntil } from "rxjs";
|
|
3
|
+
import { SliderEngine } from "../engine/slider-engine.service";
|
|
4
|
+
import { SliderStore } from "../store/slider-store.service";
|
|
5
|
+
import { SliderAutoplayPlugin } from "../plugins/autoplay.plugin";
|
|
6
|
+
import { SliderDraggablePlugin } from "../plugins/draggable/draggable.plugin";
|
|
7
|
+
import { SliderNavigationPlugin } from "../plugins/navigation/navigation.plugin";
|
|
8
|
+
import { SliderPaginationPlugin } from "../plugins/pagination/pagination.plugin";
|
|
9
|
+
import { SliderThumbsScrollPlugin } from "../plugins/thumbs/thumbs-scroll.plugin";
|
|
10
|
+
import { CommonModule } from "@angular/common";
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../engine/slider-engine.service";
|
|
13
|
+
import * as i2 from "../store/slider-store.service";
|
|
14
|
+
import * as i3 from "../plugins/draggable/draggable.plugin";
|
|
15
|
+
import * as i4 from "../plugins/pagination/pagination.plugin";
|
|
16
|
+
import * as i5 from "../plugins/navigation/navigation.plugin";
|
|
17
|
+
import * as i6 from "../plugins/autoplay.plugin";
|
|
18
|
+
import * as i7 from "../plugins/thumbs/thumbs-scroll.plugin";
|
|
19
|
+
import * as i8 from "@angular/common";
|
|
20
|
+
export class SimpleSliderComponent {
|
|
21
|
+
engine;
|
|
22
|
+
store;
|
|
23
|
+
draggable;
|
|
24
|
+
pagination;
|
|
25
|
+
navigation;
|
|
26
|
+
autoplay;
|
|
27
|
+
thumbs;
|
|
28
|
+
config;
|
|
29
|
+
slideTemplate;
|
|
30
|
+
navigationTemplate;
|
|
31
|
+
paginationTemplate;
|
|
32
|
+
slideChange = new EventEmitter();
|
|
33
|
+
isDraggingPointer = false;
|
|
34
|
+
dragStartX = 0;
|
|
35
|
+
dragStartY = 0;
|
|
36
|
+
lastIndex = -1;
|
|
37
|
+
lastSlidesRef = null;
|
|
38
|
+
destroy$ = new Subject();
|
|
39
|
+
state$;
|
|
40
|
+
sliderHost;
|
|
41
|
+
constructor(engine, store, draggable, pagination, navigation, autoplay, thumbs) {
|
|
42
|
+
this.engine = engine;
|
|
43
|
+
this.store = store;
|
|
44
|
+
this.draggable = draggable;
|
|
45
|
+
this.pagination = pagination;
|
|
46
|
+
this.navigation = navigation;
|
|
47
|
+
this.autoplay = autoplay;
|
|
48
|
+
this.thumbs = thumbs;
|
|
49
|
+
}
|
|
50
|
+
ngOnInit() {
|
|
51
|
+
this.state$ = this.store.view$;
|
|
52
|
+
this.state$.pipe(takeUntil(this.destroy$)).subscribe((state) => {
|
|
53
|
+
if (state.currentSlide !== this.lastIndex) {
|
|
54
|
+
this.lastIndex = state.currentSlide;
|
|
55
|
+
this.slideChange.emit(state.currentSlide);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
this.lastSlidesRef = this.config?.slides ?? null;
|
|
59
|
+
this.engine.init({ ...this.config, plugins: this.config.plugins });
|
|
60
|
+
}
|
|
61
|
+
ngAfterViewInit() {
|
|
62
|
+
if (this.sliderHost?.nativeElement) {
|
|
63
|
+
this.engine.attachContainer(this.sliderHost.nativeElement);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
ngOnChanges(changes) {
|
|
67
|
+
if (!changes["config"] || !this.config)
|
|
68
|
+
return;
|
|
69
|
+
const newSlidesRef = this.config.slides ?? null;
|
|
70
|
+
if (newSlidesRef !== this.lastSlidesRef) {
|
|
71
|
+
this.lastSlidesRef = newSlidesRef;
|
|
72
|
+
this.engine.destroy();
|
|
73
|
+
this.resolvePlugins(this.config);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
ngOnDestroy() {
|
|
77
|
+
this.destroySlider();
|
|
78
|
+
}
|
|
79
|
+
goTo(index) {
|
|
80
|
+
this.engine.selectSlide(index); // add this line
|
|
81
|
+
//this.slideChange.emit(index);
|
|
82
|
+
}
|
|
83
|
+
destroySlider() {
|
|
84
|
+
this.destroy$.next();
|
|
85
|
+
this.destroy$.complete();
|
|
86
|
+
this.engine.destroy();
|
|
87
|
+
} // destroys plugins and clears store
|
|
88
|
+
onNext() {
|
|
89
|
+
this.engine.next();
|
|
90
|
+
}
|
|
91
|
+
onPrevious() {
|
|
92
|
+
this.engine.previous();
|
|
93
|
+
}
|
|
94
|
+
selectSlide(index) {
|
|
95
|
+
this.engine.selectSlide(index);
|
|
96
|
+
}
|
|
97
|
+
// Handle Pointers
|
|
98
|
+
onPointerDown(event) {
|
|
99
|
+
this.dragStartX = event.clientX;
|
|
100
|
+
this.dragStartY = event.clientY;
|
|
101
|
+
this.isDraggingPointer = false;
|
|
102
|
+
// Do not capture yet; wait until movement exceeds threshold
|
|
103
|
+
this.engine.handleDragStart(event);
|
|
104
|
+
}
|
|
105
|
+
onPointerMove(event) {
|
|
106
|
+
const dx = Math.abs(event.clientX - this.dragStartX);
|
|
107
|
+
const dy = Math.abs(event.clientY - this.dragStartY);
|
|
108
|
+
if (!this.isDraggingPointer && (dx > 5 || dy > 5)) {
|
|
109
|
+
this.isDraggingPointer = true;
|
|
110
|
+
// Now start capturing pointer so dragging works outside the slider bounds
|
|
111
|
+
event.currentTarget.setPointerCapture(event.pointerId);
|
|
112
|
+
}
|
|
113
|
+
if (this.isDraggingPointer) {
|
|
114
|
+
this.engine.handleDragMove(event);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
onPointerUp(event) {
|
|
118
|
+
if (!event)
|
|
119
|
+
return;
|
|
120
|
+
if (!this.isDraggingPointer) {
|
|
121
|
+
const target = event.target;
|
|
122
|
+
// Only select the slide if click is not on an interactive child
|
|
123
|
+
const slideEl = target.closest(".slide");
|
|
124
|
+
if (slideEl && !target.closest("button, video, a")) {
|
|
125
|
+
const indexAttr = slideEl.getAttribute("data-index");
|
|
126
|
+
const index = indexAttr ? parseInt(indexAttr, 10) : null;
|
|
127
|
+
if (index !== null)
|
|
128
|
+
this.engine.selectSlide(index);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
this.engine.handleDragEnd();
|
|
132
|
+
this.isDraggingPointer = false;
|
|
133
|
+
// Release pointer capture if it was captured
|
|
134
|
+
try {
|
|
135
|
+
event.currentTarget.releasePointerCapture(event.pointerId);
|
|
136
|
+
}
|
|
137
|
+
catch { }
|
|
138
|
+
}
|
|
139
|
+
resolvePlugins(config) {
|
|
140
|
+
const runtimePlugins = [];
|
|
141
|
+
const cfg = config.plugins;
|
|
142
|
+
if (cfg?.draggable)
|
|
143
|
+
runtimePlugins.push(this.draggable);
|
|
144
|
+
if (cfg?.pagination)
|
|
145
|
+
runtimePlugins.push(this.pagination);
|
|
146
|
+
if (cfg?.navigation)
|
|
147
|
+
runtimePlugins.push(this.navigation);
|
|
148
|
+
if (cfg?.autoplay) {
|
|
149
|
+
this.autoplay.setConfig(cfg.autoplay);
|
|
150
|
+
runtimePlugins.push(this.autoplay);
|
|
151
|
+
}
|
|
152
|
+
if (cfg?.thumbs)
|
|
153
|
+
runtimePlugins.push(this.thumbs);
|
|
154
|
+
this.engine.init({ ...config, plugins: undefined }, runtimePlugins);
|
|
155
|
+
}
|
|
156
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SimpleSliderComponent, deps: [{ token: i1.SliderEngine }, { token: i2.SliderStore }, { token: i3.SliderDraggablePlugin }, { token: i4.SliderPaginationPlugin }, { token: i5.SliderNavigationPlugin }, { token: i6.SliderAutoplayPlugin }, { token: i7.SliderThumbsScrollPlugin }], target: i0.ɵɵFactoryTarget.Component });
|
|
157
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: SimpleSliderComponent, isStandalone: true, selector: "app-simple-slider", inputs: { config: "config", slideTemplate: "slideTemplate", navigationTemplate: "navigationTemplate", paginationTemplate: "paginationTemplate" }, outputs: { slideChange: "slideChange" }, providers: [
|
|
158
|
+
SliderEngine,
|
|
159
|
+
SliderStore,
|
|
160
|
+
SliderDraggablePlugin,
|
|
161
|
+
SliderPaginationPlugin,
|
|
162
|
+
SliderNavigationPlugin,
|
|
163
|
+
SliderAutoplayPlugin,
|
|
164
|
+
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: 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", 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:pan-y;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.slider.slider-draggable{cursor:grabbing}.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{position:relative;z-index:1}.navigation-slider .nav-btn{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 });
|
|
166
|
+
}
|
|
167
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: SimpleSliderComponent, decorators: [{
|
|
168
|
+
type: Component,
|
|
169
|
+
args: [{ selector: "app-simple-slider", changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule], providers: [
|
|
170
|
+
SliderEngine,
|
|
171
|
+
SliderStore,
|
|
172
|
+
SliderDraggablePlugin,
|
|
173
|
+
SliderPaginationPlugin,
|
|
174
|
+
SliderNavigationPlugin,
|
|
175
|
+
SliderAutoplayPlugin,
|
|
176
|
+
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: 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", 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:pan-y;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.slider.slider-draggable{cursor:grabbing}.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{position:relative;z-index:1}.navigation-slider .nav-btn{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
|
+
}], 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
|
+
type: Input
|
|
180
|
+
}], slideTemplate: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], navigationTemplate: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}], paginationTemplate: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], slideChange: [{
|
|
187
|
+
type: Output
|
|
188
|
+
}], sliderHost: [{
|
|
189
|
+
type: ViewChild,
|
|
190
|
+
args: ["sliderHost", { static: false }]
|
|
191
|
+
}] } });
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLXNsaWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZWRnZS1zbGlkZXIvc3JjL2xpYi9jb21wb25lbnQvc2ltcGxlLXNsaWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZWRnZS1zbGlkZXIvc3JjL2xpYi9jb21wb25lbnQvc2ltcGxlLXNsaWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULHVCQUF1QixFQUd2QixLQUFLLEVBQ0wsWUFBWSxFQUNaLE1BQU0sRUFJTixTQUFTLEdBR1YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFjLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFdEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQy9ELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNqRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNqRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUVsRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7Ozs7Ozs7QUFtQi9DLE1BQU0sT0FBTyxxQkFBcUI7SUFrQnRCO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBdkJELE1BQU0sQ0FBZTtJQUNyQixhQUFhLENBQW9CO0lBQ2pDLGtCQUFrQixDQUFvQjtJQUN0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LElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxhQUNaO3dCQUNULFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxxQkFBcUI7d0JBQ3JCLHNCQUFzQjt3QkFDdEIsc0JBQXNCO3dCQUN0QixvQkFBb0I7d0JBQ3BCLHdCQUF3QjtxQkFDekI7bVNBR1EsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLO2dCQUNHLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDSSxXQUFXO3NCQUFwQixNQUFNO2dCQVVxQyxVQUFVO3NCQUFyRCxTQUFTO3VCQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBPbkluaXQsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbiAgSW5wdXQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIE91dHB1dCxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIE9uQ2hhbmdlcyxcclxuICBPbkRlc3Ryb3ksXHJcbiAgVmlld0NoaWxkLFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgQWZ0ZXJWaWV3SW5pdCxcclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTbGlkZXJWaWV3U3RhdGUgfSBmcm9tIFwiLi4vbW9kZWxzL3NsaWRlci1zdGF0ZS5tb2RlbFwiO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0LCB0YWtlVW50aWwgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBTbGlkZXJDb25maWcgfSBmcm9tIFwiLi4vbW9kZWxzL3NsaWRlci1jb25maWcubW9kZWxcIjtcclxuaW1wb3J0IHsgU2xpZGVyRW5naW5lIH0gZnJvbSBcIi4uL2VuZ2luZS9zbGlkZXItZW5naW5lLnNlcnZpY2VcIjtcclxuaW1wb3J0IHsgU2xpZGVyU3RvcmUgfSBmcm9tIFwiLi4vc3RvcmUvc2xpZGVyLXN0b3JlLnNlcnZpY2VcIjtcclxuaW1wb3J0IHsgU2xpZGVyQXV0b3BsYXlQbHVnaW4gfSBmcm9tIFwiLi4vcGx1Z2lucy9hdXRvcGxheS5wbHVnaW5cIjtcclxuaW1wb3J0IHsgU2xpZGVyRHJhZ2dhYmxlUGx1Z2luIH0gZnJvbSBcIi4uL3BsdWdpbnMvZHJhZ2dhYmxlL2RyYWdnYWJsZS5wbHVnaW5cIjtcclxuaW1wb3J0IHsgU2xpZGVyTmF2aWdhdGlvblBsdWdpbiB9IGZyb20gXCIuLi9wbHVnaW5zL25hdmlnYXRpb24vbmF2aWdhdGlvbi5wbHVnaW5cIjtcclxuaW1wb3J0IHsgU2xpZGVyUGFnaW5hdGlvblBsdWdpbiB9IGZyb20gXCIuLi9wbHVnaW5zL3BhZ2luYXRpb24vcGFnaW5hdGlvbi5wbHVnaW5cIjtcclxuaW1wb3J0IHsgU2xpZGVyVGh1bWJzU2Nyb2xsUGx1Z2luIH0gZnJvbSBcIi4uL3BsdWdpbnMvdGh1bWJzL3RodW1icy1zY3JvbGwucGx1Z2luXCI7XHJcbmltcG9ydCB7IFNsaWRlclBsdWdpbiB9IGZyb20gXCIuLi9wbHVnaW5zL3NsaWRlci1wbHVnaW5cIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiYXBwLXNpbXBsZS1zbGlkZXJcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3NpbXBsZS1zbGlkZXIuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybDogXCIuL3NpbXBsZS1zbGlkZXIuY29tcG9uZW50LnNjc3NcIixcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAgU2xpZGVyRW5naW5lLFxyXG4gICAgU2xpZGVyU3RvcmUsXHJcbiAgICBTbGlkZXJEcmFnZ2FibGVQbHVnaW4sXHJcbiAgICBTbGlkZXJQYWdpbmF0aW9uUGx1Z2luLFxyXG4gICAgU2xpZGVyTmF2aWdhdGlvblBsdWdpbixcclxuICAgIFNsaWRlckF1dG9wbGF5UGx1Z2luLFxyXG4gICAgU2xpZGVyVGh1bWJzU2Nyb2xsUGx1Z2luLFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTaW1wbGVTbGlkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcclxuICBASW5wdXQoKSBjb25maWc6IFNsaWRlckNvbmZpZztcclxuICBASW5wdXQoKSBzbGlkZVRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuICBASW5wdXQoKSBuYXZpZ2F0aW9uVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIEBJbnB1dCgpIHBhZ2luYXRpb25UZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgQE91dHB1dCgpIHNsaWRlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcblxyXG4gIHByaXZhdGUgaXNEcmFnZ2luZ1BvaW50ZXIgPSBmYWxzZTtcclxuICBwcml2YXRlIGRyYWdTdGFydFggPSAwO1xyXG4gIHByaXZhdGUgZHJhZ1N0YXJ0WSA9IDA7XHJcbiAgcHJpdmF0ZSBsYXN0SW5kZXggPSAtMTtcclxuICBwcml2YXRlIGxhc3RTbGlkZXNSZWY6IGFueVtdIHwgbnVsbCA9IG51bGw7XHJcbiAgcHJpdmF0ZSBkZXN0cm95JCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcblxyXG4gIHN0YXRlJDogT2JzZXJ2YWJsZTxTbGlkZXJWaWV3U3RhdGU+O1xyXG4gIEBWaWV3Q2hpbGQoXCJzbGlkZXJIb3N0XCIsIHsgc3RhdGljOiBmYWxzZSB9KSBzbGlkZXJIb3N0PzogRWxlbWVudFJlZjxIVE1MRWxlbWVudD47XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBlbmdpbmU6IFNsaWRlckVuZ2luZSxcclxuICAgIHByaXZhdGUgc3RvcmU6IFNsaWRlclN0b3JlLFxyXG4gICAgcHJpdmF0ZSBkcmFnZ2FibGU6IFNsaWRlckRyYWdnYWJsZVBsdWdpbixcclxuICAgIHByaXZhdGUgcGFnaW5hdGlvbjogU2xpZGVyUGFnaW5hdGlvblBsdWdpbixcclxuICAgIHByaXZhdGUgbmF2aWdhdGlvbjogU2xpZGVyTmF2aWdhdGlvblBsdWdpbixcclxuICAgIHByaXZhdGUgYXV0b3BsYXk6IFNsaWRlckF1dG9wbGF5UGx1Z2luLFxyXG4gICAgcHJpdmF0ZSB0aHVtYnM6IFNsaWRlclRodW1ic1Njcm9sbFBsdWdpbixcclxuICApIHt9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5zdGF0ZSQgPSB0aGlzLnN0b3JlLnZpZXckO1xyXG5cclxuICAgIHRoaXMuc3RhdGUkLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKS5zdWJzY3JpYmUoKHN0YXRlKSA9PiB7XHJcbiAgICAgIGlmIChzdGF0ZS5jdXJyZW50U2xpZGUgIT09IHRoaXMubGFzdEluZGV4KSB7XHJcbiAgICAgICAgdGhpcy5sYXN0SW5kZXggPSBzdGF0ZS5jdXJyZW50U2xpZGU7XHJcbiAgICAgICAgdGhpcy5zbGlkZUNoYW5nZS5lbWl0KHN0YXRlLmN1cnJlbnRTbGlkZSk7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gICAgdGhpcy5sYXN0U2xpZGVzUmVmID0gdGhpcy5jb25maWc/LnNsaWRlcyA/PyBudWxsO1xyXG4gICAgdGhpcy5lbmdpbmUuaW5pdCh7IC4uLnRoaXMuY29uZmlnLCBwbHVnaW5zOiB0aGlzLmNvbmZpZy5wbHVnaW5zIH0pO1xyXG4gIH1cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICBpZiAodGhpcy5zbGlkZXJIb3N0Py5uYXRpdmVFbGVtZW50KSB7XHJcbiAgICAgIHRoaXMuZW5naW5lLmF0dGFjaENvbnRhaW5lcih0aGlzLnNsaWRlckhvc3QubmF0aXZlRWxlbWVudCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICBpZiAoIWNoYW5nZXNbXCJjb25maWdcIl0gfHwgIXRoaXMuY29uZmlnKSByZXR1cm47XHJcblxyXG4gICAgY29uc3QgbmV3U2xpZGVzUmVmID0gdGhpcy5jb25maWcuc2xpZGVzID8/IG51bGw7XHJcblxyXG4gICAgaWYgKG5ld1NsaWRlc1JlZiAhPT0gdGhpcy5sYXN0U2xpZGVzUmVmKSB7XHJcbiAgICAgIHRoaXMubGFzdFNsaWRlc1JlZiA9IG5ld1NsaWRlc1JlZjtcclxuICAgICAgdGhpcy5lbmdpbmUuZGVzdHJveSgpO1xyXG4gICAgICB0aGlzLnJlc29sdmVQbHVnaW5zKHRoaXMuY29uZmlnKTtcclxuICAgIH1cclxuICB9XHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLmRlc3Ryb3lTbGlkZXIoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnb1RvKGluZGV4OiBudW1iZXIpIHtcclxuICAgIHRoaXMuZW5naW5lLnNlbGVjdFNsaWRlKGluZGV4KTsgLy8gYWRkIHRoaXMgbGluZVxyXG4gICAgLy90aGlzLnNsaWRlQ2hhbmdlLmVtaXQoaW5kZXgpO1xyXG4gIH1cclxuXHJcbiAgZGVzdHJveVNsaWRlcigpIHtcclxuICAgIHRoaXMuZGVzdHJveSQubmV4dCgpO1xyXG4gICAgdGhpcy5kZXN0cm95JC5jb21wbGV0ZSgpO1xyXG4gICAgdGhpcy5lbmdpbmUuZGVzdHJveSgpO1xyXG4gIH0gLy8gZGVzdHJveXMgcGx1Z2lucyBhbmQgY2xlYXJzIHN0b3JlXHJcblxyXG4gIG9uTmV4dCgpIHtcclxuICAgIHRoaXMuZW5naW5lLm5leHQoKTtcclxuICB9XHJcbiAgb25QcmV2aW91cygpIHtcclxuICAgIHRoaXMuZW5naW5lLnByZXZpb3VzKCk7XHJcbiAgfVxyXG4gIHNlbGVjdFNsaWRlKGluZGV4OiBudW1iZXIpIHtcclxuICAgIHRoaXMuZW5naW5lLnNlbGVjdFNsaWRlKGluZGV4KTtcclxuICB9XHJcblxyXG4gIC8vIEhhbmRsZSBQb2ludGVyc1xyXG5cclxuICBvblBvaW50ZXJEb3duKGV2ZW50OiBQb2ludGVyRXZlbnQpIHtcclxuICAgIHRoaXMuZHJhZ1N0YXJ0WCA9IGV2ZW50LmNsaWVudFg7XHJcbiAgICB0aGlzLmRyYWdTdGFydFkgPSBldmVudC5jbGllbnRZO1xyXG4gICAgdGhpcy5pc0RyYWdnaW5nUG9pbnRlciA9IGZhbHNlO1xyXG5cclxuICAgIC8vIERvIG5vdCBjYXB0dXJlIHlldDsgd2FpdCB1bnRpbCBtb3ZlbWVudCBleGNlZWRzIHRocmVzaG9sZFxyXG4gICAgdGhpcy5lbmdpbmUuaGFuZGxlRHJhZ1N0YXJ0KGV2ZW50KTtcclxuICB9XHJcblxyXG4gIG9uUG9pbnRlck1vdmUoZXZlbnQ6IFBvaW50ZXJFdmVudCkge1xyXG4gICAgY29uc3QgZHggPSBNYXRoLmFicyhldmVudC5jbGllbnRYIC0gdGhpcy5kcmFnU3RhcnRYKTtcclxuICAgIGNvbnN0IGR5ID0gTWF0aC5hYnMoZXZlbnQuY2xpZW50WSAtIHRoaXMuZHJhZ1N0YXJ0WSk7XHJcblxyXG4gICAgaWYgKCF0aGlzLmlzRHJhZ2dpbmdQb2ludGVyICYmIChkeCA+IDUgfHwgZHkgPiA1KSkge1xyXG4gICAgICB0aGlzLmlzRHJhZ2dpbmdQb2ludGVyID0gdHJ1ZTtcclxuXHJcbiAgICAgIC8vIE5vdyBzdGFydCBjYXB0dXJpbmcgcG9pbnRlciBzbyBkcmFnZ2luZyB3b3JrcyBvdXRzaWRlIHRoZSBzbGlkZXIgYm91bmRzXHJcbiAgICAgIChldmVudC5jdXJyZW50VGFyZ2V0IGFzIEhUTUxFbGVtZW50KS5zZXRQb2ludGVyQ2FwdHVyZShldmVudC5wb2ludGVySWQpO1xyXG4gICAgfVxyXG5cclxuICAgIGlmICh0aGlzLmlzRHJhZ2dpbmdQb2ludGVyKSB7XHJcbiAgICAgIHRoaXMuZW5naW5lLmhhbmRsZURyYWdNb3ZlKGV2ZW50KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9uUG9pbnRlclVwKGV2ZW50OiBQb2ludGVyRXZlbnQpIHtcclxuICAgIGlmICghZXZlbnQpIHJldHVybjtcclxuXHJcbiAgICBpZiAoIXRoaXMuaXNEcmFnZ2luZ1BvaW50ZXIpIHtcclxuICAgICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50O1xyXG5cclxuICAgICAgLy8gT25seSBzZWxlY3QgdGhlIHNsaWRlIGlmIGNsaWNrIGlzIG5vdCBvbiBhbiBpbnRlcmFjdGl2ZSBjaGlsZFxyXG4gICAgICBjb25zdCBzbGlkZUVsID0gdGFyZ2V0LmNsb3Nlc3QoXCIuc2xpZGVcIik7XHJcbiAgICAgIGlmIChzbGlkZUVsICYmICF0YXJnZXQuY2xvc2VzdChcImJ1dHRvbiwgdmlkZW8sIGFcIikpIHtcclxuICAgICAgICBjb25zdCBpbmRleEF0dHIgPSBzbGlkZUVsLmdldEF0dHJpYnV0ZShcImRhdGEtaW5kZXhcIik7XHJcbiAgICAgICAgY29uc3QgaW5kZXggPSBpbmRleEF0dHIgPyBwYXJzZUludChpbmRleEF0dHIsIDEwKSA6IG51bGw7XHJcbiAgICAgICAgaWYgKGluZGV4ICE9PSBudWxsKSB0aGlzLmVuZ2luZS5zZWxlY3RTbGlkZShpbmRleCk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmVuZ2luZS5oYW5kbGVEcmFnRW5kKCk7XHJcbiAgICB0aGlzLmlzRHJhZ2dpbmdQb2ludGVyID0gZmFsc2U7XHJcblxyXG4gICAgLy8gUmVsZWFzZSBwb2ludGVyIGNhcHR1cmUgaWYgaXQgd2FzIGNhcHR1cmVkXHJcbiAgICB0cnkge1xyXG4gICAgICAoZXZlbnQuY3VycmVudFRhcmdldCBhcyBIVE1MRWxlbWVudCkucmVsZWFzZVBvaW50ZXJDYXB0dXJlKGV2ZW50LnBvaW50ZXJJZCk7XHJcbiAgICB9IGNhdGNoIHt9XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHJlc29sdmVQbHVnaW5zKGNvbmZpZzogU2xpZGVyQ29uZmlnKSB7XHJcbiAgICBjb25zdCBydW50aW1lUGx1Z2luczogU2xpZGVyUGx1Z2luW10gPSBbXTtcclxuXHJcbiAgICBjb25zdCBjZmcgPSBjb25maWcucGx1Z2lucztcclxuXHJcbiAgICBpZiAoY2ZnPy5kcmFnZ2FibGUpIHJ1bnRpbWVQbHVnaW5zLnB1c2godGhpcy5kcmFnZ2FibGUpO1xyXG4gICAgaWYgKGNmZz8ucGFnaW5hdGlvbikgcnVudGltZVBsdWdpbnMucHVzaCh0aGlzLnBhZ2luYXRpb24pO1xyXG4gICAgaWYgKGNmZz8ubmF2aWdhdGlvbikgcnVudGltZVBsdWdpbnMucHVzaCh0aGlzLm5hdmlnYXRpb24pO1xyXG5cclxuICAgIGlmIChjZmc/LmF1dG9wbGF5KSB7XHJcbiAgICAgIHRoaXMuYXV0b3BsYXkuc2V0Q29uZmlnKGNmZy5hdXRvcGxheSk7XHJcbiAgICAgIHJ1bnRpbWVQbHVnaW5zLnB1c2godGhpcy5hdXRvcGxheSk7XHJcbiAgICB9XHJcblxyXG4gICAgaWYgKGNmZz8udGh1bWJzKSBydW50aW1lUGx1Z2lucy5wdXNoKHRoaXMudGh1bWJzKTtcclxuXHJcbiAgICB0aGlzLmVuZ2luZS5pbml0KHsgLi4uY29uZmlnLCBwbHVnaW5zOiB1bmRlZmluZWQgfSwgcnVudGltZVBsdWdpbnMpO1xyXG4gIH1cclxufVxyXG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwic3RhdGUkIHwgYXN5bmMgYXMgc3RhdGVcIj5cclxuICA8ZGl2XHJcbiAgICBjbGFzcz1cInNsaWRlclwiXHJcbiAgICAjc2xpZGVySG9zdFxyXG4gICAgW2NsYXNzLnNsaWRlci12ZXJ0aWNhbF09XCJzdGF0ZS52ZXJ0aWNhbFwiXHJcbiAgICBbY2xhc3Muc2xpZGVyLWRyYWdnYWJsZV09XCJzdGF0ZS5pc0RyYWdnaW5nXCJcclxuICAgIFtjbGFzcy5zbGlkZXItLW1haW5dPVwiIWNvbmZpZy5pc1RodW1ic1wiXHJcbiAgICBbY2xhc3Muc2xpZGVyLS10aHVtYnNdPVwiY29uZmlnLmlzVGh1bWJzXCJcclxuICAgICpuZ0lmPVwic3RhdGUudmlzaWJsZVNsaWRlcz8ubGVuZ3RoID4gMCAmJiBzdGF0ZS5pc1Zpc2libGVcIlxyXG4gICAgKHBvaW50ZXJkb3duKT1cIm9uUG9pbnRlckRvd24oJGV2ZW50KVwiXHJcbiAgICAocG9pbnRlcm1vdmUpPVwib25Qb2ludGVyTW92ZSgkZXZlbnQpXCJcclxuICAgIChwb2ludGVydXApPVwib25Qb2ludGVyVXAoJGV2ZW50KVwiXHJcbiAgICAocG9pbnRlcmNhbmNlbCk9XCJvblBvaW50ZXJVcCgkZXZlbnQpXCI+XHJcbiAgICA8ZGl2XHJcbiAgICAgIGNsYXNzPVwic2xpZGVyX193cmFwcGVyXCJcclxuICAgICAgW25nU3R5bGVdPVwie1xyXG4gICAgICAgIHRyYW5zZm9ybTogc3RhdGUudHJhbnNsYXRlLFxyXG4gICAgICAgIHRyYW5zaXRpb246IHN0YXRlLnRyYW5zaXRpb24sXHJcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxyXG4gICAgICAgICdmbGV4LWRpcmVjdGlvbic6IHN0YXRlLnZlcnRpY2FsID8gJ2NvbHVtbicgOiAncm93JyxcclxuICAgICAgICAnanVzdGlmeS1jb250ZW50Jzogc3RhdGUudmlzaWJsZVNsaWRlcz8ubGVuZ3RoIDwgc3RhdGUuc2xpZGVzUGVyVmlldyA/ICdjZW50ZXInIDogJ2ZsZXgtc3RhcnQnLFxyXG4gICAgICAgIGdhcDogKHN0YXRlLnNsaWRlc1BlclZpZXcgPiAxID8gc3RhdGUuZ2FwIHx8IDAgOiAwKSArICdweCcsXHJcbiAgICAgIH1cIj5cclxuICAgICAgPGRpdlxyXG4gICAgICAgICpuZ0Zvcj1cImxldCBzbGlkZSBvZiBzdGF0ZS52aXNpYmxlU2xpZGVzOyBsZXQgaSA9IGluZGV4XCJcclxuICAgICAgICBjbGFzcz1cInNsaWRlXCJcclxuICAgICAgICBbYXR0ci5kYXRhLWluZGV4XT1cImlcIlxyXG4gICAgICAgIFtjbGFzcy5zbGlkZS0tY3VycmVudF09XCJzdGF0ZS5zZWxlY3RlZFNsaWRlID09PSBpXCJcclxuICAgICAgICBbc3R5bGUuZmxleF09XCJcclxuICAgICAgICAgICFjb25maWcuaXNUaHVtYnNcclxuICAgICAgICAgICAgPyAnMCAwIGNhbGMoJyArXHJcbiAgICAgICAgICAgICAgMTAwIC8gc3RhdGUuc2xpZGVzUGVyVmlldyArXHJcbiAgICAgICAgICAgICAgJyUgLSAnICtcclxuICAgICAgICAgICAgICAoKHN0YXRlLmdhcCB8fCAwKSAqIChzdGF0ZS5zbGlkZXNQZXJWaWV3IC0gMSkpIC8gc3RhdGUuc2xpZGVzUGVyVmlldyArXHJcbiAgICAgICAgICAgICAgJ3B4KSdcclxuICAgICAgICAgICAgOiAnMCAwICcgKyB0aHVtYlNpemUgKyAncHgnXHJcbiAgICAgICAgXCJcclxuICAgICAgICBbc3R5bGUud2lkdGhdPVwiY29uZmlnLmlzVGh1bWJzID8gdGh1bWJTaXplICsgJ3B4JyA6IG51bGxcIlxyXG4gICAgICAgIFtzdHlsZS5oZWlnaHRdPVwiY29uZmlnLmlzVGh1bWJzID8gdGh1bWJTaXplICsgJ3B4JyA6IG51bGxcIlxyXG4gICAgICAgIChjbGljayk9XCJlbmdpbmUuc2VsZWN0U2xpZGUoaSlcIj5cclxuICAgICAgICA8bmctY29udGFpbmVyXHJcbiAgICAgICAgICAqbmdUZW1wbGF0ZU91dGxldD1cInNsaWRlVGVtcGxhdGUgPyBzbGlkZVRlbXBsYXRlIDogZGVmYXVsdFNsaWRlVGVtcGxhdGU7IGNvbnRleHQ6IHsgc2xpZGU6IHNsaWRlLCBpbmRleDogaSB9XCI+PC9uZy1jb250YWluZXI+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvbmctY29udGFpbmVyPlxyXG4iXX0=
|