@elxjs/ui 0.0.180 → 0.0.181
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/components/carousel/carousel.component.mjs +72 -21
- package/esm2022/lib/components/carousel-fixed/carousel-fixed.component.mjs +75 -24
- package/fesm2022/elxjs-ui.mjs +145 -43
- package/fesm2022/elxjs-ui.mjs.map +1 -1
- package/lib/components/carousel/carousel.component.d.ts +5 -0
- package/lib/components/carousel-fixed/carousel-fixed.component.d.ts +5 -0
- package/package.json +1 -1
|
@@ -31,6 +31,10 @@ export class EluxCarouselComponent {
|
|
|
31
31
|
this.lastMoveTime = 0;
|
|
32
32
|
this.lastMoveX = 0;
|
|
33
33
|
this.wasDragging = false;
|
|
34
|
+
this.touchStartTime = 0;
|
|
35
|
+
this.touchStartX = 0;
|
|
36
|
+
this.touchStartY = 0;
|
|
37
|
+
this.isVerticalScroll = false;
|
|
34
38
|
}
|
|
35
39
|
ngAfterContentInit() {
|
|
36
40
|
this.calculateDimensions();
|
|
@@ -115,40 +119,87 @@ export class EluxCarouselComponent {
|
|
|
115
119
|
}
|
|
116
120
|
// Touch events
|
|
117
121
|
onTouchStart(event) {
|
|
118
|
-
|
|
122
|
+
this.touchStartTime = Date.now();
|
|
123
|
+
this.touchStartX = event.touches[0].clientX;
|
|
124
|
+
this.touchStartY = event.touches[0].clientY;
|
|
125
|
+
this.isVerticalScroll = false;
|
|
119
126
|
this.startDrag(event.touches[0].clientX);
|
|
120
127
|
}
|
|
121
128
|
onTouchMove(event) {
|
|
122
|
-
if (this.isDragging)
|
|
129
|
+
if (!this.isDragging)
|
|
130
|
+
return;
|
|
131
|
+
const currentX = event.touches[0].clientX;
|
|
132
|
+
const currentY = event.touches[0].clientY;
|
|
133
|
+
const deltaX = Math.abs(currentX - this.touchStartX);
|
|
134
|
+
const deltaY = Math.abs(currentY - this.touchStartY);
|
|
135
|
+
// Check if this is a vertical scroll
|
|
136
|
+
if (deltaY > deltaX && deltaY > 10) {
|
|
137
|
+
this.isVerticalScroll = true;
|
|
138
|
+
this.isDragging = false;
|
|
139
|
+
this.wasDragging = false;
|
|
140
|
+
this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.4s ease-out');
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
// Only prevent default if it's a horizontal drag
|
|
144
|
+
if (deltaX > 10) {
|
|
123
145
|
event.preventDefault();
|
|
124
146
|
this.updateDrag(event.touches[0].clientX);
|
|
125
147
|
}
|
|
126
148
|
}
|
|
127
149
|
onTouchEnd(event) {
|
|
150
|
+
if (this.isVerticalScroll) {
|
|
151
|
+
this.isVerticalScroll = false;
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
const touchDuration = Date.now() - this.touchStartTime;
|
|
155
|
+
const touchDistance = Math.abs(this.currentX - this.startX);
|
|
156
|
+
// Consider it a tap if duration < 300ms and distance < 10px
|
|
157
|
+
if (touchDuration < 300 && touchDistance < 10) {
|
|
158
|
+
this.wasDragging = false;
|
|
159
|
+
this.isDragging = false;
|
|
160
|
+
}
|
|
128
161
|
if (this.isDragging) {
|
|
129
162
|
this.endDrag();
|
|
130
163
|
}
|
|
131
164
|
}
|
|
132
165
|
setupItemClickListeners() {
|
|
133
166
|
this.items.forEach((item, index) => {
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
167
|
+
// Remove any existing listeners
|
|
168
|
+
const newItem = item.nativeElement.cloneNode(true);
|
|
169
|
+
item.nativeElement.parentNode?.replaceChild(newItem, item.nativeElement);
|
|
170
|
+
// Add both click and touchend listeners for better mobile support
|
|
171
|
+
this.renderer.listen(newItem, 'click', (event) => {
|
|
172
|
+
this.handleItemClick(event, index, newItem);
|
|
173
|
+
});
|
|
174
|
+
this.renderer.listen(newItem, 'touchend', (event) => {
|
|
175
|
+
// Only handle touchend if it wasn't a drag
|
|
176
|
+
if (!this.wasDragging && !this.isVerticalScroll) {
|
|
177
|
+
const touchDuration = Date.now() - this.touchStartTime;
|
|
178
|
+
const touchDistance = Math.abs(event.changedTouches[0].clientX - this.touchStartX);
|
|
179
|
+
if (touchDuration < 300 && touchDistance < 10) {
|
|
180
|
+
event.preventDefault();
|
|
181
|
+
this.handleItemClick(event, index, newItem);
|
|
182
|
+
}
|
|
140
183
|
}
|
|
141
|
-
this.itemClickEventEmitter.emit({
|
|
142
|
-
event,
|
|
143
|
-
index,
|
|
144
|
-
element: item.nativeElement
|
|
145
|
-
});
|
|
146
184
|
});
|
|
147
185
|
});
|
|
148
186
|
}
|
|
187
|
+
handleItemClick(event, index, element) {
|
|
188
|
+
// Prevent click if it was preceded by a drag
|
|
189
|
+
if (this.wasDragging) {
|
|
190
|
+
event.preventDefault();
|
|
191
|
+
event.stopPropagation();
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
194
|
+
this.itemClickEventEmitter.emit({
|
|
195
|
+
event,
|
|
196
|
+
index,
|
|
197
|
+
element
|
|
198
|
+
});
|
|
199
|
+
}
|
|
149
200
|
startDrag(clientX) {
|
|
150
201
|
this.isDragging = true;
|
|
151
|
-
this.wasDragging = false;
|
|
202
|
+
this.wasDragging = false;
|
|
152
203
|
this.startX = clientX;
|
|
153
204
|
this.currentX = clientX;
|
|
154
205
|
this.initialOffset = this.offset;
|
|
@@ -164,9 +215,9 @@ export class EluxCarouselComponent {
|
|
|
164
215
|
updateDrag(clientX) {
|
|
165
216
|
if (!this.isDragging)
|
|
166
217
|
return;
|
|
167
|
-
//
|
|
218
|
+
// More lenient threshold for mobile - mark as dragging only for significant movement
|
|
168
219
|
const deltaX = Math.abs(this.currentX - this.startX);
|
|
169
|
-
if (deltaX >
|
|
220
|
+
if (deltaX > 15) { // Increased from 5px to 15px for mobile
|
|
170
221
|
this.wasDragging = true;
|
|
171
222
|
}
|
|
172
223
|
this.currentX = clientX;
|
|
@@ -203,17 +254,17 @@ export class EluxCarouselComponent {
|
|
|
203
254
|
if (!this.isDragging)
|
|
204
255
|
return;
|
|
205
256
|
this.isDragging = false;
|
|
206
|
-
// Clear the wasDragging flag after a
|
|
257
|
+
// Clear the wasDragging flag after a shorter delay for mobile
|
|
207
258
|
setTimeout(() => {
|
|
208
259
|
this.wasDragging = false;
|
|
209
|
-
},
|
|
260
|
+
}, 50); // Reduced from 100ms to 50ms
|
|
210
261
|
// Re-enable CSS transitions
|
|
211
262
|
this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.4s ease-out');
|
|
212
263
|
const finalOffset = this.initialOffset + this.dragOffset;
|
|
213
|
-
const threshold =
|
|
264
|
+
const threshold = 40; // Reduced from 50px to 40px for mobile
|
|
214
265
|
const dragDistance = Math.abs(this.currentX - this.startX);
|
|
215
266
|
// Check for momentum (velocity-based slide change)
|
|
216
|
-
const momentumThreshold = 0.5
|
|
267
|
+
const momentumThreshold = 0.3; // Reduced from 0.5 to 0.3
|
|
217
268
|
const hasSignificantVelocity = Math.abs(this.velocity) > momentumThreshold;
|
|
218
269
|
if (dragDistance > threshold || hasSignificantVelocity) {
|
|
219
270
|
if (this.dragOffset > 0 || (hasSignificantVelocity && this.velocity > 0)) {
|
|
@@ -345,4 +396,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
345
396
|
}], itemClickEventEmitter: [{
|
|
346
397
|
type: Output
|
|
347
398
|
}] } });
|
|
348
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../ui/library/src/lib/components/carousel/carousel.component.ts","../../../../../../../ui/library/src/lib/components/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, Output, QueryList, Renderer2, ViewChild } from '@angular/core';\nimport { EluxIcon } from '../icon';\n\nexport type ProductItem = {\n  name: string;\n  image: string;\n};\n\n@Component({\n  standalone: true,\n  selector: 'lib-elux-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  imports: [CommonModule, EluxIcon],\n})\nexport class EluxCarouselComponent implements AfterContentInit, OnDestroy {\n  @ContentChildren('carouselItem', { read: ElementRef }) items!: QueryList<ElementRef>;\n  @ViewChild('dotsContainer') dotsContainer!: ElementRef;\n  @ViewChild('slidesContainer') slidesContainer!: ElementRef;\n\n  @Input() itemsPerSlide: number = 4;\n  @Input() removeArrows: boolean = false;\n  @Input() removeDots: boolean = false;\n  @Input() autoPlayInterval: number | null = null;\n\n  @Output() previousClickEventEmitter = new EventEmitter<Event>();\n  @Output() nextClickEventEmitter = new EventEmitter<Event>();\n  @Output() dotClickEventEmitter = new EventEmitter<Event>();\n  @Output() itemClickEventEmitter = new EventEmitter<{event: Event, index: number, element: HTMLElement}>();\n\n  currentIndex = 0;\n  currentStepIndex = 0;\n  offset = 0;\n\n  private isDragging = false;\n  private startX = 0;\n  private currentX = 0;\n  private initialOffset = 0;\n  private dragOffset = 0;\n  private containerWidth = 0;\n  private itemWidth = 0;\n  private maxOffset = 0;\n  private minOffset = 0;\n  private autoPlayTimer: any;\n  private animationId: number | null = null;\n  private velocity = 0;\n  private lastMoveTime = 0;\n  private lastMoveX = 0;\n  private wasDragging = false;\n\n  constructor(private renderer: Renderer2) {}\n\n  ngAfterContentInit() {\n    this.calculateDimensions();\n    this.setItemWidths();\n    this.updateLimits();\n    this.setupItemClickListeners();\n\n    if (this.autoPlayInterval) {\n      this.startAutoPlay();\n    }\n\n    this.items.changes.subscribe(() => {\n      this.calculateDimensions();\n      this.setItemWidths();\n      this.updateLimits();\n      this.goToFirstSlide();\n      this.setupItemClickListeners();\n    });\n\n    // Listen for window resize to recalculate dimensions\n    window.addEventListener('resize', () => this.onResize());\n  }\n\n  ngOnDestroy() {\n    this.stopAutoPlay();\n    if (this.animationId) {\n      cancelAnimationFrame(this.animationId);\n    }\n    window.removeEventListener('resize', () => this.onResize());\n  }\n\n  private calculateDimensions() {\n    if (this.slidesContainer) {\n      this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;\n      this.itemWidth = this.containerWidth / this.itemsPerSlide;\n    }\n  }\n\n  private updateLimits() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    this.maxOffset = 0;\n    this.minOffset = -((totalSteps - 1) * 100);\n  }\n\n  private onResize() {\n    this.calculateDimensions();\n    this.updateOffset();\n  }\n\n  private setItemWidths() {\n    this.items.forEach((item) => {\n      const minWidth = `calc(100% / ${this.itemsPerSlide})`;\n      this.renderer.setStyle(item.nativeElement, 'minWidth', minWidth);\n    });\n  }\n\n  startAutoPlay() {\n    this.stopAutoPlay();\n    this.autoPlayTimer = setInterval(() => {\n      if (!this.isDragging) {\n        this.nextSlide();\n      }\n    }, (this.autoPlayInterval || 0) * 1000);\n  }\n\n  stopAutoPlay() {\n    if (this.autoPlayTimer) {\n      clearInterval(this.autoPlayTimer);\n      this.autoPlayTimer = null;\n    }\n  }\n\n  // Mouse events\n  onMouseDown(event: MouseEvent) {\n    event.preventDefault();\n    this.startDrag(event.clientX);\n  }\n\n  onMouseMove(event: MouseEvent) {\n    if (this.isDragging) {\n      event.preventDefault();\n      this.updateDrag(event.clientX);\n    }\n  }\n\n  onMouseUp(event: MouseEvent) {\n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  onMouseLeave(event: MouseEvent) {\n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  // Touch events\n  onTouchStart(event: TouchEvent) {\n    event.preventDefault();\n    this.startDrag(event.touches[0].clientX);\n  }\n\n  onTouchMove(event: TouchEvent) {\n    if (this.isDragging) {\n      event.preventDefault();\n      this.updateDrag(event.touches[0].clientX);\n    }\n  }\n\n  onTouchEnd(event: TouchEvent) {\n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  private setupItemClickListeners() {\n    this.items.forEach((item, index) => {\n      this.renderer.listen(item.nativeElement, 'click', (event: Event) => {\n        // Prevent click if it was preceded by a drag\n        if (this.wasDragging) {\n          event.preventDefault();\n          event.stopPropagation();\n          return;\n        }\n        \n        this.itemClickEventEmitter.emit({\n          event,\n          index,\n          element: item.nativeElement\n        });\n      });\n    });\n  }\n\n  private startDrag(clientX: number) {\n    this.isDragging = true;\n    this.wasDragging = false; // Reset at start of potential drag\n    this.startX = clientX;\n    this.currentX = clientX;\n    this.initialOffset = this.offset;\n    this.dragOffset = 0;\n    this.velocity = 0;\n    this.lastMoveTime = Date.now();\n    this.lastMoveX = clientX;\n    \n    this.calculateDimensions();\n    this.stopAutoPlay();\n    \n    // Disable CSS transitions during drag\n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');\n  }\n\n  private updateDrag(clientX: number) {\n    if (!this.isDragging) return;\n\n    // Mark as dragging if movement is significant\n    const deltaX = Math.abs(this.currentX - this.startX);\n    if (deltaX > 5) { // 5px threshold to distinguish from accidental movement\n      this.wasDragging = true;\n    }\n\n    this.currentX = clientX;\n    const totalDeltaX = this.currentX - this.startX;\n    \n    // Calculate velocity for momentum\n    const now = Date.now();\n    const timeDelta = now - this.lastMoveTime;\n    if (timeDelta > 0) {\n      this.velocity = (clientX - this.lastMoveX) / timeDelta;\n    }\n    this.lastMoveTime = now;\n    this.lastMoveX = clientX;\n\n    // Convert pixel movement to percentage\n    const dragPercentage = (totalDeltaX / this.containerWidth) * 100;\n    \n    // Apply resistance at boundaries\n    let resistedDragPercentage = dragPercentage;\n    const potentialOffset = this.initialOffset + dragPercentage;\n    \n    if (potentialOffset > this.maxOffset) {\n      const overDrag = potentialOffset - this.maxOffset;\n      resistedDragPercentage = dragPercentage - (overDrag * 0.3);\n    } else if (potentialOffset < this.minOffset) {\n      const overDrag = this.minOffset - potentialOffset;\n      resistedDragPercentage = dragPercentage + (overDrag * 0.3);\n    }\n\n    this.dragOffset = resistedDragPercentage;\n    this.updateDragPosition();\n  }\n\n  private updateDragPosition() {\n    const newOffset = this.initialOffset + this.dragOffset;\n    this.renderer.setStyle(\n      this.slidesContainer.nativeElement, \n      'transform', \n      `translateX(${newOffset}%)`\n    );\n  }\n\n  private endDrag() {\n    if (!this.isDragging) return;\n\n    this.isDragging = false;\n    \n    // Clear the wasDragging flag after a short delay to allow click event to be processed\n    setTimeout(() => {\n      this.wasDragging = false;\n    }, 100);\n    \n    // Re-enable CSS transitions\n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.4s ease-out');\n\n    const finalOffset = this.initialOffset + this.dragOffset;\n    const threshold = 50; // Minimum drag distance in pixels to trigger slide change\n    const dragDistance = Math.abs(this.currentX - this.startX);\n    \n    // Check for momentum (velocity-based slide change)\n    const momentumThreshold = 0.5;\n    const hasSignificantVelocity = Math.abs(this.velocity) > momentumThreshold;\n    \n    if (dragDistance > threshold || hasSignificantVelocity) {\n      if (this.dragOffset > 0 || (hasSignificantVelocity && this.velocity > 0)) {\n        // Dragged right or has positive velocity - go to previous slide\n        this.prevSlide();\n      } else if (this.dragOffset < 0 || (hasSignificantVelocity && this.velocity < 0)) {\n        // Dragged left or has negative velocity - go to next slide\n        this.nextSlide();\n      } else {\n        // Small drag, snap back to current position\n        this.updateOffset();\n      }\n    } else {\n      // Small drag, snap back to current position\n      this.updateOffset();\n    }\n\n    // Reset drag state\n    this.dragOffset = 0;\n    this.velocity = 0;\n    \n    // Restart autoplay if it was enabled\n    if (this.autoPlayInterval) {\n      setTimeout(() => this.startAutoPlay(), 1000);\n    }\n  }\n\n  getStepIndexCount(): number[] {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    return Array.from({ length: totalSteps }, (_, i) => i);\n  }\n\n  getCurrentStepIndex(): number {\n    return this.currentStepIndex; \n  }\n\n  goToFirstSlide() {\n    this.currentIndex = 0;\n    this.currentStepIndex = 0;\n    this.updateOffset();\n    this.scrollActiveDotIntoView(0);\n  }\n\n  goToSlide(index: number) {\n    this.currentStepIndex = index;\n    this.currentIndex = Math.min(index * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    this.updateOffset();\n    this.scrollActiveDotIntoView(index);\n    this.dotClickEventEmitter.emit();\n  }\n\n  prevSlide() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    \n    if (this.currentStepIndex > 0) {\n      this.currentStepIndex--;\n      this.currentIndex = this.currentStepIndex * this.itemsPerSlide;\n    } else {\n      this.currentStepIndex = totalSteps - 1;\n      this.currentIndex = Math.min(this.currentStepIndex * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    }\n    \n    this.updateOffset();\n    this.scrollActiveDotIntoView(this.currentStepIndex);\n    this.previousClickEventEmitter.emit();\n  }\n\n  nextSlide() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    if (this.currentStepIndex >= totalSteps - 1) {\n      this.currentStepIndex = 0;\n      this.currentIndex = 0;\n    } else {\n      this.currentStepIndex++;\n      this.currentIndex = Math.min(this.currentStepIndex * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    }\n    this.updateOffset();\n    this.scrollActiveDotIntoView(this.currentStepIndex);\n    this.nextClickEventEmitter.emit();\n  }\n\n  updateOffset() {\n    this.offset = -100 * (this.currentIndex / this.itemsPerSlide);\n    \n    if (!this.isDragging && this.slidesContainer) {\n      this.renderer.setStyle(\n        this.slidesContainer.nativeElement, \n        'transform', \n        `translateX(${this.offset}%)`\n      );\n    }\n  }\n\n  private scrollActiveDotIntoView(index: number) {\n    setTimeout(() => {\n      const dotsContainer = this.dotsContainer?.nativeElement;\n      if (!dotsContainer) return;\n\n      const dots = dotsContainer.getElementsByClassName('dot');\n      if (!dots || !dots[index]) return;\n\n      const activeDot = dots[index];\n      const containerWidth = dotsContainer.offsetWidth;\n      const dotWidth = activeDot.offsetWidth + 10;\n      const scrollPosition = dotWidth * index - containerWidth / 2 + dotWidth / 2;\n\n      dotsContainer.scrollTo({\n        left: Math.max(0, scrollPosition),\n        behavior: 'smooth',\n      });\n    });\n  }\n}\n","<div class=\"c-carousel-container\">\n  <div \n    class=\"c-carousel-slides\" \n    #slidesContainer\n    [style.transform]=\"'translateX(' + offset + '%)'\" \n    (mousedown)=\"onMouseDown($event)\"\n    (mousemove)=\"onMouseMove($event)\"\n    (mouseup)=\"onMouseUp($event)\"\n    (mouseleave)=\"onMouseLeave($event)\"\n    (touchstart)=\"onTouchStart($event)\" \n    (touchmove)=\"onTouchMove($event)\" \n    (touchend)=\"onTouchEnd($event)\">\n    <ng-content></ng-content>\n  </div>\n\n  <div class=\"c-carousel-footer\">\n    <button [hidden]=\"removeArrows\" class=\"c-carousel-nav prev\" title=\"Slide anterior\" aria-label=\"Slide anterior\" (click)=\"prevSlide()\">\n      <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n\n    <div [hidden]=\"removeDots\" class=\"c-carousel-dots\" #dotsContainer>\n      <span\n        role=\"button\"\n        class=\"dot\"\n        *ngFor=\"let index of getStepIndexCount()\"\n        (click)=\"goToSlide(index)\"\n        (keyup)=\"goToSlide(index)\"\n        [class.active]=\"index === getCurrentStepIndex()\"\n        [attr.aria-disabled]=\"true\"\n        [attr.aria-label]=\"'pagina' + (index + 1)\"\n      >\n      </span>\n    </div>\n\n    <button [hidden]=\"removeArrows\" class=\"c-carousel-nav next\" title=\"Próximo slide\" aria-label=\"Próximo slide\" (click)=\"nextSlide()\">\n      <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n  </div>\n</div>\n"]}
|
|
399
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../ui/library/src/lib/components/carousel/carousel.component.ts","../../../../../../../ui/library/src/lib/components/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, Output, QueryList, Renderer2, ViewChild } from '@angular/core';\nimport { EluxIcon } from '../icon';\n\nexport type ProductItem = {\n  name: string;\n  image: string;\n};\n\n@Component({\n  standalone: true,\n  selector: 'lib-elux-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  imports: [CommonModule, EluxIcon],\n})\nexport class EluxCarouselComponent implements AfterContentInit, OnDestroy {\n  @ContentChildren('carouselItem', { read: ElementRef }) items!: QueryList<ElementRef>;\n  @ViewChild('dotsContainer') dotsContainer!: ElementRef;\n  @ViewChild('slidesContainer') slidesContainer!: ElementRef;\n\n  @Input() itemsPerSlide: number = 4;\n  @Input() removeArrows: boolean = false;\n  @Input() removeDots: boolean = false;\n  @Input() autoPlayInterval: number | null = null;\n\n  @Output() previousClickEventEmitter = new EventEmitter<Event>();\n  @Output() nextClickEventEmitter = new EventEmitter<Event>();\n  @Output() dotClickEventEmitter = new EventEmitter<Event>();\n  @Output() itemClickEventEmitter = new EventEmitter<{event: Event, index: number, element: HTMLElement}>();\n\n  currentIndex = 0;\n  currentStepIndex = 0;\n  offset = 0;\n\n  private isDragging = false;\n  private startX = 0;\n  private currentX = 0;\n  private initialOffset = 0;\n  private dragOffset = 0;\n  private containerWidth = 0;\n  private itemWidth = 0;\n  private maxOffset = 0;\n  private minOffset = 0;\n  private autoPlayTimer: any;\n  private animationId: number | null = null;\n  private velocity = 0;\n  private lastMoveTime = 0;\n  private lastMoveX = 0;\n  private wasDragging = false;\n  private touchStartTime = 0;\n  private touchStartX = 0;\n  private touchStartY = 0;\n  private isVerticalScroll = false;\n\n  constructor(private renderer: Renderer2) {}\n\n  ngAfterContentInit() {\n    this.calculateDimensions();\n    this.setItemWidths();\n    this.updateLimits();\n    this.setupItemClickListeners();\n\n    if (this.autoPlayInterval) {\n      this.startAutoPlay();\n    }\n\n    this.items.changes.subscribe(() => {\n      this.calculateDimensions();\n      this.setItemWidths();\n      this.updateLimits();\n      this.goToFirstSlide();\n      this.setupItemClickListeners();\n    });\n\n    // Listen for window resize to recalculate dimensions\n    window.addEventListener('resize', () => this.onResize());\n  }\n\n  ngOnDestroy() {\n    this.stopAutoPlay();\n    if (this.animationId) {\n      cancelAnimationFrame(this.animationId);\n    }\n    window.removeEventListener('resize', () => this.onResize());\n  }\n\n  private calculateDimensions() {\n    if (this.slidesContainer) {\n      this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;\n      this.itemWidth = this.containerWidth / this.itemsPerSlide;\n    }\n  }\n\n  private updateLimits() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    this.maxOffset = 0;\n    this.minOffset = -((totalSteps - 1) * 100);\n  }\n\n  private onResize() {\n    this.calculateDimensions();\n    this.updateOffset();\n  }\n\n  private setItemWidths() {\n    this.items.forEach((item) => {\n      const minWidth = `calc(100% / ${this.itemsPerSlide})`;\n      this.renderer.setStyle(item.nativeElement, 'minWidth', minWidth);\n    });\n  }\n\n  startAutoPlay() {\n    this.stopAutoPlay();\n    this.autoPlayTimer = setInterval(() => {\n      if (!this.isDragging) {\n        this.nextSlide();\n      }\n    }, (this.autoPlayInterval || 0) * 1000);\n  }\n\n  stopAutoPlay() {\n    if (this.autoPlayTimer) {\n      clearInterval(this.autoPlayTimer);\n      this.autoPlayTimer = null;\n    }\n  }\n\n  // Mouse events\n  onMouseDown(event: MouseEvent) {\n    event.preventDefault();\n    this.startDrag(event.clientX);\n  }\n\n  onMouseMove(event: MouseEvent) {\n    if (this.isDragging) {\n      event.preventDefault();\n      this.updateDrag(event.clientX);\n    }\n  }\n\n  onMouseUp(event: MouseEvent) {\n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  onMouseLeave(event: MouseEvent) {\n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  // Touch events\n  onTouchStart(event: TouchEvent) {\n    this.touchStartTime = Date.now();\n    this.touchStartX = event.touches[0].clientX;\n    this.touchStartY = event.touches[0].clientY;\n    this.isVerticalScroll = false;\n    this.startDrag(event.touches[0].clientX);\n  }\n\n  onTouchMove(event: TouchEvent) {\n    if (!this.isDragging) return;\n    \n    const currentX = event.touches[0].clientX;\n    const currentY = event.touches[0].clientY;\n    const deltaX = Math.abs(currentX - this.touchStartX);\n    const deltaY = Math.abs(currentY - this.touchStartY);\n    \n    // Check if this is a vertical scroll\n    if (deltaY > deltaX && deltaY > 10) {\n      this.isVerticalScroll = true;\n      this.isDragging = false;\n      this.wasDragging = false;\n      this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.4s ease-out');\n      return;\n    }\n    \n    // Only prevent default if it's a horizontal drag\n    if (deltaX > 10) {\n      event.preventDefault();\n      this.updateDrag(event.touches[0].clientX);\n    }\n  }\n\n  onTouchEnd(event: TouchEvent) {\n    if (this.isVerticalScroll) {\n      this.isVerticalScroll = false;\n      return;\n    }\n    \n    const touchDuration = Date.now() - this.touchStartTime;\n    const touchDistance = Math.abs(this.currentX - this.startX);\n    \n    // Consider it a tap if duration < 300ms and distance < 10px\n    if (touchDuration < 300 && touchDistance < 10) {\n      this.wasDragging = false;\n      this.isDragging = false;\n    }\n    \n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  private setupItemClickListeners() {\n    this.items.forEach((item, index) => {\n      // Remove any existing listeners\n      const newItem = item.nativeElement.cloneNode(true);\n      item.nativeElement.parentNode?.replaceChild(newItem, item.nativeElement);\n      \n      // Add both click and touchend listeners for better mobile support\n      this.renderer.listen(newItem, 'click', (event: Event) => {\n        this.handleItemClick(event, index, newItem);\n      });\n      \n      this.renderer.listen(newItem, 'touchend', (event: TouchEvent) => {\n        // Only handle touchend if it wasn't a drag\n        if (!this.wasDragging && !this.isVerticalScroll) {\n          const touchDuration = Date.now() - this.touchStartTime;\n          const touchDistance = Math.abs(event.changedTouches[0].clientX - this.touchStartX);\n          \n          if (touchDuration < 300 && touchDistance < 10) {\n            event.preventDefault();\n            this.handleItemClick(event, index, newItem);\n          }\n        }\n      });\n    });\n  }\n\n  private handleItemClick(event: Event, index: number, element: HTMLElement) {\n    // Prevent click if it was preceded by a drag\n    if (this.wasDragging) {\n      event.preventDefault();\n      event.stopPropagation();\n      return;\n    }\n    \n    this.itemClickEventEmitter.emit({\n      event,\n      index,\n      element\n    });\n  }\n\n  private startDrag(clientX: number) {\n    this.isDragging = true;\n    this.wasDragging = false;\n    this.startX = clientX;\n    this.currentX = clientX;\n    this.initialOffset = this.offset;\n    this.dragOffset = 0;\n    this.velocity = 0;\n    this.lastMoveTime = Date.now();\n    this.lastMoveX = clientX;\n    \n    this.calculateDimensions();\n    this.stopAutoPlay();\n    \n    // Disable CSS transitions during drag\n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');\n  }\n\n  private updateDrag(clientX: number) {\n    if (!this.isDragging) return;\n\n    // More lenient threshold for mobile - mark as dragging only for significant movement\n    const deltaX = Math.abs(this.currentX - this.startX);\n    if (deltaX > 15) { // Increased from 5px to 15px for mobile\n      this.wasDragging = true;\n    }\n\n    this.currentX = clientX;\n    const totalDeltaX = this.currentX - this.startX;\n    \n    // Calculate velocity for momentum\n    const now = Date.now();\n    const timeDelta = now - this.lastMoveTime;\n    if (timeDelta > 0) {\n      this.velocity = (clientX - this.lastMoveX) / timeDelta;\n    }\n    this.lastMoveTime = now;\n    this.lastMoveX = clientX;\n\n    // Convert pixel movement to percentage\n    const dragPercentage = (totalDeltaX / this.containerWidth) * 100;\n    \n    // Apply resistance at boundaries\n    let resistedDragPercentage = dragPercentage;\n    const potentialOffset = this.initialOffset + dragPercentage;\n    \n    if (potentialOffset > this.maxOffset) {\n      const overDrag = potentialOffset - this.maxOffset;\n      resistedDragPercentage = dragPercentage - (overDrag * 0.3);\n    } else if (potentialOffset < this.minOffset) {\n      const overDrag = this.minOffset - potentialOffset;\n      resistedDragPercentage = dragPercentage + (overDrag * 0.3);\n    }\n\n    this.dragOffset = resistedDragPercentage;\n    this.updateDragPosition();\n  }\n\n  private updateDragPosition() {\n    const newOffset = this.initialOffset + this.dragOffset;\n    this.renderer.setStyle(\n      this.slidesContainer.nativeElement, \n      'transform', \n      `translateX(${newOffset}%)`\n    );\n  }\n\n  private endDrag() {\n    if (!this.isDragging) return;\n\n    this.isDragging = false;\n    \n    // Clear the wasDragging flag after a shorter delay for mobile\n    setTimeout(() => {\n      this.wasDragging = false;\n    }, 50); // Reduced from 100ms to 50ms\n    \n    // Re-enable CSS transitions\n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.4s ease-out');\n\n    const finalOffset = this.initialOffset + this.dragOffset;\n    const threshold = 40; // Reduced from 50px to 40px for mobile\n    const dragDistance = Math.abs(this.currentX - this.startX);\n    \n    // Check for momentum (velocity-based slide change)\n    const momentumThreshold = 0.3; // Reduced from 0.5 to 0.3\n    const hasSignificantVelocity = Math.abs(this.velocity) > momentumThreshold;\n    \n    if (dragDistance > threshold || hasSignificantVelocity) {\n      if (this.dragOffset > 0 || (hasSignificantVelocity && this.velocity > 0)) {\n        // Dragged right or has positive velocity - go to previous slide\n        this.prevSlide();\n      } else if (this.dragOffset < 0 || (hasSignificantVelocity && this.velocity < 0)) {\n        // Dragged left or has negative velocity - go to next slide\n        this.nextSlide();\n      } else {\n        // Small drag, snap back to current position\n        this.updateOffset();\n      }\n    } else {\n      // Small drag, snap back to current position\n      this.updateOffset();\n    }\n\n    // Reset drag state\n    this.dragOffset = 0;\n    this.velocity = 0;\n    \n    // Restart autoplay if it was enabled\n    if (this.autoPlayInterval) {\n      setTimeout(() => this.startAutoPlay(), 1000);\n    }\n  }\n\n  getStepIndexCount(): number[] {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    return Array.from({ length: totalSteps }, (_, i) => i);\n  }\n\n  getCurrentStepIndex(): number {\n    return this.currentStepIndex; \n  }\n\n  goToFirstSlide() {\n    this.currentIndex = 0;\n    this.currentStepIndex = 0;\n    this.updateOffset();\n    this.scrollActiveDotIntoView(0);\n  }\n\n  goToSlide(index: number) {\n    this.currentStepIndex = index;\n    this.currentIndex = Math.min(index * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    this.updateOffset();\n    this.scrollActiveDotIntoView(index);\n    this.dotClickEventEmitter.emit();\n  }\n\n  prevSlide() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    \n    if (this.currentStepIndex > 0) {\n      this.currentStepIndex--;\n      this.currentIndex = this.currentStepIndex * this.itemsPerSlide;\n    } else {\n      this.currentStepIndex = totalSteps - 1;\n      this.currentIndex = Math.min(this.currentStepIndex * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    }\n    \n    this.updateOffset();\n    this.scrollActiveDotIntoView(this.currentStepIndex);\n    this.previousClickEventEmitter.emit();\n  }\n\n  nextSlide() {\n    const totalSteps = Math.ceil(this.items.length / this.itemsPerSlide);\n    if (this.currentStepIndex >= totalSteps - 1) {\n      this.currentStepIndex = 0;\n      this.currentIndex = 0;\n    } else {\n      this.currentStepIndex++;\n      this.currentIndex = Math.min(this.currentStepIndex * this.itemsPerSlide, this.items.length - this.itemsPerSlide);\n    }\n    this.updateOffset();\n    this.scrollActiveDotIntoView(this.currentStepIndex);\n    this.nextClickEventEmitter.emit();\n  }\n\n  updateOffset() {\n    this.offset = -100 * (this.currentIndex / this.itemsPerSlide);\n    \n    if (!this.isDragging && this.slidesContainer) {\n      this.renderer.setStyle(\n        this.slidesContainer.nativeElement, \n        'transform', \n        `translateX(${this.offset}%)`\n      );\n    }\n  }\n\n  private scrollActiveDotIntoView(index: number) {\n    setTimeout(() => {\n      const dotsContainer = this.dotsContainer?.nativeElement;\n      if (!dotsContainer) return;\n\n      const dots = dotsContainer.getElementsByClassName('dot');\n      if (!dots || !dots[index]) return;\n\n      const activeDot = dots[index];\n      const containerWidth = dotsContainer.offsetWidth;\n      const dotWidth = activeDot.offsetWidth + 10;\n      const scrollPosition = dotWidth * index - containerWidth / 2 + dotWidth / 2;\n\n      dotsContainer.scrollTo({\n        left: Math.max(0, scrollPosition),\n        behavior: 'smooth',\n      });\n    });\n  }\n}\n","<div class=\"c-carousel-container\">\n  <div \n    class=\"c-carousel-slides\" \n    #slidesContainer\n    [style.transform]=\"'translateX(' + offset + '%)'\" \n    (mousedown)=\"onMouseDown($event)\"\n    (mousemove)=\"onMouseMove($event)\"\n    (mouseup)=\"onMouseUp($event)\"\n    (mouseleave)=\"onMouseLeave($event)\"\n    (touchstart)=\"onTouchStart($event)\" \n    (touchmove)=\"onTouchMove($event)\" \n    (touchend)=\"onTouchEnd($event)\">\n    <ng-content></ng-content>\n  </div>\n\n  <div class=\"c-carousel-footer\">\n    <button [hidden]=\"removeArrows\" class=\"c-carousel-nav prev\" title=\"Slide anterior\" aria-label=\"Slide anterior\" (click)=\"prevSlide()\">\n      <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n\n    <div [hidden]=\"removeDots\" class=\"c-carousel-dots\" #dotsContainer>\n      <span\n        role=\"button\"\n        class=\"dot\"\n        *ngFor=\"let index of getStepIndexCount()\"\n        (click)=\"goToSlide(index)\"\n        (keyup)=\"goToSlide(index)\"\n        [class.active]=\"index === getCurrentStepIndex()\"\n        [attr.aria-disabled]=\"true\"\n        [attr.aria-label]=\"'pagina' + (index + 1)\"\n      >\n      </span>\n    </div>\n\n    <button [hidden]=\"removeArrows\" class=\"c-carousel-nav next\" title=\"Próximo slide\" aria-label=\"Próximo slide\" (click)=\"nextSlide()\">\n      <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n  </div>\n</div>\n"]}
|