@elxjs/ui 0.0.201 → 0.0.203

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.
@@ -1,472 +0,0 @@
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 EluxCarouselFixedComponent {
7
- constructor(renderer) {
8
- this.renderer = renderer;
9
- this.itemWidth = 200;
10
- this.gap = 16;
11
- this.showArrows = true;
12
- this.showDots = true;
13
- this.previousClickEventEmitter = new EventEmitter();
14
- this.nextClickEventEmitter = new EventEmitter();
15
- this.dotClickEventEmitter = new EventEmitter();
16
- this.currentIndex = 0;
17
- this.translateX = 0;
18
- this.isDragging = false;
19
- this.isMouseDown = false;
20
- this.startX = 0;
21
- this.currentX = 0;
22
- this.initialTranslateX = 0;
23
- this.dragOffset = 0;
24
- this.containerWidth = 0;
25
- this.maxTranslateX = 0;
26
- this.minTranslateX = 0;
27
- this.velocity = 0;
28
- this.lastMoveTime = 0;
29
- this.lastMoveX = 0;
30
- this.touchStartTime = 0;
31
- this.touchStartX = 0;
32
- this.touchStartY = 0;
33
- this.isVerticalScroll = false;
34
- this.wasDragging = false;
35
- this.clicksDisabled = false;
36
- this.clickListeners = [];
37
- this.dragStarted = false;
38
- this.mouseDownTime = 0;
39
- this.calculateRightBleedContainer = () => {
40
- if (this.rightBleedContainer) {
41
- const el = this.rightBleedContainer.nativeElement;
42
- const left = el.getBoundingClientRect().left;
43
- let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;
44
- scrollbarWidth = scrollbarWidth == 0 || scrollbarWidth > 30 ? 0 : scrollbarWidth;
45
- el.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);
46
- el.style.setProperty('--left-offset', `${left}px`);
47
- }
48
- };
49
- }
50
- ngAfterContentInit() {
51
- setTimeout(() => {
52
- this.calculateDimensions();
53
- this.setItemWidths();
54
- this.updateLimits();
55
- this.setupClickPrevention();
56
- this.items.changes.subscribe(() => {
57
- this.calculateDimensions();
58
- this.setItemWidths();
59
- this.updateLimits();
60
- this.goToFirstItem();
61
- this.setupClickPrevention();
62
- // Força atualização visual dos dots
63
- if (this.cd && typeof this.cd.detectChanges === 'function') {
64
- this.cd.detectChanges();
65
- }
66
- });
67
- }, 10);
68
- window.addEventListener('resize', () => this.onResize());
69
- }
70
- ngOnDestroy() {
71
- // Clean up click listeners
72
- this.clickListeners.forEach(unlisten => unlisten());
73
- this.clickListeners = [];
74
- window.removeEventListener('resize', () => this.onResize());
75
- }
76
- calculateDimensions() {
77
- if (this.slidesContainer) {
78
- this.containerWidth = this.slidesContainer.nativeElement.offsetWidth;
79
- }
80
- }
81
- updateLimits() {
82
- const totalWidth = this.items.length * (this.itemWidth + this.gap);
83
- this.maxTranslateX = 0;
84
- if (totalWidth > this.containerWidth) {
85
- this.minTranslateX = this.containerWidth - totalWidth;
86
- }
87
- else {
88
- this.minTranslateX = 0;
89
- }
90
- }
91
- onResize() {
92
- this.calculateRightBleedContainer();
93
- this.calculateDimensions();
94
- this.updateLimits();
95
- // Garante que o currentIndex não ultrapasse o novo máximo
96
- const maxIndex = this.getMaxIndex();
97
- if (this.currentIndex > maxIndex) {
98
- this.currentIndex = maxIndex;
99
- }
100
- this.updateTransform();
101
- // Força detecção de mudanças para atualizar dots
102
- if (window.ng && window.ng.getInjector) {
103
- // Angular DevTools presente, não faz nada
104
- }
105
- else if (this.cd && typeof this.cd.detectChanges === 'function') {
106
- this.cd.detectChanges();
107
- }
108
- }
109
- ngAfterViewInit() {
110
- // Garante cálculo correto após view carregada
111
- setTimeout(() => {
112
- this.calculateRightBleedContainer();
113
- this.calculateDimensions();
114
- this.updateLimits();
115
- this.updateTransform();
116
- });
117
- }
118
- setItemWidths() {
119
- this.items.forEach((item) => {
120
- this.renderer.setStyle(item.nativeElement, 'width', `${this.itemWidth}px`);
121
- this.renderer.setStyle(item.nativeElement, 'flex-shrink', '0');
122
- this.renderer.setStyle(item.nativeElement, 'margin-right', `${this.gap}px`);
123
- });
124
- }
125
- // Mouse events
126
- onMouseDown(event) {
127
- event.preventDefault();
128
- this.mouseDownTime = Date.now();
129
- this.dragStarted = false;
130
- this.isMouseDown = true;
131
- this.wasDragging = false;
132
- this.clicksDisabled = false;
133
- this.startX = event.clientX;
134
- this.currentX = event.clientX;
135
- this.initialTranslateX = this.translateX;
136
- this.dragOffset = 0;
137
- this.velocity = 0;
138
- this.lastMoveTime = Date.now();
139
- this.lastMoveX = event.clientX;
140
- this.calculateDimensions();
141
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
142
- }
143
- onMouseMove(event) {
144
- if (!this.isMouseDown)
145
- return;
146
- event.preventDefault();
147
- const dragDistance = Math.abs(event.clientX - this.startX);
148
- // Only start dragging if moved more than 5px
149
- if (dragDistance > 5 && !this.isDragging) {
150
- this.isDragging = true;
151
- this.dragStarted = true;
152
- this.wasDragging = true;
153
- }
154
- if (this.isDragging) {
155
- this.updateDrag(event.clientX);
156
- }
157
- }
158
- onMouseUp(event) {
159
- if (!this.isMouseDown)
160
- return;
161
- this.isMouseDown = false;
162
- if (this.isDragging) {
163
- const mouseUpTime = Date.now();
164
- const holdDuration = mouseUpTime - this.mouseDownTime;
165
- const mouseDistance = Math.abs(this.currentX - this.startX);
166
- if (mouseDistance > 5 || (holdDuration > 200 && mouseDistance > 0)) {
167
- this.wasDragging = true;
168
- }
169
- this.endDrag();
170
- }
171
- else {
172
- // Reset transition if it was just a click
173
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
174
- }
175
- }
176
- onMouseLeave(event) {
177
- if (this.isDragging) {
178
- this.wasDragging = true;
179
- this.endDrag();
180
- }
181
- this.isMouseDown = false;
182
- }
183
- // Touch events
184
- onTouchStart(event) {
185
- this.touchStartTime = Date.now();
186
- this.touchStartX = event.touches[0].clientX;
187
- this.touchStartY = event.touches[0].clientY;
188
- this.isVerticalScroll = false;
189
- this.isMouseDown = true;
190
- this.wasDragging = false;
191
- this.dragStarted = false;
192
- this.clicksDisabled = false;
193
- this.startX = event.touches[0].clientX;
194
- this.currentX = event.touches[0].clientX;
195
- this.initialTranslateX = this.translateX;
196
- this.dragOffset = 0;
197
- this.velocity = 0;
198
- this.lastMoveTime = Date.now();
199
- this.lastMoveX = event.touches[0].clientX;
200
- this.calculateDimensions();
201
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'none');
202
- }
203
- onTouchMove(event) {
204
- if (!this.isMouseDown)
205
- return;
206
- const currentX = event.touches[0].clientX;
207
- const currentY = event.touches[0].clientY;
208
- const deltaX = Math.abs(currentX - this.touchStartX);
209
- const deltaY = Math.abs(currentY - this.touchStartY);
210
- // Check if this is a vertical scroll
211
- if (deltaY > deltaX && deltaY > 10) {
212
- this.isVerticalScroll = true;
213
- this.isDragging = false;
214
- this.isMouseDown = false;
215
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
216
- return;
217
- }
218
- // Start dragging if horizontal movement > 10px
219
- if (deltaX > 10 && !this.isDragging) {
220
- this.isDragging = true;
221
- this.dragStarted = true;
222
- this.wasDragging = true;
223
- }
224
- if (this.isDragging && deltaX > 10) {
225
- event.preventDefault();
226
- this.updateDrag(currentX);
227
- }
228
- }
229
- onTouchEnd(event) {
230
- if (this.isVerticalScroll) {
231
- this.isVerticalScroll = false;
232
- this.isMouseDown = false;
233
- return;
234
- }
235
- this.isMouseDown = false;
236
- const touchDuration = Date.now() - this.touchStartTime;
237
- const touchDistance = Math.abs(this.currentX - this.startX);
238
- // Mark as dragging if significant movement occurred
239
- if (touchDistance > 10 || touchDuration > 300) {
240
- this.wasDragging = true;
241
- }
242
- if (this.isDragging) {
243
- this.endDrag();
244
- }
245
- else {
246
- // Reset transition if it was just a tap
247
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
248
- }
249
- }
250
- setupClickPrevention() {
251
- // Clean up existing listeners
252
- this.clickListeners.forEach(unlisten => unlisten());
253
- this.clickListeners = [];
254
- this.items.forEach((item) => {
255
- // Only prevent click events, not mouseup which is needed for drag functionality
256
- const eventHandler = (event) => {
257
- if (event.type === 'click' && (this.wasDragging || this.clicksDisabled || this.dragStarted)) {
258
- event.preventDefault();
259
- event.stopPropagation();
260
- event.stopImmediatePropagation();
261
- return false;
262
- }
263
- return true;
264
- };
265
- // Only listen to click events to avoid interfering with drag functionality
266
- item.nativeElement.addEventListener('click', eventHandler, true);
267
- this.clickListeners.push(() => {
268
- item.nativeElement.removeEventListener('click', eventHandler, true);
269
- });
270
- });
271
- }
272
- updateDrag(clientX) {
273
- if (!this.isDragging)
274
- return;
275
- this.currentX = clientX;
276
- const totalDeltaX = this.currentX - this.startX;
277
- // Mark as dragging if movement is significant
278
- if (Math.abs(totalDeltaX) > 5) {
279
- this.wasDragging = true;
280
- this.dragStarted = true;
281
- }
282
- const now = Date.now();
283
- const timeDelta = now - this.lastMoveTime;
284
- if (timeDelta > 0) {
285
- this.velocity = (clientX - this.lastMoveX) / timeDelta;
286
- }
287
- this.lastMoveTime = now;
288
- this.lastMoveX = clientX;
289
- let resistedDeltaX = totalDeltaX;
290
- const potentialTranslateX = this.initialTranslateX + totalDeltaX;
291
- // Apply softer resistance at boundaries
292
- if (potentialTranslateX > this.maxTranslateX) {
293
- const overDrag = potentialTranslateX - this.maxTranslateX;
294
- resistedDeltaX = totalDeltaX - (overDrag * 0.5);
295
- }
296
- else if (potentialTranslateX < this.minTranslateX) {
297
- const overDrag = this.minTranslateX - potentialTranslateX;
298
- resistedDeltaX = totalDeltaX + (overDrag * 0.5);
299
- }
300
- this.dragOffset = resistedDeltaX;
301
- this.updateDragPosition();
302
- }
303
- updateDragPosition() {
304
- const newTranslateX = this.initialTranslateX + this.dragOffset;
305
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transform', `translateX(${newTranslateX}px)`);
306
- }
307
- endDrag() {
308
- if (!this.isDragging)
309
- return;
310
- this.isDragging = false;
311
- // Disable clicks temporarily after any drag
312
- if (this.wasDragging || this.dragStarted) {
313
- this.clicksDisabled = true;
314
- setTimeout(() => {
315
- this.clicksDisabled = false;
316
- }, 200);
317
- }
318
- // Clear the wasDragging and dragStarted flags after a shorter delay
319
- setTimeout(() => {
320
- this.wasDragging = false;
321
- this.dragStarted = false;
322
- }, 250);
323
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transition', 'transform 0.3s ease-out');
324
- // Snap sempre para o início da página mais próxima
325
- this.snapToNearestItem();
326
- this.dragOffset = 0;
327
- this.velocity = 0;
328
- }
329
- getMaxIndex() {
330
- // Permite avançar até que o último item esteja visível (não necessariamente alinhado à esquerda)
331
- if (!this.items || this.items.length === 0)
332
- return 0;
333
- const visibleCount = Math.max(1, Math.floor(this.containerWidth / (this.itemWidth + this.gap)));
334
- if (this.items.length <= visibleCount)
335
- return 0;
336
- // Última posição onde o último item aparece visível
337
- return this.items.length - visibleCount;
338
- }
339
- canGoNext() {
340
- return this.currentIndex < this.getMaxIndex();
341
- }
342
- nextItem() {
343
- const maxIndex = this.getMaxIndex();
344
- if (this.canGoNext()) {
345
- let newIndex = this.currentIndex + 1;
346
- if (newIndex > maxIndex)
347
- newIndex = maxIndex;
348
- this.currentIndex = newIndex;
349
- this.updateTransform();
350
- this.nextClickEventEmitter.emit();
351
- }
352
- }
353
- canGoPrevious() {
354
- return this.currentIndex > 0;
355
- }
356
- prevItem() {
357
- if (this.canGoPrevious()) {
358
- let newIndex = this.currentIndex - 1;
359
- if (newIndex < 0)
360
- newIndex = 0;
361
- this.currentIndex = newIndex;
362
- this.updateTransform();
363
- this.previousClickEventEmitter.emit();
364
- }
365
- }
366
- goToDot(dotIndex) {
367
- const maxIndex = this.getMaxIndex();
368
- let newIndex = dotIndex;
369
- if (newIndex > maxIndex)
370
- newIndex = maxIndex;
371
- this.currentIndex = newIndex;
372
- this.updateTransform();
373
- this.dotClickEventEmitter.emit();
374
- }
375
- snapToNearestItem() {
376
- const itemStep = this.itemWidth + this.gap;
377
- const position = -(this.initialTranslateX + this.dragOffset) / itemStep;
378
- // Threshold: 0.3 = 30%, 0.5 = 50% (padrão)
379
- const threshold = 0.3;
380
- let targetIndex;
381
- // Calcula quantos itens completos foram arrastados
382
- const itemsMoved = Math.floor(Math.abs(position - this.currentIndex));
383
- const decimal = Math.abs(position - this.currentIndex) - itemsMoved;
384
- if (position > this.currentIndex) {
385
- // Arrastando para frente
386
- if (decimal >= threshold) {
387
- targetIndex = this.currentIndex + itemsMoved + 1;
388
- }
389
- else {
390
- targetIndex = this.currentIndex + itemsMoved;
391
- }
392
- }
393
- else if (position < this.currentIndex) {
394
- // Arrastando para trás
395
- if (decimal >= threshold) {
396
- targetIndex = this.currentIndex - itemsMoved - 1;
397
- }
398
- else {
399
- targetIndex = this.currentIndex - itemsMoved;
400
- }
401
- }
402
- else {
403
- // Não se moveu
404
- targetIndex = this.currentIndex;
405
- }
406
- const maxIndex = this.getMaxIndex();
407
- targetIndex = Math.max(0, Math.min(targetIndex, maxIndex));
408
- this.currentIndex = targetIndex;
409
- this.updateTransform();
410
- }
411
- getDotsArray() {
412
- // Só mostra dots para cada posição possível (cada "página" possível)
413
- const maxIndex = this.getMaxIndex();
414
- return Array(maxIndex + 1);
415
- }
416
- getCurrentDotIndex() {
417
- return this.currentIndex;
418
- }
419
- updateTransform() {
420
- const itemStep = this.itemWidth + this.gap;
421
- this.translateX = -this.currentIndex * itemStep;
422
- // Clamp para não mostrar espaço vazio à direita
423
- const visibleCount = Math.max(1, Math.floor(this.containerWidth / itemStep));
424
- // Inclui o gap após o último item
425
- const totalWidth = this.items.length * itemStep;
426
- if (this.items.length > visibleCount) {
427
- const minTranslateX = this.containerWidth - totalWidth;
428
- this.translateX = Math.max(this.translateX, minTranslateX);
429
- }
430
- else {
431
- this.translateX = 0;
432
- }
433
- if (!this.isDragging && this.slidesContainer) {
434
- this.renderer.setStyle(this.slidesContainer.nativeElement, 'transform', `translateX(${this.translateX}px)`);
435
- }
436
- }
437
- // Adicione este método para evitar erro de propriedade ausente
438
- goToFirstItem() {
439
- this.currentIndex = 0;
440
- this.updateTransform();
441
- }
442
- 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 }); }
443
- 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", dotClickEventEmitter: "dotClickEventEmitter" }, 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 && getDotsArray().length > 1\"\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 && getDotsArray().length > 1\">\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 && getDotsArray().length > 1\"\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"] }] }); }
444
- }
445
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: EluxCarouselFixedComponent, decorators: [{
446
- type: Component,
447
- 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 && getDotsArray().length > 1\"\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 && getDotsArray().length > 1\">\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 && getDotsArray().length > 1\"\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"] }]
448
- }], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { items: [{
449
- type: ContentChildren,
450
- args: ['carouselItem', { read: ElementRef }]
451
- }], slidesContainer: [{
452
- type: ViewChild,
453
- args: ['slidesContainer']
454
- }], rightBleedContainer: [{
455
- type: ViewChild,
456
- args: ['rightBleedContainer', { static: false }]
457
- }], itemWidth: [{
458
- type: Input
459
- }], gap: [{
460
- type: Input
461
- }], showArrows: [{
462
- type: Input
463
- }], showDots: [{
464
- type: Input
465
- }], previousClickEventEmitter: [{
466
- type: Output
467
- }], nextClickEventEmitter: [{
468
- type: Output
469
- }], dotClickEventEmitter: [{
470
- type: Output
471
- }] } });
472
- //# 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  @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\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    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    // 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 && getDotsArray().length > 1\"\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 && getDotsArray().length > 1\">\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 && getDotsArray().length > 1\"\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"]}