@elxjs/ui 0.0.200 → 0.0.202

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.
@@ -0,0 +1,536 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
+ import { EluxIcon } from '../icon';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ export class EluxCarouselBleedComponent {
7
+ constructor(renderer) {
8
+ this.renderer = renderer;
9
+ this.itemWidth = 200;
10
+ this.gap = 16;
11
+ this.title = '';
12
+ this.previousClickEventEmitter = new EventEmitter();
13
+ this.nextClickEventEmitter = new EventEmitter();
14
+ this.dotClickEventEmitter = new EventEmitter();
15
+ this.currentIndex = 0;
16
+ this.translateX = 0;
17
+ this.isDragging = false;
18
+ this.isMouseDown = false;
19
+ this.startX = 0;
20
+ this.currentX = 0;
21
+ this.initialTranslateX = 0;
22
+ this.dragOffset = 0;
23
+ this.containerWidth = 0;
24
+ this.maxTranslateX = 0;
25
+ this.minTranslateX = 0;
26
+ this.velocity = 0;
27
+ this.lastMoveTime = 0;
28
+ this.lastMoveX = 0;
29
+ this.touchStartTime = 0;
30
+ this.touchStartX = 0;
31
+ this.touchStartY = 0;
32
+ this.isVerticalScroll = false;
33
+ this.wasDragging = false;
34
+ this.clicksDisabled = false;
35
+ this.clickListeners = [];
36
+ this.dragStarted = false;
37
+ this.mouseDownTime = 0;
38
+ this.resizeRafId = null;
39
+ this.lastLeftOffset = 0;
40
+ this.lastScrollbarWidth = 0;
41
+ this.calculateBleedOffsets = () => {
42
+ if (!this.bleedShell)
43
+ return;
44
+ const el = this.bleedShell.nativeElement;
45
+ const left = Math.round(el.getBoundingClientRect().left);
46
+ let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;
47
+ scrollbarWidth = scrollbarWidth == 0 || scrollbarWidth > 30 ? 0 : scrollbarWidth;
48
+ if (left !== this.lastLeftOffset) {
49
+ el.style.setProperty('--left-offset', `${left}px`);
50
+ this.lastLeftOffset = left;
51
+ }
52
+ if (scrollbarWidth !== this.lastScrollbarWidth) {
53
+ el.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);
54
+ this.lastScrollbarWidth = scrollbarWidth;
55
+ }
56
+ };
57
+ this.scheduleResize = () => {
58
+ if (this.resizeRafId !== null) {
59
+ cancelAnimationFrame(this.resizeRafId);
60
+ }
61
+ this.resizeRafId = requestAnimationFrame(() => {
62
+ this.resizeRafId = null;
63
+ this.onResize();
64
+ });
65
+ };
66
+ }
67
+ ngAfterContentInit() {
68
+ setTimeout(() => {
69
+ this.calculateDimensions();
70
+ this.setItemWidths();
71
+ this.updateLimits();
72
+ this.setupClickPrevention();
73
+ this.items.changes.subscribe(() => {
74
+ this.calculateDimensions();
75
+ this.setItemWidths();
76
+ this.updateLimits();
77
+ this.goToFirstItem();
78
+ this.setupClickPrevention();
79
+ // Força atualização visual dos dots
80
+ if (this.cd && typeof this.cd.detectChanges === 'function') {
81
+ this.cd.detectChanges();
82
+ }
83
+ });
84
+ }, 10);
85
+ window.addEventListener('resize', this.scheduleResize);
86
+ }
87
+ ngOnDestroy() {
88
+ // Clean up click listeners
89
+ this.clickListeners.forEach(unlisten => unlisten());
90
+ this.clickListeners = [];
91
+ window.removeEventListener('resize', this.scheduleResize);
92
+ if (this.resizeRafId !== null) {
93
+ cancelAnimationFrame(this.resizeRafId);
94
+ this.resizeRafId = null;
95
+ }
96
+ }
97
+ calculateDimensions() {
98
+ if (this.bleedShell?.nativeElement) {
99
+ this.containerWidth = this.bleedShell.nativeElement.offsetWidth;
100
+ return;
101
+ }
102
+ if (this.slidesContainer) {
103
+ this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;
104
+ }
105
+ }
106
+ updateLimits() {
107
+ const totalWidth = this.getTotalWidth();
108
+ this.maxTranslateX = 0;
109
+ if (totalWidth > this.containerWidth) {
110
+ this.minTranslateX = this.containerWidth - totalWidth;
111
+ }
112
+ else {
113
+ this.minTranslateX = 0;
114
+ }
115
+ }
116
+ onResize() {
117
+ this.calculateBleedOffsets();
118
+ this.calculateDimensions();
119
+ this.updateLimits();
120
+ // Garante que o currentIndex não ultrapasse o novo máximo
121
+ const maxIndex = this.getMaxIndex();
122
+ if (this.currentIndex > maxIndex) {
123
+ this.currentIndex = maxIndex;
124
+ }
125
+ this.updateTransform();
126
+ // Força detecção de mudanças para atualizar dots
127
+ if (window.ng && window.ng.getInjector) {
128
+ // Angular DevTools presente, não faz nada
129
+ }
130
+ else if (this.cd && typeof this.cd.detectChanges === 'function') {
131
+ this.cd.detectChanges();
132
+ }
133
+ }
134
+ ngAfterViewInit() {
135
+ // Garante cálculo correto após view carregada
136
+ setTimeout(() => {
137
+ this.calculateBleedOffsets();
138
+ this.calculateDimensions();
139
+ this.updateLimits();
140
+ this.updateTransform();
141
+ });
142
+ }
143
+ setItemWidths() {
144
+ const lastIndex = this.items.length - 1;
145
+ this.items.forEach((item, index) => {
146
+ this.renderer.addClass(item.nativeElement, 'c-carousel-fixed-item');
147
+ this.renderer.setStyle(item.nativeElement, 'width', `${this.itemWidth}px`);
148
+ this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');
149
+ this.renderer.setStyle(item.nativeElement, 'margin-right', index === lastIndex ? '0px' : `${this.gap}px`);
150
+ });
151
+ }
152
+ isDragStartAllowed(target) {
153
+ if (!target)
154
+ return false;
155
+ const element = target;
156
+ if (element === this.slidesContainer?.nativeElement)
157
+ return false;
158
+ return !!element.closest('.c-carousel-fixed-item');
159
+ }
160
+ // Mouse events
161
+ onMouseDown(event) {
162
+ if (!this.isDragStartAllowed(event.target))
163
+ return;
164
+ event.preventDefault();
165
+ this.mouseDownTime = Date.now();
166
+ this.dragStarted = false;
167
+ this.isMouseDown = true;
168
+ this.wasDragging = false;
169
+ this.clicksDisabled = false;
170
+ this.startX = event.clientX;
171
+ this.currentX = event.clientX;
172
+ this.initialTranslateX = this.translateX;
173
+ this.dragOffset = 0;
174
+ this.velocity = 0;
175
+ this.lastMoveTime = Date.now();
176
+ this.lastMoveX = event.clientX;
177
+ this.calculateDimensions();
178
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
179
+ }
180
+ onMouseMove(event) {
181
+ if (!this.isMouseDown)
182
+ return;
183
+ event.preventDefault();
184
+ const dragDistance = Math.abs(event.clientX - this.startX);
185
+ // Only start dragging if moved more than 5px
186
+ if (dragDistance > 5 && !this.isDragging) {
187
+ this.isDragging = true;
188
+ this.dragStarted = true;
189
+ this.wasDragging = true;
190
+ }
191
+ if (this.isDragging) {
192
+ this.updateDrag(event.clientX);
193
+ }
194
+ }
195
+ onMouseUp(event) {
196
+ if (!this.isMouseDown)
197
+ return;
198
+ this.isMouseDown = false;
199
+ if (this.isDragging) {
200
+ const mouseUpTime = Date.now();
201
+ const holdDuration = mouseUpTime - this.mouseDownTime;
202
+ const mouseDistance = Math.abs(this.currentX - this.startX);
203
+ if (mouseDistance > 5 || (holdDuration > 200 && mouseDistance > 0)) {
204
+ this.wasDragging = true;
205
+ }
206
+ this.endDrag();
207
+ }
208
+ else {
209
+ // Reset transition if it was just a click
210
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
211
+ }
212
+ }
213
+ onMouseLeave(event) {
214
+ if (this.isDragging) {
215
+ this.wasDragging = true;
216
+ this.endDrag();
217
+ }
218
+ this.isMouseDown = false;
219
+ }
220
+ // Touch events
221
+ onTouchStart(event) {
222
+ if (!this.isDragStartAllowed(event.target))
223
+ return;
224
+ this.touchStartTime = Date.now();
225
+ this.touchStartX = event.touches[0].clientX;
226
+ this.touchStartY = event.touches[0].clientY;
227
+ this.isVerticalScroll = false;
228
+ this.isMouseDown = true;
229
+ this.wasDragging = false;
230
+ this.dragStarted = false;
231
+ this.clicksDisabled = false;
232
+ this.startX = event.touches[0].clientX;
233
+ this.currentX = event.touches[0].clientX;
234
+ this.initialTranslateX = this.translateX;
235
+ this.dragOffset = 0;
236
+ this.velocity = 0;
237
+ this.lastMoveTime = Date.now();
238
+ this.lastMoveX = event.touches[0].clientX;
239
+ this.calculateDimensions();
240
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
241
+ }
242
+ onTouchMove(event) {
243
+ if (!this.isMouseDown)
244
+ return;
245
+ const currentX = event.touches[0].clientX;
246
+ const currentY = event.touches[0].clientY;
247
+ const deltaX = Math.abs(currentX - this.touchStartX);
248
+ const deltaY = Math.abs(currentY - this.touchStartY);
249
+ // Check if this is a vertical scroll
250
+ if (deltaY > deltaX && deltaY > 10) {
251
+ this.isVerticalScroll = true;
252
+ this.isDragging = false;
253
+ this.isMouseDown = false;
254
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
255
+ return;
256
+ }
257
+ // Start dragging if horizontal movement > 10px
258
+ if (deltaX > 10 && !this.isDragging) {
259
+ this.isDragging = true;
260
+ this.dragStarted = true;
261
+ this.wasDragging = true;
262
+ }
263
+ if (this.isDragging && deltaX > 10) {
264
+ event.preventDefault();
265
+ this.updateDrag(currentX);
266
+ }
267
+ }
268
+ onTouchEnd(event) {
269
+ if (this.isVerticalScroll) {
270
+ this.isVerticalScroll = false;
271
+ this.isMouseDown = false;
272
+ return;
273
+ }
274
+ this.isMouseDown = false;
275
+ const touchDuration = Date.now() - this.touchStartTime;
276
+ const touchDistance = Math.abs(this.currentX - this.startX);
277
+ // Mark as dragging if significant movement occurred
278
+ if (touchDistance > 10 || touchDuration > 300) {
279
+ this.wasDragging = true;
280
+ }
281
+ if (this.isDragging) {
282
+ this.endDrag();
283
+ }
284
+ else {
285
+ // Reset transition if it was just a tap
286
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
287
+ }
288
+ }
289
+ setupClickPrevention() {
290
+ // Clean up existing listeners
291
+ this.clickListeners.forEach(unlisten => unlisten());
292
+ this.clickListeners = [];
293
+ this.items.forEach((item) => {
294
+ // Only prevent click events, not mouseup which is needed for drag functionality
295
+ const eventHandler = (event) => {
296
+ if (event.type === 'click' && (this.wasDragging || this.clicksDisabled || this.dragStarted)) {
297
+ event.preventDefault();
298
+ event.stopPropagation();
299
+ event.stopImmediatePropagation();
300
+ return false;
301
+ }
302
+ return true;
303
+ };
304
+ // Only listen to click events to avoid interfering with drag functionality
305
+ item.nativeElement.addEventListener('click', eventHandler, true);
306
+ this.clickListeners.push(() => {
307
+ item.nativeElement.removeEventListener('click', eventHandler, true);
308
+ });
309
+ });
310
+ }
311
+ updateDrag(clientX) {
312
+ if (!this.isDragging)
313
+ return;
314
+ this.currentX = clientX;
315
+ const totalDeltaX = this.currentX - this.startX;
316
+ // Mark as dragging if movement is significant
317
+ if (Math.abs(totalDeltaX) > 5) {
318
+ this.wasDragging = true;
319
+ this.dragStarted = true;
320
+ }
321
+ const now = Date.now();
322
+ const timeDelta = now - this.lastMoveTime;
323
+ if (timeDelta > 0) {
324
+ this.velocity = (clientX - this.lastMoveX) / timeDelta;
325
+ }
326
+ this.lastMoveTime = now;
327
+ this.lastMoveX = clientX;
328
+ let resistedDeltaX = totalDeltaX;
329
+ const potentialTranslateX = this.initialTranslateX + totalDeltaX;
330
+ // Apply softer resistance at boundaries
331
+ if (potentialTranslateX > this.maxTranslateX) {
332
+ const overDrag = potentialTranslateX - this.maxTranslateX;
333
+ resistedDeltaX = totalDeltaX - (overDrag * 0.5);
334
+ }
335
+ else if (potentialTranslateX < this.minTranslateX) {
336
+ const overDrag = this.minTranslateX - potentialTranslateX;
337
+ resistedDeltaX = totalDeltaX + (overDrag * 0.5);
338
+ }
339
+ this.dragOffset = resistedDeltaX;
340
+ this.updateDragPosition();
341
+ }
342
+ updateDragPosition() {
343
+ const newTranslateX = this.initialTranslateX + this.dragOffset;
344
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transform', `translateX(${newTranslateX}px)`);
345
+ }
346
+ endDrag() {
347
+ if (!this.isDragging)
348
+ return;
349
+ this.isDragging = false;
350
+ // Disable clicks temporarily after any drag
351
+ if (this.wasDragging || this.dragStarted) {
352
+ this.clicksDisabled = true;
353
+ setTimeout(() => {
354
+ this.clicksDisabled = false;
355
+ }, 200);
356
+ }
357
+ // Clear the wasDragging and dragStarted flags after a shorter delay
358
+ setTimeout(() => {
359
+ this.wasDragging = false;
360
+ this.dragStarted = false;
361
+ }, 250);
362
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
363
+ // Snap sempre para o início da página mais próxima
364
+ this.snapToNearestItem();
365
+ this.dragOffset = 0;
366
+ this.velocity = 0;
367
+ }
368
+ getMaxIndex() {
369
+ // Permite avançar até que o último item esteja alinhado ao lado direito do shell
370
+ if (!this.items || this.items.length === 0)
371
+ return 0;
372
+ const itemStep = this.itemWidth + this.gap;
373
+ const totalWidth = this.getTotalWidth();
374
+ const overflow = totalWidth - this.containerWidth;
375
+ if (overflow <= 0)
376
+ return 0;
377
+ return Math.ceil(overflow / itemStep);
378
+ }
379
+ canGoNext() {
380
+ return this.currentIndex < this.getMaxIndex();
381
+ }
382
+ getPageStep() {
383
+ const step = Math.max(1, Math.floor((this.containerWidth + this.gap) / (this.itemWidth + this.gap)));
384
+ return step;
385
+ }
386
+ getVisibleCount() {
387
+ return Math.max(1, Math.floor((this.containerWidth + this.gap) / (this.itemWidth + this.gap)));
388
+ }
389
+ getPageCount() {
390
+ const maxIndex = this.getMaxIndex();
391
+ if (maxIndex === 0)
392
+ return 1;
393
+ const pageStep = this.getPageStep();
394
+ return 1 + Math.ceil(maxIndex / pageStep);
395
+ }
396
+ getPageStart(dotIndex) {
397
+ const maxIndex = this.getMaxIndex();
398
+ const pageStep = this.getPageStep();
399
+ return Math.min(dotIndex * pageStep, maxIndex);
400
+ }
401
+ nextPage() {
402
+ if (this.canGoNext()) {
403
+ const pageCount = this.getPageCount();
404
+ const currentDot = this.getCurrentDotIndex();
405
+ const targetDot = Math.min(currentDot + 1, pageCount - 1);
406
+ this.currentIndex = this.getPageStart(targetDot);
407
+ this.updateTransform();
408
+ this.nextClickEventEmitter.emit();
409
+ }
410
+ }
411
+ canGoPrevious() {
412
+ return this.currentIndex > 0;
413
+ }
414
+ prevPage() {
415
+ if (this.canGoPrevious()) {
416
+ const currentDot = this.getCurrentDotIndex();
417
+ const targetDot = Math.max(currentDot - 1, 0);
418
+ this.currentIndex = this.getPageStart(targetDot);
419
+ this.updateTransform();
420
+ this.previousClickEventEmitter.emit();
421
+ }
422
+ }
423
+ goToDot(dotIndex) {
424
+ const maxIndex = this.getMaxIndex();
425
+ let newIndex = this.getPageStart(dotIndex);
426
+ if (newIndex > maxIndex)
427
+ newIndex = maxIndex;
428
+ this.currentIndex = newIndex;
429
+ this.updateTransform();
430
+ this.dotClickEventEmitter.emit();
431
+ }
432
+ snapToNearestItem() {
433
+ const itemStep = this.itemWidth + this.gap;
434
+ const position = -(this.initialTranslateX + this.dragOffset) / itemStep;
435
+ // Threshold: 0.3 = 30%, 0.5 = 50% (padrão)
436
+ const threshold = 0.3;
437
+ let targetIndex;
438
+ // Calcula quantos itens completos foram arrastados
439
+ const itemsMoved = Math.floor(Math.abs(position - this.currentIndex));
440
+ const decimal = Math.abs(position - this.currentIndex) - itemsMoved;
441
+ if (position > this.currentIndex) {
442
+ // Arrastando para frente
443
+ if (decimal >= threshold) {
444
+ targetIndex = this.currentIndex + itemsMoved + 1;
445
+ }
446
+ else {
447
+ targetIndex = this.currentIndex + itemsMoved;
448
+ }
449
+ }
450
+ else if (position < this.currentIndex) {
451
+ // Arrastando para trás
452
+ if (decimal >= threshold) {
453
+ targetIndex = this.currentIndex - itemsMoved - 1;
454
+ }
455
+ else {
456
+ targetIndex = this.currentIndex - itemsMoved;
457
+ }
458
+ }
459
+ else {
460
+ // Não se moveu
461
+ targetIndex = this.currentIndex;
462
+ }
463
+ const maxIndex = this.getMaxIndex();
464
+ targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));
465
+ this.currentIndex = targetIndex;
466
+ this.updateTransform();
467
+ }
468
+ getDotsArray() {
469
+ return Array(this.getPageCount());
470
+ }
471
+ getCurrentDotIndex() {
472
+ const pageCount = this.getPageCount();
473
+ for (let i = pageCount - 1; i >= 0; i -= 1) {
474
+ if (this.currentIndex >= this.getPageStart(i)) {
475
+ return i;
476
+ }
477
+ }
478
+ return 0;
479
+ }
480
+ updateTransform() {
481
+ const itemStep = this.itemWidth + this.gap;
482
+ this.translateX = -this.currentIndex * itemStep;
483
+ // Clamp para não mostrar espaço vazio à direita
484
+ const visibleCount = Math.max(1, Math.floor(this.containerWidth / itemStep));
485
+ // Inclui o gap após o último item
486
+ const totalWidth = this.getTotalWidth();
487
+ if (this.items.length > visibleCount) {
488
+ const minTranslateX = this.containerWidth - totalWidth;
489
+ this.translateX = Math.max(this.translateX, minTranslateX);
490
+ }
491
+ else {
492
+ this.translateX = 0;
493
+ }
494
+ if (!this.isDragging && this.slidesContainer) {
495
+ this.renderer.setStyle(this.slidesContainer.nativeElement, 'transform', `translateX(${this.translateX}px)`);
496
+ }
497
+ }
498
+ getTotalWidth() {
499
+ if (!this.items || this.items.length === 0)
500
+ return 0;
501
+ return this.items.length * this.itemWidth + (this.items.length - 1) * this.gap;
502
+ }
503
+ // Adicione este método para evitar erro de propriedade ausente
504
+ goToFirstItem() {
505
+ this.currentIndex = 0;
506
+ this.updateTransform();
507
+ }
508
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: EluxCarouselBleedComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
509
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: EluxCarouselBleedComponent, isStandalone: true, selector: "lib-elux-carousel-bleed", inputs: { itemWidth: "itemWidth", gap: "gap", title: "title" }, outputs: { previousClickEventEmitter: "previousClickEventEmitter", nextClickEventEmitter: "nextClickEventEmitter", dotClickEventEmitter: "dotClickEventEmitter" }, queries: [{ propertyName: "items", predicate: ["carouselItem"], read: ElementRef }], viewQueries: [{ propertyName: "slidesContainer", first: true, predicate: ["slidesContainer"], descendants: true }, { propertyName: "bleedShell", first: true, predicate: ["bleedShell"], descendants: true }], ngImport: i0, template: "<div class=\"c-carousel-fixed-shell\" #bleedShell>\n <div *ngIf=\"title\" class=\"c-carousel-fixed-header\">\n <div class=\"c-carousel-fixed-header-inner\">\n <div class=\"c-carousel-fixed-title\">\n {{ title }}\n </div>\n <div class=\"c-carousel-fixed-controls\">\n <button\n class=\"c-carousel-fixed-nav prev\"\n [disabled]=\"!canGoPrevious()\"\n title=\"P\u00E1gina anterior\"\n aria-label=\"P\u00E1gina anterior\"\n (click)=\"prevPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Left.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n\n <button\n class=\"c-carousel-fixed-nav next\"\n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3xima p\u00E1gina\"\n aria-label=\"Pr\u00F3xima p\u00E1gina\"\n (click)=\"nextPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Right.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n </div>\n </div>\n </div>\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 >\n <ng-content></ng-content>\n </div>\n </div>\n\n <div class=\"c-carousel-fixed-footer\" *ngIf=\"getDotsArray().length > 1\">\n <div class=\"c-carousel-fixed-controls\">\n <button\n *ngIf=\"title == ''\"\n class=\"c-carousel-fixed-nav prev\"\n [disabled]=\"!canGoPrevious()\"\n title=\"P\u00E1gina anterior\"\n aria-label=\"P\u00E1gina anterior\"\n (click)=\"prevPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Left.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n\n <div class=\"c-carousel-fixed-dots\">\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 >\n </span>\n </ng-container>\n </div>\n\n <button\n *ngIf=\"title == ''\"\n class=\"c-carousel-fixed-nav next\"\n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3xima p\u00E1gina\"\n aria-label=\"Pr\u00F3xima p\u00E1gina\"\n (click)=\"nextPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Right.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n </div>\n </div>\n</div>\n", styles: [".c-carousel-fixed-shell{position:relative}.c-carousel-fixed-controls{display:flex;align-items:center;gap:12px}.c-carousel-fixed-nav{background:none;border:none;cursor:pointer;width:24px;height:24px;padding:0;border-radius:50%;background-color:#e9ebed;transition:all ease-in-out .2s;z-index:2;display:inline-flex;align-items:center;justify-content:center}.c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.2)}.c-carousel-fixed-nav:disabled{opacity:.2;cursor:not-allowed}.c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-nav :host ::ng-deep span{display:block}.c-carousel-fixed-header{margin-bottom:32px}@media (min-width: 992px){.c-carousel-fixed-header{margin-bottom:40px}}.c-carousel-fixed-header .c-carousel-fixed-header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.c-carousel-fixed-header .c-carousel-fixed-header-inner .c-carousel-fixed-title{font-size:20px;font-weight:600;line-height:24px;color:#011e41}@media (min-width: 992px){.c-carousel-fixed-header .c-carousel-fixed-header-inner .c-carousel-fixed-title{font-size:32px;line-height:35px}}.c-carousel-fixed-container{overflow-x:hidden;width:calc(100vw - var(--scrollbar-width, 0px));margin-left:calc(-1 * var(--left-offset, 0px));padding-left:var(--left-offset, 0px)}.c-carousel-fixed-slides{display:flex;transition:transform .5s ease-out;touch-action:pan-y;cursor:default;will-change:transform}:host ::ng-deep .c-carousel-fixed-item{cursor:grab}:host ::ng-deep .c-carousel-fixed-item:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;justify-content:center;margin-top:32px;margin-bottom:32px}@media (min-width: 992px){.c-carousel-fixed-footer{margin-top:40px;margin-bottom:40px}}.c-carousel-fixed-footer .c-carousel-fixed-dots{display:flex;align-items:center;gap:8px;margin:0 8px}.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:#3d5275}\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"] }] }); }
510
+ }
511
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: EluxCarouselBleedComponent, decorators: [{
512
+ type: Component,
513
+ args: [{ standalone: true, selector: 'lib-elux-carousel-bleed', imports: [CommonModule, EluxIcon], template: "<div class=\"c-carousel-fixed-shell\" #bleedShell>\n <div *ngIf=\"title\" class=\"c-carousel-fixed-header\">\n <div class=\"c-carousel-fixed-header-inner\">\n <div class=\"c-carousel-fixed-title\">\n {{ title }}\n </div>\n <div class=\"c-carousel-fixed-controls\">\n <button\n class=\"c-carousel-fixed-nav prev\"\n [disabled]=\"!canGoPrevious()\"\n title=\"P\u00E1gina anterior\"\n aria-label=\"P\u00E1gina anterior\"\n (click)=\"prevPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Left.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n\n <button\n class=\"c-carousel-fixed-nav next\"\n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3xima p\u00E1gina\"\n aria-label=\"Pr\u00F3xima p\u00E1gina\"\n (click)=\"nextPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Right.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n </div>\n </div>\n </div>\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 >\n <ng-content></ng-content>\n </div>\n </div>\n\n <div class=\"c-carousel-fixed-footer\" *ngIf=\"getDotsArray().length > 1\">\n <div class=\"c-carousel-fixed-controls\">\n <button\n *ngIf=\"title == ''\"\n class=\"c-carousel-fixed-nav prev\"\n [disabled]=\"!canGoPrevious()\"\n title=\"P\u00E1gina anterior\"\n aria-label=\"P\u00E1gina anterior\"\n (click)=\"prevPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Left.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n\n <div class=\"c-carousel-fixed-dots\">\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 >\n </span>\n </ng-container>\n </div>\n\n <button\n *ngIf=\"title == ''\"\n class=\"c-carousel-fixed-nav next\"\n [disabled]=\"!canGoNext()\"\n title=\"Pr\u00F3xima p\u00E1gina\"\n aria-label=\"Pr\u00F3xima p\u00E1gina\"\n (click)=\"nextPage()\"\n >\n <lib-elux-icon\n [icon]=\"'Chevron_Right.svg'\"\n [size]=\"'16'\"\n [sizeType]=\"'px'\"\n [color]=\"'#020F2E'\"\n ></lib-elux-icon>\n </button>\n </div>\n </div>\n</div>\n", styles: [".c-carousel-fixed-shell{position:relative}.c-carousel-fixed-controls{display:flex;align-items:center;gap:12px}.c-carousel-fixed-nav{background:none;border:none;cursor:pointer;width:24px;height:24px;padding:0;border-radius:50%;background-color:#e9ebed;transition:all ease-in-out .2s;z-index:2;display:inline-flex;align-items:center;justify-content:center}.c-carousel-fixed-nav:hover:not(:disabled){transform:scale(1.2)}.c-carousel-fixed-nav:disabled{opacity:.2;cursor:not-allowed}.c-carousel-fixed-nav:disabled:hover{transform:none}.c-carousel-fixed-nav :host ::ng-deep span{display:block}.c-carousel-fixed-header{margin-bottom:32px}@media (min-width: 992px){.c-carousel-fixed-header{margin-bottom:40px}}.c-carousel-fixed-header .c-carousel-fixed-header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.c-carousel-fixed-header .c-carousel-fixed-header-inner .c-carousel-fixed-title{font-size:20px;font-weight:600;line-height:24px;color:#011e41}@media (min-width: 992px){.c-carousel-fixed-header .c-carousel-fixed-header-inner .c-carousel-fixed-title{font-size:32px;line-height:35px}}.c-carousel-fixed-container{overflow-x:hidden;width:calc(100vw - var(--scrollbar-width, 0px));margin-left:calc(-1 * var(--left-offset, 0px));padding-left:var(--left-offset, 0px)}.c-carousel-fixed-slides{display:flex;transition:transform .5s ease-out;touch-action:pan-y;cursor:default;will-change:transform}:host ::ng-deep .c-carousel-fixed-item{cursor:grab}:host ::ng-deep .c-carousel-fixed-item:active{cursor:grabbing}.c-carousel-fixed-footer{display:flex;justify-content:center;margin-top:32px;margin-bottom:32px}@media (min-width: 992px){.c-carousel-fixed-footer{margin-top:40px;margin-bottom:40px}}.c-carousel-fixed-footer .c-carousel-fixed-dots{display:flex;align-items:center;gap:8px;margin:0 8px}.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:#3d5275}\n"] }]
514
+ }], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { items: [{
515
+ type: ContentChildren,
516
+ args: ['carouselItem', { read: ElementRef }]
517
+ }], slidesContainer: [{
518
+ type: ViewChild,
519
+ args: ['slidesContainer']
520
+ }], bleedShell: [{
521
+ type: ViewChild,
522
+ args: ['bleedShell', { static: false }]
523
+ }], itemWidth: [{
524
+ type: Input
525
+ }], gap: [{
526
+ type: Input
527
+ }], title: [{
528
+ type: Input
529
+ }], previousClickEventEmitter: [{
530
+ type: Output
531
+ }], nextClickEventEmitter: [{
532
+ type: Output
533
+ }], dotClickEventEmitter: [{
534
+ type: Output
535
+ }] } });
536
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel-bleed.component.js","sourceRoot":"","sources":["../../../../../../../ui/library/src/lib/components/carousel-bleed/carousel-bleed.component.ts","../../../../../../../ui/library/src/lib/components/carousel-bleed/carousel-bleed.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-bleed',\n  templateUrl: './carousel-bleed.component.html',\n  styleUrls: ['./carousel-bleed.component.scss'],\n  imports: [CommonModule, EluxIcon],\n})\nexport class EluxCarouselBleedComponent implements AfterContentInit, OnDestroy {\n  @ContentChildren('carouselItem', { read: ElementRef }) items!: QueryList<ElementRef>;\n  @ViewChild('slidesContainer') slidesContainer!: ElementRef;\n  @ViewChild('bleedShell', { static: false }) bleedShell!: ElementRef<HTMLDivElement>;\n\n  @Input() itemWidth: number = 200;\n  @Input() gap: number = 16;\n  @Input() title: string = '';\n\n  @Output() previousClickEventEmitter = new EventEmitter<Event>();\n  @Output() nextClickEventEmitter = new EventEmitter<Event>();\n  @Output() dotClickEventEmitter = 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  private resizeRafId: number | null = null;\n  private lastLeftOffset = 0;\n  private lastScrollbarWidth = 0;\n\n  constructor(private renderer: Renderer2) {}\n\n  private calculateBleedOffsets = () => {\n    if (!this.bleedShell) return;\n\n    const el = this.bleedShell.nativeElement;\n    const left = Math.round(el.getBoundingClientRect().left);\n\n    let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n    scrollbarWidth = scrollbarWidth == 0 || scrollbarWidth > 30 ? 0 : scrollbarWidth;\n\n    if (left !== this.lastLeftOffset) {\n      el.style.setProperty('--left-offset', `${left}px`);\n      this.lastLeftOffset = left;\n    }\n\n    if (scrollbarWidth !== this.lastScrollbarWidth) {\n      el.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);\n      this.lastScrollbarWidth = scrollbarWidth;\n    }\n  };\n\n  private scheduleResize = () => {\n    if (this.resizeRafId !== null) {\n      cancelAnimationFrame(this.resizeRafId);\n    }\n\n    this.resizeRafId = requestAnimationFrame(() => {\n      this.resizeRafId = null;\n      this.onResize();\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.scheduleResize);\n  }\n\n  ngOnDestroy() {\n    // Clean up click listeners\n    this.clickListeners.forEach(unlisten => unlisten());\n    this.clickListeners = [];\n    window.removeEventListener('resize', this.scheduleResize);\n    if (this.resizeRafId !== null) {\n      cancelAnimationFrame(this.resizeRafId);\n      this.resizeRafId = null;\n    }\n  }\n\n  private calculateDimensions() {\n    if (this.bleedShell?.nativeElement) {\n      this.containerWidth = this.bleedShell.nativeElement.offsetWidth;\n      return;\n    }\n    if (this.slidesContainer) {\n      this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;\n    }\n  }\n\n  private updateLimits() {\n    const totalWidth = this.getTotalWidth();\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.calculateBleedOffsets();\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.calculateBleedOffsets();\n      this.calculateDimensions();\n      this.updateLimits();\n      this.updateTransform();\n    });\n  }\n\n  private setItemWidths() {\n    const lastIndex = this.items.length - 1;\n    this.items.forEach((item, index) => {\n      this.renderer.addClass(item.nativeElement, 'c-carousel-fixed-item');\n      this.renderer.setStyle(item.nativeElement, 'width', `${this.itemWidth}px`);\n      this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');\n      this.renderer.setStyle(\n        item.nativeElement,\n        'margin-right',\n        index === lastIndex ? '0px' : `${this.gap}px`\n      );\n    });\n  }\n\n  private isDragStartAllowed(target: EventTarget | null): boolean {\n    if (!target) return false;\n    const element = target as Element;\n    if (element === this.slidesContainer?.nativeElement) return false;\n    return !!element.closest('.c-carousel-fixed-item');\n  }\n\n  // Mouse events\n  onMouseDown(event: MouseEvent) {\n    if (!this.isDragStartAllowed(event.target)) return;\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    if (!this.isDragStartAllowed(event.target)) return;\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 alinhado ao lado direito do shell\n    if (!this.items || this.items.length === 0) return 0;\n    const itemStep = this.itemWidth + this.gap;\n    const totalWidth = this.getTotalWidth();\n    const overflow = totalWidth - this.containerWidth;\n    if (overflow <= 0) return 0;\n    return Math.ceil(overflow / itemStep);\n  }\n\n  canGoNext(): boolean {\n    return this.currentIndex < this.getMaxIndex();\n  }\n\n  private getPageStep(): number {\n    const step = Math.max(1, Math.floor((this.containerWidth + this.gap) / (this.itemWidth + this.gap)));\n    return step;\n  }\n\n  private getVisibleCount(): number {\n    return Math.max(1, Math.floor((this.containerWidth + this.gap) / (this.itemWidth + this.gap)));\n  }\n\n  private getPageCount(): number {\n    const maxIndex = this.getMaxIndex();\n    if (maxIndex === 0) return 1;\n\n    const pageStep = this.getPageStep();\n    return 1 + Math.ceil(maxIndex / pageStep);\n  }\n\n  private getPageStart(dotIndex: number): number {\n    const maxIndex = this.getMaxIndex();\n    const pageStep = this.getPageStep();\n    return Math.min(dotIndex * pageStep, maxIndex);\n  }\n\n  nextPage() {\n    if (this.canGoNext()) {\n      const pageCount = this.getPageCount();\n      const currentDot = this.getCurrentDotIndex();\n      const targetDot = Math.min(currentDot + 1, pageCount - 1);\n      this.currentIndex = this.getPageStart(targetDot);\n      this.updateTransform();\n      this.nextClickEventEmitter.emit();\n    }\n  }\n\n  canGoPrevious(): boolean {\n    return this.currentIndex > 0;\n  }\n\n  prevPage() {\n    if (this.canGoPrevious()) {\n      const currentDot = this.getCurrentDotIndex();\n      const targetDot = Math.max(currentDot - 1, 0);\n      this.currentIndex = this.getPageStart(targetDot);\n      this.updateTransform();\n      this.previousClickEventEmitter.emit();\n    }\n  }\n\n  goToDot(dotIndex: number) {\n    const maxIndex = this.getMaxIndex();\n    let newIndex = this.getPageStart(dotIndex);\n    if (newIndex > maxIndex) newIndex = maxIndex;\n    this.currentIndex = newIndex;\n    this.updateTransform();\n    this.dotClickEventEmitter.emit();\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    return Array(this.getPageCount());\n  }\n\n  getCurrentDotIndex(): number {\n    const pageCount = this.getPageCount();\n    for (let i = pageCount - 1; i >= 0; i -= 1) {\n      if (this.currentIndex >= this.getPageStart(i)) {\n        return i;\n      }\n    }\n    return 0;\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.getTotalWidth();\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  private getTotalWidth(): number {\n    if (!this.items || this.items.length === 0) return 0;\n    return this.items.length * this.itemWidth + (this.items.length - 1) * this.gap;\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-shell\" #bleedShell>\n  <div *ngIf=\"title\" class=\"c-carousel-fixed-header\">\n    <div class=\"c-carousel-fixed-header-inner\">\n      <div class=\"c-carousel-fixed-title\">\n        {{ title }}\n      </div>\n      <div class=\"c-carousel-fixed-controls\">\n        <button\n          class=\"c-carousel-fixed-nav prev\"\n          [disabled]=\"!canGoPrevious()\"\n          title=\"Página anterior\"\n          aria-label=\"Página anterior\"\n          (click)=\"prevPage()\"\n        >\n          <lib-elux-icon\n            [icon]=\"'Chevron_Left.svg'\"\n            [size]=\"'16'\"\n            [sizeType]=\"'px'\"\n            [color]=\"'#020F2E'\"\n          ></lib-elux-icon>\n        </button>\n\n        <button\n          class=\"c-carousel-fixed-nav next\"\n          [disabled]=\"!canGoNext()\"\n          title=\"Próxima página\"\n          aria-label=\"Próxima página\"\n          (click)=\"nextPage()\"\n        >\n          <lib-elux-icon\n            [icon]=\"'Chevron_Right.svg'\"\n            [size]=\"'16'\"\n            [sizeType]=\"'px'\"\n            [color]=\"'#020F2E'\"\n          ></lib-elux-icon>\n        </button>\n      </div>\n    </div>\n  </div>\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    >\n      <ng-content></ng-content>\n    </div>\n  </div>\n\n  <div class=\"c-carousel-fixed-footer\" *ngIf=\"getDotsArray().length > 1\">\n    <div class=\"c-carousel-fixed-controls\">\n      <button\n        *ngIf=\"title == ''\"\n        class=\"c-carousel-fixed-nav prev\"\n        [disabled]=\"!canGoPrevious()\"\n        title=\"Página anterior\"\n        aria-label=\"Página anterior\"\n        (click)=\"prevPage()\"\n      >\n        <lib-elux-icon\n          [icon]=\"'Chevron_Left.svg'\"\n          [size]=\"'16'\"\n          [sizeType]=\"'px'\"\n          [color]=\"'#020F2E'\"\n        ></lib-elux-icon>\n      </button>\n\n      <div class=\"c-carousel-fixed-dots\">\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          >\n          </span>\n        </ng-container>\n      </div>\n\n      <button\n        *ngIf=\"title == ''\"\n        class=\"c-carousel-fixed-nav next\"\n        [disabled]=\"!canGoNext()\"\n        title=\"Próxima página\"\n        aria-label=\"Próxima página\"\n        (click)=\"nextPage()\"\n      >\n        <lib-elux-icon\n          [icon]=\"'Chevron_Right.svg'\"\n          [size]=\"'16'\"\n          [sizeType]=\"'px'\"\n          [color]=\"'#020F2E'\"\n        ></lib-elux-icon>\n      </button>\n    </div>\n  </div>\n</div>\n"]}