@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.
- package/assets/icons/MeatballMenu.svg +3 -0
- package/esm2022/lib/components/carousel-fixed/carousel-fixed.component.mjs +204 -151
- package/esm2022/lib/components/toast/toast.component.mjs +3 -3
- package/fesm2022/elxjs-ui.mjs +204 -152
- package/fesm2022/elxjs-ui.mjs.map +1 -1
- package/lib/components/carousel-fixed/carousel-fixed.component.d.ts +15 -10
- package/package.json +1 -1
|
@@ -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;
|
|
9
|
-
this.gap = 16;
|
|
10
|
-
this.
|
|
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
|
-
|
|
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)
|
|
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.
|
|
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.
|
|
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.
|
|
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
|
-
//
|
|
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(
|
|
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
|
-
//
|
|
264
|
-
|
|
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
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
this.
|
|
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
|
-
|
|
316
|
-
|
|
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
|
-
|
|
328
|
-
// Use the current index instead of visual calculation to avoid double movement
|
|
341
|
+
nextItem() {
|
|
329
342
|
const maxIndex = this.getMaxIndex();
|
|
330
|
-
|
|
331
|
-
|
|
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
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
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
|
-
//
|
|
368
|
-
|
|
369
|
-
//
|
|
370
|
-
|
|
371
|
-
|
|
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.
|
|
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
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
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",
|
|
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
|
|
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
|
-
}],
|
|
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"]}
|