@elxjs/ui 0.0.182 → 0.0.184

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.
@@ -2,17 +2,20 @@ import { CommonModule } from '@angular/common';
2
2
  import { Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
3
  import { EluxIcon } from '../icon';
4
4
  import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
5
6
  export class EluxCarouselFixedComponent {
6
7
  constructor(renderer) {
7
8
  this.renderer = renderer;
8
- this.itemWidth = 200; // Fixed width in pixels
9
- this.gap = 16; // Gap between items in pixels
10
- this.removeArrows = false;
9
+ this.itemWidth = 200;
10
+ this.gap = 16;
11
+ this.showArrows = true;
12
+ this.showDots = true;
11
13
  this.previousClickEventEmitter = new EventEmitter();
12
14
  this.nextClickEventEmitter = new EventEmitter();
13
15
  this.currentIndex = 0;
14
16
  this.translateX = 0;
15
17
  this.isDragging = false;
18
+ this.isMouseDown = false;
16
19
  this.startX = 0;
17
20
  this.currentX = 0;
18
21
  this.initialTranslateX = 0;
@@ -32,19 +35,35 @@ export class EluxCarouselFixedComponent {
32
35
  this.clickListeners = [];
33
36
  this.dragStarted = false;
34
37
  this.mouseDownTime = 0;
38
+ this.calculateRightBleedContainer = () => {
39
+ if (this.rightBleedContainer) {
40
+ const el = this.rightBleedContainer.nativeElement;
41
+ const left = el.getBoundingClientRect().left;
42
+ let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;
43
+ scrollbarWidth = scrollbarWidth == 0 || scrollbarWidth > 30 ? 0 : scrollbarWidth;
44
+ el.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);
45
+ el.style.setProperty('--left-offset', `${left}px`);
46
+ }
47
+ };
35
48
  }
36
49
  ngAfterContentInit() {
37
- this.calculateDimensions();
38
- this.setItemWidths();
39
- this.updateLimits();
40
- this.setupClickPrevention();
41
- this.items.changes.subscribe(() => {
50
+ setTimeout(() => {
42
51
  this.calculateDimensions();
43
52
  this.setItemWidths();
44
53
  this.updateLimits();
45
- this.goToFirstItem();
46
54
  this.setupClickPrevention();
47
- });
55
+ this.items.changes.subscribe(() => {
56
+ this.calculateDimensions();
57
+ this.setItemWidths();
58
+ this.updateLimits();
59
+ this.goToFirstItem();
60
+ this.setupClickPrevention();
61
+ // Força atualização visual dos dots
62
+ if (this.cd && typeof this.cd.detectChanges === 'function') {
63
+ this.cd.detectChanges();
64
+ }
65
+ });
66
+ }, 10);
48
67
  window.addEventListener('resize', () => this.onResize());
49
68
  }
50
69
  ngOnDestroy() {
@@ -59,23 +78,41 @@ export class EluxCarouselFixedComponent {
59
78
  }
60
79
  }
61
80
  updateLimits() {
62
- const totalWidth = this.items.length * (this.itemWidth + this.gap) - this.gap;
81
+ const totalWidth = this.items.length * (this.itemWidth + this.gap);
63
82
  this.maxTranslateX = 0;
64
- // Calculate minimum translateX to ensure last item is fully visible
65
83
  if (totalWidth > this.containerWidth) {
66
84
  this.minTranslateX = this.containerWidth - totalWidth;
67
- // Add some padding to ensure last item is completely visible
68
- const paddingOffset = this.gap;
69
- this.minTranslateX -= paddingOffset;
70
85
  }
71
86
  else {
72
87
  this.minTranslateX = 0;
73
88
  }
74
89
  }
75
90
  onResize() {
91
+ this.calculateRightBleedContainer();
76
92
  this.calculateDimensions();
77
93
  this.updateLimits();
94
+ // Garante que o currentIndex não ultrapasse o novo máximo
95
+ const maxIndex = this.getMaxIndex();
96
+ if (this.currentIndex > maxIndex) {
97
+ this.currentIndex = maxIndex;
98
+ }
78
99
  this.updateTransform();
100
+ // Força detecção de mudanças para atualizar dots
101
+ if (window.ng && window.ng.getInjector) {
102
+ // Angular DevTools presente, não faz nada
103
+ }
104
+ else if (this.cd && typeof this.cd.detectChanges === 'function') {
105
+ this.cd.detectChanges();
106
+ }
107
+ }
108
+ ngAfterViewInit() {
109
+ // Garante cálculo correto após view carregada
110
+ setTimeout(() => {
111
+ this.calculateRightBleedContainer();
112
+ this.calculateDimensions();
113
+ this.updateLimits();
114
+ this.updateTransform();
115
+ });
79
116
  }
80
117
  setItemWidths() {
81
118
  this.items.forEach((item) => {
@@ -83,50 +120,64 @@ export class EluxCarouselFixedComponent {
83
120
  this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');
84
121
  this.renderer.setStyle(item.nativeElement, 'margin-right', `${this.gap}px`);
85
122
  });
86
- // Remove margin from last item
87
- if (this.items.last) {
88
- this.renderer.setStyle(this.items.last.nativeElement, 'margin-right', '0');
89
- }
90
123
  }
91
124
  // Mouse events
92
125
  onMouseDown(event) {
93
126
  event.preventDefault();
94
127
  this.mouseDownTime = Date.now();
95
128
  this.dragStarted = false;
96
- this.startDrag(event.clientX);
129
+ this.isMouseDown = true;
130
+ this.wasDragging = false;
131
+ this.clicksDisabled = false;
132
+ this.startX = event.clientX;
133
+ this.currentX = event.clientX;
134
+ this.initialTranslateX = this.translateX;
135
+ this.dragOffset = 0;
136
+ this.velocity = 0;
137
+ this.lastMoveTime = Date.now();
138
+ this.lastMoveX = event.clientX;
139
+ this.calculateDimensions();
140
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
97
141
  }
98
142
  onMouseMove(event) {
143
+ if (!this.isMouseDown)
144
+ return;
145
+ event.preventDefault();
146
+ const dragDistance = Math.abs(event.clientX - this.startX);
147
+ // Only start dragging if moved more than 5px
148
+ if (dragDistance > 5 && !this.isDragging) {
149
+ this.isDragging = true;
150
+ this.dragStarted = true;
151
+ this.wasDragging = true;
152
+ }
99
153
  if (this.isDragging) {
100
- event.preventDefault();
101
- // Mark that we've started dragging if we've moved more than 5px
102
- const dragDistance = Math.abs(this.currentX - this.startX);
103
- if (dragDistance > 5 && !this.dragStarted) {
104
- this.dragStarted = true;
105
- this.wasDragging = true;
106
- }
107
154
  this.updateDrag(event.clientX);
108
155
  }
109
156
  }
110
157
  onMouseUp(event) {
158
+ if (!this.isMouseDown)
159
+ return;
160
+ this.isMouseDown = false;
111
161
  if (this.isDragging) {
112
162
  const mouseUpTime = Date.now();
113
163
  const holdDuration = mouseUpTime - this.mouseDownTime;
114
164
  const mouseDistance = Math.abs(this.currentX - this.startX);
115
- // Consider it a drag if:
116
- // 1. We moved more than 5px, OR
117
- // 2. We held the mouse down for more than 200ms and moved at all
118
165
  if (mouseDistance > 5 || (holdDuration > 200 && mouseDistance > 0)) {
119
166
  this.wasDragging = true;
120
167
  }
121
168
  this.endDrag();
122
169
  }
170
+ else {
171
+ // Reset transition if it was just a click
172
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
173
+ }
123
174
  }
124
175
  onMouseLeave(event) {
125
176
  if (this.isDragging) {
126
- // If mouse leaves while dragging, definitely consider it a drag
127
177
  this.wasDragging = true;
128
178
  this.endDrag();
129
179
  }
180
+ this.isMouseDown = false;
130
181
  }
131
182
  // Touch events
132
183
  onTouchStart(event) {
@@ -134,10 +185,22 @@ export class EluxCarouselFixedComponent {
134
185
  this.touchStartX = event.touches[0].clientX;
135
186
  this.touchStartY = event.touches[0].clientY;
136
187
  this.isVerticalScroll = false;
137
- this.startDrag(event.touches[0].clientX);
188
+ this.isMouseDown = true;
189
+ this.wasDragging = false;
190
+ this.dragStarted = false;
191
+ this.clicksDisabled = false;
192
+ this.startX = event.touches[0].clientX;
193
+ this.currentX = event.touches[0].clientX;
194
+ this.initialTranslateX = this.translateX;
195
+ this.dragOffset = 0;
196
+ this.velocity = 0;
197
+ this.lastMoveTime = Date.now();
198
+ this.lastMoveX = event.touches[0].clientX;
199
+ this.calculateDimensions();
200
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
138
201
  }
139
202
  onTouchMove(event) {
140
- if (!this.isDragging)
203
+ if (!this.isMouseDown)
141
204
  return;
142
205
  const currentX = event.touches[0].clientX;
143
206
  const currentY = event.touches[0].clientY;
@@ -147,20 +210,28 @@ export class EluxCarouselFixedComponent {
147
210
  if (deltaY > deltaX && deltaY > 10) {
148
211
  this.isVerticalScroll = true;
149
212
  this.isDragging = false;
213
+ this.isMouseDown = false;
150
214
  this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
151
215
  return;
152
216
  }
153
- // Only prevent default if it's a horizontal drag
154
- if (deltaX > 10) {
217
+ // Start dragging if horizontal movement > 10px
218
+ if (deltaX > 10 && !this.isDragging) {
219
+ this.isDragging = true;
220
+ this.dragStarted = true;
221
+ this.wasDragging = true;
222
+ }
223
+ if (this.isDragging && deltaX > 10) {
155
224
  event.preventDefault();
156
- this.updateDrag(event.touches[0].clientX);
225
+ this.updateDrag(currentX);
157
226
  }
158
227
  }
159
228
  onTouchEnd(event) {
160
229
  if (this.isVerticalScroll) {
161
230
  this.isVerticalScroll = false;
231
+ this.isMouseDown = false;
162
232
  return;
163
233
  }
234
+ this.isMouseDown = false;
164
235
  const touchDuration = Date.now() - this.touchStartTime;
165
236
  const touchDistance = Math.abs(this.currentX - this.startX);
166
237
  // Mark as dragging if significant movement occurred
@@ -170,6 +241,10 @@ export class EluxCarouselFixedComponent {
170
241
  if (this.isDragging) {
171
242
  this.endDrag();
172
243
  }
244
+ else {
245
+ // Reset transition if it was just a tap
246
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
247
+ }
173
248
  }
174
249
  setupClickPrevention() {
175
250
  // Clean up existing listeners
@@ -193,21 +268,6 @@ export class EluxCarouselFixedComponent {
193
268
  });
194
269
  });
195
270
  }
196
- startDrag(clientX) {
197
- this.isDragging = true;
198
- this.wasDragging = false;
199
- this.dragStarted = false;
200
- this.clicksDisabled = false;
201
- this.startX = clientX;
202
- this.currentX = clientX;
203
- this.initialTranslateX = this.translateX;
204
- this.dragOffset = 0;
205
- this.velocity = 0;
206
- this.lastMoveTime = Date.now();
207
- this.lastMoveX = clientX;
208
- this.calculateDimensions();
209
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
210
- }
211
271
  updateDrag(clientX) {
212
272
  if (!this.isDragging)
213
273
  return;
@@ -260,156 +320,149 @@ export class EluxCarouselFixedComponent {
260
320
  this.dragStarted = false;
261
321
  }, 250);
262
322
  this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
263
- // Calculate how far we've actually moved in terms of items
264
- const currentTranslateX = this.initialTranslateX + this.dragOffset;
265
- const itemStep = this.itemWidth + this.gap;
266
- const movedItemsFloat = Math.abs(currentTranslateX - this.initialTranslateX) / itemStep;
267
- // Adjusted thresholds
268
- const minThreshold = 0.25;
269
- const dragDistance = Math.abs(this.currentX - this.startX);
270
- const momentumThreshold = 0.2;
271
- const hasSignificantVelocity = Math.abs(this.velocity) > momentumThreshold;
272
- // More lenient conditions
273
- if (movedItemsFloat > minThreshold || hasSignificantVelocity || dragDistance > 40) {
274
- // Calculate how many items to advance based on actual drag distance
275
- let itemsToAdvance = Math.round(movedItemsFloat);
276
- // For velocity-based movement, use a separate calculation
277
- if (hasSignificantVelocity && movedItemsFloat < 1) {
278
- const velocityMultiplier = Math.abs(this.velocity) * 2;
279
- itemsToAdvance = Math.max(1, Math.floor(velocityMultiplier));
280
- }
281
- // Ensure minimum 1 item for significant drags, but don't double count
282
- if (itemsToAdvance === 0 && movedItemsFloat >= minThreshold) {
283
- itemsToAdvance = 1;
284
- }
285
- if (this.dragOffset > 0 || (hasSignificantVelocity && this.velocity > 0)) {
286
- // Dragged right - go to previous items
287
- this.goToPreviousItems(itemsToAdvance);
288
- }
289
- else if (this.dragOffset < 0 || (hasSignificantVelocity && this.velocity < 0)) {
290
- // Dragged left - go to next items
291
- this.goToNextItems(itemsToAdvance);
292
- }
293
- else {
294
- this.snapToNearestItem();
295
- }
296
- }
297
- else {
298
- // Small movement - snap to nearest item
299
- this.snapToNearestItem();
300
- }
323
+ // Snap sempre para o início da página mais próxima
324
+ this.snapToNearestItem();
301
325
  this.dragOffset = 0;
302
326
  this.velocity = 0;
303
327
  }
304
- snapToNearestItem() {
305
- const currentTranslateX = this.initialTranslateX + this.dragOffset;
306
- const itemStep = this.itemWidth + this.gap;
307
- // Find the closest valid position
308
- let targetIndex = Math.round(-currentTranslateX / itemStep);
309
- // Clamp to valid bounds
310
- const maxIndex = this.getMaxIndex();
311
- targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));
312
- this.currentIndex = targetIndex;
313
- this.updateTransform();
328
+ getMaxIndex() {
329
+ // Permite avançar até que o último item esteja visível (não necessariamente alinhado à esquerda)
330
+ if (!this.items || this.items.length === 0)
331
+ return 0;
332
+ const visibleCount = Math.max(1, Math.floor(this.containerWidth / (this.itemWidth + this.gap)));
333
+ if (this.items.length <= visibleCount)
334
+ return 0;
335
+ // Última posição onde o último item aparece visível
336
+ return this.items.length - visibleCount;
314
337
  }
315
- goToPreviousItems(itemCount) {
316
- // Use the current index instead of visual calculation to avoid double movement
317
- const newIndex = Math.max(0, this.currentIndex - itemCount);
318
- if (newIndex !== this.currentIndex) {
319
- this.currentIndex = newIndex;
320
- this.updateTransform();
321
- this.previousClickEventEmitter.emit();
322
- }
323
- else {
324
- this.snapToNearestItem();
325
- }
338
+ canGoNext() {
339
+ return this.currentIndex < this.getMaxIndex();
326
340
  }
327
- goToNextItems(itemCount) {
328
- // Use the current index instead of visual calculation to avoid double movement
341
+ nextItem() {
329
342
  const maxIndex = this.getMaxIndex();
330
- const newIndex = Math.min(maxIndex, this.currentIndex + itemCount);
331
- if (newIndex !== this.currentIndex) {
343
+ if (this.canGoNext()) {
344
+ let newIndex = this.currentIndex + 1;
345
+ if (newIndex > maxIndex)
346
+ newIndex = maxIndex;
332
347
  this.currentIndex = newIndex;
333
348
  this.updateTransform();
334
349
  this.nextClickEventEmitter.emit();
335
350
  }
336
- else {
337
- this.snapToNearestItem();
338
- }
339
351
  }
340
352
  canGoPrevious() {
341
353
  return this.currentIndex > 0;
342
354
  }
343
- canGoNext() {
344
- return this.currentIndex < this.getMaxIndex();
345
- }
346
- goToFirstItem() {
347
- this.currentIndex = 0;
348
- this.updateTransform();
349
- }
350
355
  prevItem() {
351
356
  if (this.canGoPrevious()) {
352
- this.currentIndex--;
357
+ let newIndex = this.currentIndex - 1;
358
+ if (newIndex < 0)
359
+ newIndex = 0;
360
+ this.currentIndex = newIndex;
353
361
  this.updateTransform();
354
362
  this.previousClickEventEmitter.emit();
355
363
  }
356
364
  }
357
- nextItem() {
358
- if (this.canGoNext()) {
359
- this.currentIndex++;
360
- this.updateTransform();
361
- this.nextClickEventEmitter.emit();
365
+ goToDot(dotIndex) {
366
+ const maxIndex = this.getMaxIndex();
367
+ let newIndex = dotIndex;
368
+ if (newIndex > maxIndex)
369
+ newIndex = maxIndex;
370
+ this.currentIndex = newIndex;
371
+ this.updateTransform();
372
+ }
373
+ snapToNearestItem() {
374
+ const itemStep = this.itemWidth + this.gap;
375
+ const position = -(this.initialTranslateX + this.dragOffset) / itemStep;
376
+ // Threshold: 0.3 = 30%, 0.5 = 50% (padrão)
377
+ const threshold = 0.3;
378
+ let targetIndex;
379
+ // Calcula quantos itens completos foram arrastados
380
+ const itemsMoved = Math.floor(Math.abs(position - this.currentIndex));
381
+ const decimal = Math.abs(position - this.currentIndex) - itemsMoved;
382
+ if (position > this.currentIndex) {
383
+ // Arrastando para frente
384
+ if (decimal >= threshold) {
385
+ targetIndex = this.currentIndex + itemsMoved + 1;
386
+ }
387
+ else {
388
+ targetIndex = this.currentIndex + itemsMoved;
389
+ }
390
+ }
391
+ else if (position < this.currentIndex) {
392
+ // Arrastando para trás
393
+ if (decimal >= threshold) {
394
+ targetIndex = this.currentIndex - itemsMoved - 1;
395
+ }
396
+ else {
397
+ targetIndex = this.currentIndex - itemsMoved;
398
+ }
362
399
  }
400
+ else {
401
+ // Não se moveu
402
+ targetIndex = this.currentIndex;
403
+ }
404
+ const maxIndex = this.getMaxIndex();
405
+ targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));
406
+ this.currentIndex = targetIndex;
407
+ this.updateTransform();
408
+ }
409
+ getDotsArray() {
410
+ // Só mostra dots para cada posição possível (cada "página" possível)
411
+ const maxIndex = this.getMaxIndex();
412
+ return Array(maxIndex + 1);
413
+ }
414
+ getCurrentDotIndex() {
415
+ return this.currentIndex;
363
416
  }
364
417
  updateTransform() {
365
418
  const itemStep = this.itemWidth + this.gap;
366
419
  this.translateX = -this.currentIndex * itemStep;
367
- // Apply strict boundaries to ensure last item is always fully visible
368
- this.translateX = Math.max(this.minTranslateX, Math.min(this.maxTranslateX, this.translateX));
369
- // Recalculate currentIndex based on actual translateX to stay in sync
370
- if (this.translateX <= this.minTranslateX) {
371
- this.currentIndex = this.getMaxIndex();
420
+ // Clamp para não mostrar espaço vazio à direita
421
+ const visibleCount = Math.max(1, Math.floor(this.containerWidth / itemStep));
422
+ // Inclui o gap após o último item
423
+ const totalWidth = this.items.length * itemStep;
424
+ if (this.items.length > visibleCount) {
425
+ const minTranslateX = this.containerWidth - totalWidth;
426
+ this.translateX = Math.max(this.translateX, minTranslateX);
372
427
  }
373
428
  else {
374
- this.currentIndex = Math.max(0, Math.min(this.currentIndex, this.getMaxIndex()));
429
+ this.translateX = 0;
375
430
  }
376
431
  if (!this.isDragging && this.slidesContainer) {
377
432
  this.renderer.setStyle(this.slidesContainer.nativeElement, 'transform', `translateX(${this.translateX}px)`);
378
433
  }
379
434
  }
380
- getMaxIndex() {
381
- const visibleWidth = this.containerWidth;
382
- const totalItemsWidth = this.items.length * (this.itemWidth + this.gap) - this.gap;
383
- if (totalItemsWidth <= visibleWidth) {
384
- return 0;
385
- }
386
- // Calculate how many complete items can fit in the visible area
387
- const itemsPerView = Math.floor(visibleWidth / (this.itemWidth + this.gap));
388
- // Maximum index ensures the last item is always fully visible
389
- const maxIndex = Math.max(0, this.items.length - itemsPerView);
390
- return maxIndex;
435
+ // Adicione este método para evitar erro de propriedade ausente
436
+ goToFirstItem() {
437
+ this.currentIndex = 0;
438
+ this.updateTransform();
391
439
  }
392
440
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: EluxCarouselFixedComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
393
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: EluxCarouselFixedComponent, isStandalone: true, selector: "lib-elux-carousel-fixed", inputs: { itemWidth: "itemWidth", gap: "gap", removeArrows: "removeArrows" }, outputs: { previousClickEventEmitter: "previousClickEventEmitter", nextClickEventEmitter: "nextClickEventEmitter" }, queries: [{ propertyName: "items", predicate: ["carouselItem"], read: ElementRef }], viewQueries: [{ propertyName: "slidesContainer", first: true, predicate: ["slidesContainer"], descendants: true }], ngImport: i0, template: "<div class=\"c-carousel-fixed-container\">\n <div \n class=\"c-carousel-fixed-slides\" \n #slidesContainer\n [style.transform]=\"'translateX(' + translateX + 'px)'\" \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-fixed-footer\" [hidden]=\"removeArrows\">\n <button \n class=\"c-carousel-fixed-nav prev\" \n [disabled]=\"!canGoPrevious()\"\n title=\"Item anterior\" \n aria-label=\"Item anterior\" \n (click)=\"prevItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n\n <button \n class=\"c-carousel-fixed-nav next\" \n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3ximo item\" \n aria-label=\"Pr\u00F3ximo item\" \n (click)=\"nextItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n </div>\n</div>\n", styles: [".c-carousel-fixed-container{position:relative;width:100%;padding-right:16px}.c-carousel-fixed-slides{display:flex;transition:transform .3s ease-out;touch-action:pan-y;cursor:grab;-webkit-user-select:none;user-select:none;will-change:transform;padding-right:16px}.c-carousel-fixed-slides:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 0}.c-carousel-fixed-footer .c-carousel-fixed-nav{background:none;border:none;cursor:pointer;padding:8px;border-radius:50px;background-color:#dfe7ea;transition:all ease-in-out .2s;z-index:2}.c-carousel-fixed-footer .c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.1)}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled{opacity:.5;cursor:not-allowed}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-footer .c-carousel-fixed-nav ::ng-deep span{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: EluxIcon, selector: "lib-elux-icon", inputs: ["color", "useSubscription", "icon", "description", "size", "height", "width", "sizeType"] }] }); }
441
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: EluxCarouselFixedComponent, isStandalone: true, selector: "lib-elux-carousel-fixed", inputs: { itemWidth: "itemWidth", gap: "gap", showArrows: "showArrows", showDots: "showDots" }, outputs: { previousClickEventEmitter: "previousClickEventEmitter", nextClickEventEmitter: "nextClickEventEmitter" }, queries: [{ propertyName: "items", predicate: ["carouselItem"], read: ElementRef }], viewQueries: [{ propertyName: "slidesContainer", first: true, predicate: ["slidesContainer"], descendants: true }, { propertyName: "rightBleedContainer", first: true, predicate: ["rightBleedContainer"], descendants: true }], ngImport: i0, template: "<div class=\"c-carousel-fixed-container\" #rightBleedContainer>\n <div \n class=\"c-carousel-fixed-slides\" \n #slidesContainer\n [style.transform]=\"'translateX(' + translateX + 'px)'\" \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</div>\n<div class=\"c-carousel-fixed-footer\" *ngIf=\"showArrows || showDots\">\n <button *ngIf=\"showArrows\"\n class=\"c-carousel-fixed-nav prev\" \n [disabled]=\"!canGoPrevious()\"\n title=\"Item anterior\" \n aria-label=\"Item anterior\" \n (click)=\"prevItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n\n <div class=\"c-carousel-fixed-dots\" *ngIf=\"showDots\">\n <ng-container *ngFor=\"let dot of getDotsArray(); let idx = index\">\n <span \n class=\"c-carousel-fixed-dot\" \n [class.active]=\"idx === getCurrentDotIndex()\" \n (click)=\"goToDot(idx)\">\n </span>\n </ng-container>\n </div>\n\n <button *ngIf=\"showArrows\"\n class=\"c-carousel-fixed-nav next\" \n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3ximo item\" \n aria-label=\"Pr\u00F3ximo item\" \n (click)=\"nextItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n</div>\n", styles: [".c-carousel-fixed-container{overflow-x:hidden;width:calc(100vw - var(--left-offset, 0px) - var(--scrollbar-width, 0px))}.c-carousel-fixed-slides{display:flex;transition:transform .5s ease-out;touch-action:pan-y;cursor:grab;will-change:transform}.c-carousel-fixed-slides:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;justify-content:space-between;padding:16px}.c-carousel-fixed-footer .c-carousel-fixed-nav{background:none;border:none;cursor:pointer;padding:8px;border-radius:50px;background-color:#dfe7ea;transition:all ease-in-out .2s;z-index:2}.c-carousel-fixed-footer .c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.2)}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled{opacity:.3;cursor:not-allowed}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-footer .c-carousel-fixed-nav ::ng-deep span{display:block}.c-carousel-fixed-footer .c-carousel-fixed-dots{display:flex;align-items:center;gap:8px;margin:0 16px}.c-carousel-fixed-footer .c-carousel-fixed-dots .c-carousel-fixed-dot{width:10px;height:10px;border-radius:50%;background:#dfe7ea;transition:background .3s;cursor:pointer;display:inline-block}.c-carousel-fixed-footer .c-carousel-fixed-dots .c-carousel-fixed-dot.active{background:#011e41}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: EluxIcon, selector: "lib-elux-icon", inputs: ["color", "useSubscription", "icon", "description", "size", "height", "width", "sizeType"] }] }); }
394
442
  }
395
443
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: EluxCarouselFixedComponent, decorators: [{
396
444
  type: Component,
397
- args: [{ standalone: true, selector: 'lib-elux-carousel-fixed', imports: [CommonModule, EluxIcon], template: "<div class=\"c-carousel-fixed-container\">\n <div \n class=\"c-carousel-fixed-slides\" \n #slidesContainer\n [style.transform]=\"'translateX(' + translateX + 'px)'\" \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-fixed-footer\" [hidden]=\"removeArrows\">\n <button \n class=\"c-carousel-fixed-nav prev\" \n [disabled]=\"!canGoPrevious()\"\n title=\"Item anterior\" \n aria-label=\"Item anterior\" \n (click)=\"prevItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n\n <button \n class=\"c-carousel-fixed-nav next\" \n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3ximo item\" \n aria-label=\"Pr\u00F3ximo item\" \n (click)=\"nextItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n </div>\n</div>\n", styles: [".c-carousel-fixed-container{position:relative;width:100%;padding-right:16px}.c-carousel-fixed-slides{display:flex;transition:transform .3s ease-out;touch-action:pan-y;cursor:grab;-webkit-user-select:none;user-select:none;will-change:transform;padding-right:16px}.c-carousel-fixed-slides:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 0}.c-carousel-fixed-footer .c-carousel-fixed-nav{background:none;border:none;cursor:pointer;padding:8px;border-radius:50px;background-color:#dfe7ea;transition:all ease-in-out .2s;z-index:2}.c-carousel-fixed-footer .c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.1)}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled{opacity:.5;cursor:not-allowed}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-footer .c-carousel-fixed-nav ::ng-deep span{display:block}\n"] }]
445
+ args: [{ standalone: true, selector: 'lib-elux-carousel-fixed', imports: [CommonModule, EluxIcon], template: "<div class=\"c-carousel-fixed-container\" #rightBleedContainer>\n <div \n class=\"c-carousel-fixed-slides\" \n #slidesContainer\n [style.transform]=\"'translateX(' + translateX + 'px)'\" \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</div>\n<div class=\"c-carousel-fixed-footer\" *ngIf=\"showArrows || showDots\">\n <button *ngIf=\"showArrows\"\n class=\"c-carousel-fixed-nav prev\" \n [disabled]=\"!canGoPrevious()\"\n title=\"Item anterior\" \n aria-label=\"Item anterior\" \n (click)=\"prevItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n\n <div class=\"c-carousel-fixed-dots\" *ngIf=\"showDots\">\n <ng-container *ngFor=\"let dot of getDotsArray(); let idx = index\">\n <span \n class=\"c-carousel-fixed-dot\" \n [class.active]=\"idx === getCurrentDotIndex()\" \n (click)=\"goToDot(idx)\">\n </span>\n </ng-container>\n </div>\n\n <button *ngIf=\"showArrows\"\n class=\"c-carousel-fixed-nav next\" \n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3ximo item\" \n aria-label=\"Pr\u00F3ximo item\" \n (click)=\"nextItem()\">\n <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n </button>\n</div>\n", styles: [".c-carousel-fixed-container{overflow-x:hidden;width:calc(100vw - var(--left-offset, 0px) - var(--scrollbar-width, 0px))}.c-carousel-fixed-slides{display:flex;transition:transform .5s ease-out;touch-action:pan-y;cursor:grab;will-change:transform}.c-carousel-fixed-slides:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;justify-content:space-between;padding:16px}.c-carousel-fixed-footer .c-carousel-fixed-nav{background:none;border:none;cursor:pointer;padding:8px;border-radius:50px;background-color:#dfe7ea;transition:all ease-in-out .2s;z-index:2}.c-carousel-fixed-footer .c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.2)}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled{opacity:.3;cursor:not-allowed}.c-carousel-fixed-footer .c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-footer .c-carousel-fixed-nav ::ng-deep span{display:block}.c-carousel-fixed-footer .c-carousel-fixed-dots{display:flex;align-items:center;gap:8px;margin:0 16px}.c-carousel-fixed-footer .c-carousel-fixed-dots .c-carousel-fixed-dot{width:10px;height:10px;border-radius:50%;background:#dfe7ea;transition:background .3s;cursor:pointer;display:inline-block}.c-carousel-fixed-footer .c-carousel-fixed-dots .c-carousel-fixed-dot.active{background:#011e41}\n"] }]
398
446
  }], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { items: [{
399
447
  type: ContentChildren,
400
448
  args: ['carouselItem', { read: ElementRef }]
401
449
  }], slidesContainer: [{
402
450
  type: ViewChild,
403
451
  args: ['slidesContainer']
452
+ }], rightBleedContainer: [{
453
+ type: ViewChild,
454
+ args: ['rightBleedContainer', { static: false }]
404
455
  }], itemWidth: [{
405
456
  type: Input
406
457
  }], gap: [{
407
458
  type: Input
408
- }], removeArrows: [{
459
+ }], showArrows: [{
460
+ type: Input
461
+ }], showDots: [{
409
462
  type: Input
410
463
  }], previousClickEventEmitter: [{
411
464
  type: Output
412
465
  }], nextClickEventEmitter: [{
413
466
  type: Output
414
467
  }] } });
415
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel-fixed.component.js","sourceRoot":"","sources":["../../../../../../../ui/library/src/lib/components/carousel-fixed/carousel-fixed.component.ts","../../../../../../../ui/library/src/lib/components/carousel-fixed/carousel-fixed.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\n@Component({\n  standalone: true,\n  selector: 'lib-elux-carousel-fixed',\n  templateUrl: './carousel-fixed.component.html',\n  styleUrls: ['./carousel-fixed.component.scss'],\n  imports: [CommonModule, EluxIcon],\n})\nexport class EluxCarouselFixedComponent implements AfterContentInit, OnDestroy {\n  @ContentChildren('carouselItem', { read: ElementRef }) items!: QueryList<ElementRef>;\n  @ViewChild('slidesContainer') slidesContainer!: ElementRef;\n\n  @Input() itemWidth: number = 200; // Fixed width in pixels\n  @Input() gap: number = 16; // Gap between items in pixels\n  @Input() removeArrows: boolean = false;\n\n  @Output() previousClickEventEmitter = new EventEmitter<Event>();\n  @Output() nextClickEventEmitter = new EventEmitter<Event>();\n\n  currentIndex = 0;\n  translateX = 0;\n\n  private isDragging = false;\n  private startX = 0;\n  private currentX = 0;\n  private initialTranslateX = 0;\n  private dragOffset = 0;\n  private containerWidth = 0;\n  private maxTranslateX = 0;\n  private minTranslateX = 0;\n  private velocity = 0;\n  private lastMoveTime = 0;\n  private lastMoveX = 0;\n  private touchStartTime = 0;\n  private touchStartX = 0;\n  private touchStartY = 0;\n  private isVerticalScroll = false;\n  private wasDragging = false;\n  private clicksDisabled = false;\n  private clickListeners: (() => void)[] = [];\n  private dragStarted = false;\n  private mouseDownTime = 0;\n\n  constructor(private renderer: Renderer2) {}\n\n  ngAfterContentInit() {\n    this.calculateDimensions();\n    this.setItemWidths();\n    this.updateLimits();\n    this.setupClickPrevention();\n\n    this.items.changes.subscribe(() => {\n      this.calculateDimensions();\n      this.setItemWidths();\n      this.updateLimits();\n      this.goToFirstItem();\n      this.setupClickPrevention();\n    });\n\n    window.addEventListener('resize', () => this.onResize());\n  }\n\n  ngOnDestroy() {\n    // Clean up click listeners\n    this.clickListeners.forEach(unlisten => unlisten());\n    this.clickListeners = [];\n    window.removeEventListener('resize', () => this.onResize());\n  }\n\n  private calculateDimensions() {\n    if (this.slidesContainer) {\n      this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;\n    }\n  }\n\n  private updateLimits() {\n    const totalWidth = this.items.length * (this.itemWidth + this.gap) - this.gap;\n    this.maxTranslateX = 0;\n    \n    // Calculate minimum translateX to ensure last item is fully visible\n    if (totalWidth > this.containerWidth) {\n      this.minTranslateX = this.containerWidth - totalWidth;\n      \n      // Add some padding to ensure last item is completely visible\n      const paddingOffset = this.gap;\n      this.minTranslateX -= paddingOffset;\n    } else {\n      this.minTranslateX = 0;\n    }\n  }\n\n  private onResize() {\n    this.calculateDimensions();\n    this.updateLimits();\n    this.updateTransform();\n  }\n\n  private setItemWidths() {\n    this.items.forEach((item) => {\n      this.renderer.setStyle(item.nativeElement, 'width', `${this.itemWidth}px`);\n      this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');\n      this.renderer.setStyle(item.nativeElement, 'margin-right', `${this.gap}px`);\n    });\n    \n    // Remove margin from last item\n    if (this.items.last) {\n      this.renderer.setStyle(this.items.last.nativeElement, 'margin-right', '0');\n    }\n  }\n\n  // Mouse events\n  onMouseDown(event: MouseEvent) {\n    event.preventDefault();\n    this.mouseDownTime = Date.now();\n    this.dragStarted = false;\n    this.startDrag(event.clientX);\n  }\n\n  onMouseMove(event: MouseEvent) {\n    if (this.isDragging) {\n      event.preventDefault();\n      \n      // Mark that we've started dragging if we've moved more than 5px\n      const dragDistance = Math.abs(this.currentX - this.startX);\n      if (dragDistance > 5 && !this.dragStarted) {\n        this.dragStarted = true;\n        this.wasDragging = true;\n      }\n      \n      this.updateDrag(event.clientX);\n    }\n  }\n\n  onMouseUp(event: MouseEvent) {\n    if (this.isDragging) {\n      const mouseUpTime = Date.now();\n      const holdDuration = mouseUpTime - this.mouseDownTime;\n      const mouseDistance = Math.abs(this.currentX - this.startX);\n      \n      // Consider it a drag if:\n      // 1. We moved more than 5px, OR\n      // 2. We held the mouse down for more than 200ms and moved at all\n      if (mouseDistance > 5 || (holdDuration > 200 && mouseDistance > 0)) {\n        this.wasDragging = true;\n      }\n      \n      this.endDrag();\n    }\n  }\n\n  onMouseLeave(event: MouseEvent) {\n    if (this.isDragging) {\n      // If mouse leaves while dragging, definitely consider it a drag\n      this.wasDragging = true;\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.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s 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    // Mark as dragging if significant movement occurred\n    if (touchDistance > 10 || touchDuration > 300) {\n      this.wasDragging = true;\n    }\n    \n    if (this.isDragging) {\n      this.endDrag();\n    }\n  }\n\n  private setupClickPrevention() {\n    // Clean up existing listeners\n    this.clickListeners.forEach(unlisten => unlisten());\n    this.clickListeners = [];\n\n    this.items.forEach((item) => {\n      // Only prevent click events, not mouseup which is needed for drag functionality\n      const eventHandler = (event: Event) => {\n        if (event.type === 'click' && (this.wasDragging || this.clicksDisabled || this.dragStarted)) {\n          event.preventDefault();\n          event.stopPropagation();\n          event.stopImmediatePropagation();\n          return false;\n        }\n        return true;\n      };\n\n      // Only listen to click events to avoid interfering with drag functionality\n      item.nativeElement.addEventListener('click', eventHandler, true);\n      \n      this.clickListeners.push(() => {\n        item.nativeElement.removeEventListener('click', eventHandler, true);\n      });\n    });\n  }\n\n  private startDrag(clientX: number) {\n    this.isDragging = true;\n    this.wasDragging = false;\n    this.dragStarted = false;\n    this.clicksDisabled = false;\n    this.startX = clientX;\n    this.currentX = clientX;\n    this.initialTranslateX = this.translateX;\n    this.dragOffset = 0;\n    this.velocity = 0;\n    this.lastMoveTime = Date.now();\n    this.lastMoveX = clientX;\n    \n    this.calculateDimensions();\n    \n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');\n  }\n\n  private updateDrag(clientX: number) {\n    if (!this.isDragging) return;\n\n    this.currentX = clientX;\n    const totalDeltaX = this.currentX - this.startX;\n    \n    // Mark as dragging if movement is significant\n    if (Math.abs(totalDeltaX) > 5) {\n      this.wasDragging = true;\n      this.dragStarted = true;\n    }\n    \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    let resistedDeltaX = totalDeltaX;\n    const potentialTranslateX = this.initialTranslateX + totalDeltaX;\n    \n    // Apply softer resistance at boundaries\n    if (potentialTranslateX > this.maxTranslateX) {\n      const overDrag = potentialTranslateX - this.maxTranslateX;\n      resistedDeltaX = totalDeltaX - (overDrag * 0.5);\n    } else if (potentialTranslateX < this.minTranslateX) {\n      const overDrag = this.minTranslateX - potentialTranslateX;\n      resistedDeltaX = totalDeltaX + (overDrag * 0.5);\n    }\n\n    this.dragOffset = resistedDeltaX;\n    this.updateDragPosition();\n  }\n\n  private updateDragPosition() {\n    const newTranslateX = this.initialTranslateX + this.dragOffset;\n    this.renderer.setStyle(\n      this.slidesContainer.nativeElement, \n      'transform', \n      `translateX(${newTranslateX}px)`\n    );\n  }\n\n  private endDrag() {\n    if (!this.isDragging) return;\n\n    this.isDragging = false;\n    \n    // Disable clicks temporarily after any drag\n    if (this.wasDragging || this.dragStarted) {\n      this.clicksDisabled = true;\n      setTimeout(() => {\n        this.clicksDisabled = false;\n      }, 200);\n    }\n    \n    // Clear the wasDragging and dragStarted flags after a shorter delay\n    setTimeout(() => {\n      this.wasDragging = false;\n      this.dragStarted = false;\n    }, 250);\n    \n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');\n\n    // Calculate how far we've actually moved in terms of items\n    const currentTranslateX = this.initialTranslateX + this.dragOffset;\n    const itemStep = this.itemWidth + this.gap;\n    const movedItemsFloat = Math.abs(currentTranslateX - this.initialTranslateX) / itemStep;\n    \n    // Adjusted thresholds\n    const minThreshold = 0.25;\n    const dragDistance = Math.abs(this.currentX - this.startX);\n    const momentumThreshold = 0.2;\n    const hasSignificantVelocity = Math.abs(this.velocity) > momentumThreshold;\n    \n    // More lenient conditions\n    if (movedItemsFloat > minThreshold || hasSignificantVelocity || dragDistance > 40) {\n      \n      // Calculate how many items to advance based on actual drag distance\n      let itemsToAdvance = Math.round(movedItemsFloat);\n      \n      // For velocity-based movement, use a separate calculation\n      if (hasSignificantVelocity && movedItemsFloat < 1) {\n        const velocityMultiplier = Math.abs(this.velocity) * 2;\n        itemsToAdvance = Math.max(1, Math.floor(velocityMultiplier));\n      }\n      \n      // Ensure minimum 1 item for significant drags, but don't double count\n      if (itemsToAdvance === 0 && movedItemsFloat >= minThreshold) {\n        itemsToAdvance = 1;\n      }\n      \n      if (this.dragOffset > 0 || (hasSignificantVelocity && this.velocity > 0)) {\n        // Dragged right - go to previous items\n        this.goToPreviousItems(itemsToAdvance);\n      } else if (this.dragOffset < 0 || (hasSignificantVelocity && this.velocity < 0)) {\n        // Dragged left - go to next items\n        this.goToNextItems(itemsToAdvance);\n      } else {\n        this.snapToNearestItem();\n      }\n    } else {\n      // Small movement - snap to nearest item\n      this.snapToNearestItem();\n    }\n\n    this.dragOffset = 0;\n    this.velocity = 0;\n  }\n\n  private snapToNearestItem() {\n    const currentTranslateX = this.initialTranslateX + this.dragOffset;\n    const itemStep = this.itemWidth + this.gap;\n    \n    // Find the closest valid position\n    let targetIndex = Math.round(-currentTranslateX / itemStep);\n    \n    // Clamp to valid bounds\n    const maxIndex = this.getMaxIndex();\n    targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));\n    \n    this.currentIndex = targetIndex;\n    this.updateTransform();\n  }\n\n  private goToPreviousItems(itemCount: number) {\n    // Use the current index instead of visual calculation to avoid double movement\n    const newIndex = Math.max(0, this.currentIndex - itemCount);\n    \n    if (newIndex !== this.currentIndex) {\n      this.currentIndex = newIndex;\n      this.updateTransform();\n      this.previousClickEventEmitter.emit();\n    } else {\n      this.snapToNearestItem();\n    }\n  }\n\n  private goToNextItems(itemCount: number) {\n    // Use the current index instead of visual calculation to avoid double movement\n    const maxIndex = this.getMaxIndex();\n    const newIndex = Math.min(maxIndex, this.currentIndex + itemCount);\n    \n    if (newIndex !== this.currentIndex) {\n      this.currentIndex = newIndex;\n      this.updateTransform();\n      this.nextClickEventEmitter.emit();\n    } else {\n      this.snapToNearestItem();\n    }\n  }\n\n  canGoPrevious(): boolean {\n    return this.currentIndex > 0;\n  }\n\n  canGoNext(): boolean {\n    return this.currentIndex < this.getMaxIndex();\n  }\n\n  goToFirstItem() {\n    this.currentIndex = 0;\n    this.updateTransform();\n  }\n\n  prevItem() {\n    if (this.canGoPrevious()) {\n      this.currentIndex--;\n      this.updateTransform();\n      this.previousClickEventEmitter.emit();\n    }\n  }\n\n  nextItem() {\n    if (this.canGoNext()) {\n      this.currentIndex++;\n      this.updateTransform();\n      this.nextClickEventEmitter.emit();\n    }\n  }\n\n  private updateTransform() {\n    const itemStep = this.itemWidth + this.gap;\n    this.translateX = -this.currentIndex * itemStep;\n    \n    // Apply strict boundaries to ensure last item is always fully visible\n    this.translateX = Math.max(this.minTranslateX, Math.min(this.maxTranslateX, this.translateX));\n    \n    // Recalculate currentIndex based on actual translateX to stay in sync\n    if (this.translateX <= this.minTranslateX) {\n      this.currentIndex = this.getMaxIndex();\n    } else {\n      this.currentIndex = Math.max(0, Math.min(this.currentIndex, this.getMaxIndex()));\n    }\n    \n    if (!this.isDragging && this.slidesContainer) {\n      this.renderer.setStyle(\n        this.slidesContainer.nativeElement, \n        'transform', \n        `translateX(${this.translateX}px)`\n      );\n    }\n  }\n\n  private getMaxIndex(): number {\n    const visibleWidth = this.containerWidth;\n    const totalItemsWidth = this.items.length * (this.itemWidth + this.gap) - this.gap;\n    \n    if (totalItemsWidth <= visibleWidth) {\n      return 0;\n    }\n    \n    // Calculate how many complete items can fit in the visible area\n    const itemsPerView = Math.floor(visibleWidth / (this.itemWidth + this.gap));\n    \n    // Maximum index ensures the last item is always fully visible\n    const maxIndex = Math.max(0, this.items.length - itemsPerView);\n    \n    return maxIndex;\n  }\n}\n","<div class=\"c-carousel-fixed-container\">\n  <div \n    class=\"c-carousel-fixed-slides\" \n    #slidesContainer\n    [style.transform]=\"'translateX(' + translateX + 'px)'\" \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-fixed-footer\" [hidden]=\"removeArrows\">\n    <button \n      class=\"c-carousel-fixed-nav prev\" \n      [disabled]=\"!canGoPrevious()\"\n      title=\"Item anterior\" \n      aria-label=\"Item anterior\" \n      (click)=\"prevItem()\">\n      <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n\n    <button \n      class=\"c-carousel-fixed-nav next\" \n      [disabled]=\"!canGoNext()\"\n      title=\"Próximo item\" \n      aria-label=\"Próximo item\" \n      (click)=\"nextItem()\">\n      <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n  </div>\n</div>\n"]}
468
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel-fixed.component.js","sourceRoot":"","sources":["../../../../../../../ui/library/src/lib/components/carousel-fixed/carousel-fixed.component.ts","../../../../../../../ui/library/src/lib/components/carousel-fixed/carousel-fixed.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\n@Component({\n  standalone: true,\n  selector: 'lib-elux-carousel-fixed',\n  templateUrl: './carousel-fixed.component.html',\n  styleUrls: ['./carousel-fixed.component.scss'],\n  imports: [CommonModule, EluxIcon],\n})\nexport class EluxCarouselFixedComponent implements AfterContentInit, OnDestroy {\n  @ContentChildren('carouselItem', { read: ElementRef }) items!: QueryList<ElementRef>;\n  @ViewChild('slidesContainer') slidesContainer!: ElementRef;\n  @ViewChild('rightBleedContainer', { static: false }) rightBleedContainer!: ElementRef<HTMLDivElement>;\n\n\n  @Input() itemWidth: number = 200;\n  @Input() gap: number = 16;\n  @Input() showArrows: boolean = true;\n  @Input() showDots: boolean = true;\n\n  @Output() previousClickEventEmitter = new EventEmitter<Event>();\n  @Output() nextClickEventEmitter = new EventEmitter<Event>();\n\n  currentIndex = 0;\n  translateX = 0;\n\n  private isDragging = false;\n  private isMouseDown = false;\n  private startX = 0;\n  private currentX = 0;\n  private initialTranslateX = 0;\n  private dragOffset = 0;\n  private containerWidth = 0;\n  private maxTranslateX = 0;\n  private minTranslateX = 0;\n  private velocity = 0;\n  private lastMoveTime = 0;\n  private lastMoveX = 0;\n  private touchStartTime = 0;\n  private touchStartX = 0;\n  private touchStartY = 0;\n  private isVerticalScroll = false;\n  private wasDragging = false;\n  private clicksDisabled = false;\n  private clickListeners: (() => void)[] = [];\n  private dragStarted = false;\n  private mouseDownTime = 0;\n\n  constructor(private renderer: Renderer2) {}\n\n  private calculateRightBleedContainer = () => {\n    if (this.rightBleedContainer) {\n      const el = this.rightBleedContainer.nativeElement;\n      const left = el.getBoundingClientRect().left;\n\n      let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n      scrollbarWidth = scrollbarWidth == 0 || scrollbarWidth > 30 ? 0 : scrollbarWidth;     \n      \n      el.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);\n      el.style.setProperty('--left-offset', `${left}px`);\n    }\n  };\n\n  ngAfterContentInit() {\n    setTimeout(() => {\n      this.calculateDimensions();\n      this.setItemWidths();\n      this.updateLimits();\n      this.setupClickPrevention();\n\n      this.items.changes.subscribe(() => {\n        this.calculateDimensions();\n        this.setItemWidths();\n        this.updateLimits();\n        this.goToFirstItem();\n        this.setupClickPrevention();\n        // Força atualização visual dos dots\n        if ((this as any).cd && typeof (this as any).cd.detectChanges === 'function') {\n          (this as any).cd.detectChanges();\n        }\n      });\n    }, 10);\n\n    window.addEventListener('resize', () => this.onResize());\n  }\n\n  ngOnDestroy() {\n    // Clean up click listeners\n    this.clickListeners.forEach(unlisten => unlisten());\n    this.clickListeners = [];\n    window.removeEventListener('resize', () => this.onResize());\n  }\n\n  private calculateDimensions() {\n    if (this.slidesContainer) {\n      this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;\n    }\n  }\n\n  private updateLimits() {\n    const totalWidth = this.items.length * (this.itemWidth + this.gap);\n    this.maxTranslateX = 0;\n    \n    if (totalWidth > this.containerWidth) {\n      this.minTranslateX = this.containerWidth - totalWidth;\n    } else {\n      this.minTranslateX = 0;\n    }\n  }\n\n  private onResize() {\n    this.calculateRightBleedContainer();\n    this.calculateDimensions();\n    this.updateLimits();\n\n    // Garante que o currentIndex não ultrapasse o novo máximo\n    const maxIndex = this.getMaxIndex();\n    if (this.currentIndex > maxIndex) {\n      this.currentIndex = maxIndex;\n    }\n\n    this.updateTransform();\n    \n    // Força detecção de mudanças para atualizar dots\n    if ((window as any).ng && (window as any).ng.getInjector) {\n      // Angular DevTools presente, não faz nada\n    } else if ((this as any).cd && typeof (this as any).cd.detectChanges === 'function') {\n      (this as any).cd.detectChanges();\n    }\n  }\n\n  ngAfterViewInit() {\n    // Garante cálculo correto após view carregada\n    setTimeout(() => {\n      this.calculateRightBleedContainer();\n      this.calculateDimensions();\n      this.updateLimits();\n      this.updateTransform();\n    });\n  }\n\n  private setItemWidths() {\n    this.items.forEach((item) => {\n      this.renderer.setStyle(item.nativeElement, 'width', `${this.itemWidth}px`);\n      this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');\n      this.renderer.setStyle(item.nativeElement, 'margin-right', `${this.gap}px`);\n    });\n  }\n\n  // Mouse events\n  onMouseDown(event: MouseEvent) {\n    event.preventDefault();\n    this.mouseDownTime = Date.now();\n    this.dragStarted = false;\n    this.isMouseDown = true;\n    this.wasDragging = false;\n    this.clicksDisabled = false;\n    this.startX = event.clientX;\n    this.currentX = event.clientX;\n    this.initialTranslateX = this.translateX;\n    this.dragOffset = 0;\n    this.velocity = 0;\n    this.lastMoveTime = Date.now();\n    this.lastMoveX = event.clientX;\n    \n    this.calculateDimensions();\n    \n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');\n  }\n\n  onMouseMove(event: MouseEvent) {\n    if (!this.isMouseDown) return;\n    \n    event.preventDefault();\n    \n    const dragDistance = Math.abs(event.clientX - this.startX);\n    \n    // Only start dragging if moved more than 5px\n    if (dragDistance > 5 && !this.isDragging) {\n      this.isDragging = true;\n      this.dragStarted = true;\n      this.wasDragging = true;\n    }\n    \n    if (this.isDragging) {\n      this.updateDrag(event.clientX);\n    }\n  }\n\n  onMouseUp(event: MouseEvent) {\n    if (!this.isMouseDown) return;\n    \n    this.isMouseDown = false;\n    \n    if (this.isDragging) {\n      const mouseUpTime = Date.now();\n      const holdDuration = mouseUpTime - this.mouseDownTime;\n      const mouseDistance = Math.abs(this.currentX - this.startX);\n      \n      if (mouseDistance > 5 || (holdDuration > 200 && mouseDistance > 0)) {\n        this.wasDragging = true;\n      }\n      \n      this.endDrag();\n    } else {\n      // Reset transition if it was just a click\n      this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');\n    }\n  }\n\n  onMouseLeave(event: MouseEvent) {\n    if (this.isDragging) {\n      this.wasDragging = true;\n      this.endDrag();\n    }\n    this.isMouseDown = false;\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.isMouseDown = true;\n    this.wasDragging = false;\n    this.dragStarted = false;\n    this.clicksDisabled = false;\n    this.startX = event.touches[0].clientX;\n    this.currentX = event.touches[0].clientX;\n    this.initialTranslateX = this.translateX;\n    this.dragOffset = 0;\n    this.velocity = 0;\n    this.lastMoveTime = Date.now();\n    this.lastMoveX = event.touches[0].clientX;\n    \n    this.calculateDimensions();\n    \n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');\n  }\n\n  onTouchMove(event: TouchEvent) {\n    if (!this.isMouseDown) 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.isMouseDown = false;\n      this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');\n      return;\n    }\n    \n    // Start dragging if horizontal movement > 10px\n    if (deltaX > 10 && !this.isDragging) {\n      this.isDragging = true;\n      this.dragStarted = true;\n      this.wasDragging = true;\n    }\n    \n    if (this.isDragging && deltaX > 10) {\n      event.preventDefault();\n      this.updateDrag(currentX);\n    }\n  }\n\n  onTouchEnd(event: TouchEvent) {\n    if (this.isVerticalScroll) {\n      this.isVerticalScroll = false;\n      this.isMouseDown = false;\n      return;\n    }\n    \n    this.isMouseDown = false;\n    \n    const touchDuration = Date.now() - this.touchStartTime;\n    const touchDistance = Math.abs(this.currentX - this.startX);\n    \n    // Mark as dragging if significant movement occurred\n    if (touchDistance > 10 || touchDuration > 300) {\n      this.wasDragging = true;\n    }\n    \n    if (this.isDragging) {\n      this.endDrag();\n    } else {\n      // Reset transition if it was just a tap\n      this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');\n    }\n  }\n\n  private setupClickPrevention() {\n    // Clean up existing listeners\n    this.clickListeners.forEach(unlisten => unlisten());\n    this.clickListeners = [];\n\n    this.items.forEach((item) => {\n      // Only prevent click events, not mouseup which is needed for drag functionality\n      const eventHandler = (event: Event) => {\n        if (event.type === 'click' && (this.wasDragging || this.clicksDisabled || this.dragStarted)) {\n          event.preventDefault();\n          event.stopPropagation();\n          event.stopImmediatePropagation();\n          return false;\n        }\n        return true;\n      };\n\n      // Only listen to click events to avoid interfering with drag functionality\n      item.nativeElement.addEventListener('click', eventHandler, true);\n      \n      this.clickListeners.push(() => {\n        item.nativeElement.removeEventListener('click', eventHandler, true);\n      });\n    });\n  }\n\n  private updateDrag(clientX: number) {\n    if (!this.isDragging) return;\n\n    this.currentX = clientX;\n    const totalDeltaX = this.currentX - this.startX;\n    \n    // Mark as dragging if movement is significant\n    if (Math.abs(totalDeltaX) > 5) {\n      this.wasDragging = true;\n      this.dragStarted = true;\n    }\n    \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    let resistedDeltaX = totalDeltaX;\n    const potentialTranslateX = this.initialTranslateX + totalDeltaX;\n    \n    // Apply softer resistance at boundaries\n    if (potentialTranslateX > this.maxTranslateX) {\n      const overDrag = potentialTranslateX - this.maxTranslateX;\n      resistedDeltaX = totalDeltaX - (overDrag * 0.5);\n    } else if (potentialTranslateX < this.minTranslateX) {\n      const overDrag = this.minTranslateX - potentialTranslateX;\n      resistedDeltaX = totalDeltaX + (overDrag * 0.5);\n    }\n\n    this.dragOffset = resistedDeltaX;\n    this.updateDragPosition();\n  }\n\n  private updateDragPosition() {\n    const newTranslateX = this.initialTranslateX + this.dragOffset;\n    this.renderer.setStyle(\n      this.slidesContainer.nativeElement, \n      'transform', \n      `translateX(${newTranslateX}px)`\n    );\n  }\n\n  private endDrag() {\n    if (!this.isDragging) return;\n\n    this.isDragging = false;\n    \n    // Disable clicks temporarily after any drag\n    if (this.wasDragging || this.dragStarted) {\n      this.clicksDisabled = true;\n      setTimeout(() => {\n        this.clicksDisabled = false;\n      }, 200);\n    }\n    \n    // Clear the wasDragging and dragStarted flags after a shorter delay\n    setTimeout(() => {\n      this.wasDragging = false;\n      this.dragStarted = false;\n    }, 250);\n    \n    this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');\n\n    // Snap sempre para o início da página mais próxima\n    this.snapToNearestItem();\n\n    this.dragOffset = 0;\n    this.velocity = 0;\n  }\n\n  private getMaxIndex(): number {\n    // Permite avançar até que o último item esteja visível (não necessariamente alinhado à esquerda)\n    if (!this.items || this.items.length === 0) return 0;\n    const visibleCount = Math.max(1, Math.floor(this.containerWidth / (this.itemWidth + this.gap)));\n    if (this.items.length <= visibleCount) return 0;\n    // Última posição onde o último item aparece visível\n    return this.items.length - visibleCount;\n  }\n\n  canGoNext(): boolean {\n    return this.currentIndex < this.getMaxIndex();\n  }\n\n  nextItem() {\n    const maxIndex = this.getMaxIndex();\n    if (this.canGoNext()) {\n      let newIndex = this.currentIndex + 1;\n      if (newIndex > maxIndex) newIndex = maxIndex;\n      this.currentIndex = newIndex;\n      this.updateTransform();\n      this.nextClickEventEmitter.emit();\n    }\n  }\n\n  canGoPrevious(): boolean {\n    return this.currentIndex > 0;\n  }\n\n  prevItem() {\n    if (this.canGoPrevious()) {\n      let newIndex = this.currentIndex - 1;\n      if (newIndex < 0) newIndex = 0;\n      this.currentIndex = newIndex;\n      this.updateTransform();\n      this.previousClickEventEmitter.emit();\n    }\n  }\n\n  goToDot(dotIndex: number) {\n    const maxIndex = this.getMaxIndex();\n    let newIndex = dotIndex;\n    if (newIndex > maxIndex) newIndex = maxIndex;\n    this.currentIndex = newIndex;\n    this.updateTransform();\n  }\n\n  private snapToNearestItem() {\n    const itemStep = this.itemWidth + this.gap;\n    const position = -(this.initialTranslateX + this.dragOffset) / itemStep;\n    \n    // Threshold: 0.3 = 30%, 0.5 = 50% (padrão)\n    const threshold = 0.3;\n    \n    let targetIndex: number;\n    \n    // Calcula quantos itens completos foram arrastados\n    const itemsMoved = Math.floor(Math.abs(position - this.currentIndex));\n    const decimal = Math.abs(position - this.currentIndex) - itemsMoved;\n    \n    if (position > this.currentIndex) {\n      // Arrastando para frente\n      if (decimal >= threshold) {\n        targetIndex = this.currentIndex + itemsMoved + 1;\n      } else {\n        targetIndex = this.currentIndex + itemsMoved;\n      }\n    } else if (position < this.currentIndex) {\n      // Arrastando para trás\n      if (decimal >= threshold) {\n        targetIndex = this.currentIndex - itemsMoved - 1;\n      } else {\n        targetIndex = this.currentIndex - itemsMoved;\n      }\n    } else {\n      // Não se moveu\n      targetIndex = this.currentIndex;\n    }\n    \n    const maxIndex = this.getMaxIndex();\n    targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));\n    this.currentIndex = targetIndex;\n    this.updateTransform();\n  }\n\n  getDotsArray(): any[] {\n    // Só mostra dots para cada posição possível (cada \"página\" possível)\n    const maxIndex = this.getMaxIndex();\n    return Array(maxIndex + 1);\n  }\n\n  getCurrentDotIndex(): number {\n    return this.currentIndex;\n  }\n\n  private updateTransform() {\n    const itemStep = this.itemWidth + this.gap;\n    this.translateX = -this.currentIndex * itemStep;\n\n    // Clamp para não mostrar espaço vazio à direita\n    const visibleCount = Math.max(1, Math.floor(this.containerWidth / itemStep));\n    // Inclui o gap após o último item\n    const totalWidth = this.items.length * itemStep;\n    if (this.items.length > visibleCount) {\n      const minTranslateX = this.containerWidth - totalWidth;\n      this.translateX = Math.max(this.translateX, minTranslateX);\n    } else {\n      this.translateX = 0;\n    }\n\n    if (!this.isDragging && this.slidesContainer) {\n      this.renderer.setStyle(\n        this.slidesContainer.nativeElement,\n        'transform',\n        `translateX(${this.translateX}px)`\n      );\n    }\n  }\n\n  // Adicione este método para evitar erro de propriedade ausente\n  goToFirstItem() {\n    this.currentIndex = 0;\n    this.updateTransform();\n  }\n}\n","<div class=\"c-carousel-fixed-container\" #rightBleedContainer>\n  <div \n  class=\"c-carousel-fixed-slides\" \n  #slidesContainer\n  [style.transform]=\"'translateX(' + translateX + 'px)'\" \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</div>\n<div class=\"c-carousel-fixed-footer\" *ngIf=\"showArrows || showDots\">\n    <button *ngIf=\"showArrows\"\n      class=\"c-carousel-fixed-nav prev\" \n      [disabled]=\"!canGoPrevious()\"\n      title=\"Item anterior\" \n      aria-label=\"Item anterior\" \n      (click)=\"prevItem()\">\n      <lib-elux-icon [icon]=\"'Chevron_Left.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n\n    <div class=\"c-carousel-fixed-dots\" *ngIf=\"showDots\">\n      <ng-container *ngFor=\"let dot of getDotsArray(); let idx = index\">\n        <span \n          class=\"c-carousel-fixed-dot\" \n          [class.active]=\"idx === getCurrentDotIndex()\" \n          (click)=\"goToDot(idx)\">\n        </span>\n      </ng-container>\n    </div>\n\n    <button *ngIf=\"showArrows\"\n      class=\"c-carousel-fixed-nav next\" \n      [disabled]=\"!canGoNext()\"\n      title=\"Próximo item\" \n      aria-label=\"Próximo item\" \n      (click)=\"nextItem()\">\n      <lib-elux-icon [icon]=\"'Chevron_Right.svg'\" [size]=\"'16'\" [sizeType]=\"'px'\" [color]=\"'#020F2E'\"></lib-elux-icon>\n    </button>\n</div>\n"]}