ngx-edge-slider 1.0.1 → 2.0.0
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", 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" }]
|
|
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,{"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  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"]}
|