@datarailsshared/datarailsshared 1.6.73 → 1.6.77

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,28 +1,45 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, Input, TemplateRef, } from '@angular/core';
3
- import { take as _take, takeRight as _takeRight } from 'lodash';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, Input, QueryList, TemplateRef, ViewChild, ViewChildren, } from '@angular/core';
4
3
  import { DrInputsModule } from '../dr-inputs/dr-inputs.module';
5
4
  import * as i0 from "@angular/core";
6
5
  import * as i1 from "@angular/common";
7
6
  import * as i2 from "../dr-inputs/button/button.component";
8
- function DrGalleryComponent_div_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
7
+ const _c0 = ["carouselContainer"];
8
+ const _c1 = ["carouselItem"];
9
+ function DrGalleryComponent_dr_button_0_Template(rf, ctx) { if (rf & 1) {
10
+ const _r5 = i0.ɵɵgetCurrentView();
11
+ i0.ɵɵelementStart(0, "dr-button", 5);
12
+ i0.ɵɵlistener("click", function DrGalleryComponent_dr_button_0_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.prev()); });
13
+ i0.ɵɵelementEnd();
14
+ } if (rf & 2) {
15
+ i0.ɵɵproperty("icon", "dr-icon-arrow-left");
16
+ } }
17
+ function DrGalleryComponent_div_4_ng_container_2_Template(rf, ctx) { if (rf & 1) {
9
18
  i0.ɵɵelementContainer(0);
10
19
  } }
11
- const _c0 = function (a0) { return { "dr-gallery-item_active": a0 }; };
12
- const _c1 = function (a0) { return { $implicit: a0 }; };
13
- function DrGalleryComponent_div_3_Template(rf, ctx) { if (rf & 1) {
14
- i0.ɵɵelementStart(0, "div", 5);
15
- i0.ɵɵtemplate(1, DrGalleryComponent_div_3_ng_container_1_Template, 1, 0, "ng-container", 6);
20
+ const _c2 = function () { return {}; };
21
+ const _c3 = function (a0) { return { $implicit: a0 }; };
22
+ function DrGalleryComponent_div_4_Template(rf, ctx) { if (rf & 1) {
23
+ i0.ɵɵelementStart(0, "div", 6, 7);
24
+ i0.ɵɵtemplate(2, DrGalleryComponent_div_4_ng_container_2_Template, 1, 0, "ng-container", 8);
25
+ i0.ɵɵelementEnd();
26
+ } if (rf & 2) {
27
+ const item_r6 = ctx.$implicit;
28
+ const i_r7 = ctx.index;
29
+ const ctx_r2 = i0.ɵɵnextContext();
30
+ i0.ɵɵstyleProp("transition", ctx_r2.transition);
31
+ i0.ɵɵclassProp("dr-gallery-item_active", ctx_r2.centerIndex === i_r7)("dr-gallery-item_fadein", ctx_r2.fadeIn && ctx_r2.centerIndex === i_r7 + 1);
32
+ i0.ɵɵproperty("ngStyle", ctx_r2.modeType === "loop" ? ctx_r2.getStyle() : i0.ɵɵpureFunction0(9, _c2));
33
+ i0.ɵɵadvance(2);
34
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r2.template)("ngTemplateOutletContext", i0.ɵɵpureFunction1(10, _c3, item_r6));
35
+ } }
36
+ function DrGalleryComponent_dr_button_5_Template(rf, ctx) { if (rf & 1) {
37
+ const _r11 = i0.ɵɵgetCurrentView();
38
+ i0.ɵɵelementStart(0, "dr-button", 9);
39
+ i0.ɵɵlistener("click", function DrGalleryComponent_dr_button_5_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r11); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.next()); });
16
40
  i0.ɵɵelementEnd();
17
41
  } if (rf & 2) {
18
- const item_r1 = ctx.$implicit;
19
- const i_r2 = ctx.index;
20
- const ctx_r0 = i0.ɵɵnextContext();
21
- i0.ɵɵstyleMap(ctx_r0.getStyle());
22
- i0.ɵɵstyleProp("transition", ctx_r0.transition);
23
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(7, _c0, ctx_r0.centerIndex === i_r2));
24
- i0.ɵɵadvance(1);
25
- i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.template)("ngTemplateOutletContext", i0.ɵɵpureFunction1(9, _c1, item_r1));
42
+ i0.ɵɵproperty("iconSize", "24px")("icon", "dr-icon-arrow-right");
26
43
  } }
27
44
  export class DrGalleryComponent {
28
45
  set items(value) {
@@ -47,25 +64,66 @@ export class DrGalleryComponent {
47
64
  get centerIndex() {
48
65
  return this.itemsCount > 1 && this.itemsCount % 2 !== 0 ? this.activeIndex + Math.floor(this.itemsCount / 2) : null;
49
66
  }
50
- ngOnChanges() {
51
- this.activeIndex = this.itemsCount;
52
- this.initializeCarousel();
53
- this.updateTransform();
54
- }
55
67
  constructor(cdr) {
56
68
  this.cdr = cdr;
57
69
  this._items = [];
58
70
  this._itemsCount = 3;
59
71
  this.defaultTransition = '250ms ease-in-out';
60
72
  this.noTransition = '0ms';
73
+ this.modeType = 'loop';
74
+ this.isOutsideBtns = false;
75
+ this.fadeIn = false;
76
+ this.autoPlay = false;
77
+ this.autoplayInterval = 5000; //5 seconds
61
78
  this.activeIndex = 0;
62
79
  this.carouselItems = [];
63
- this.transform = `translateX(0%)`;
80
+ this.transform = 'translateX(0%)';
64
81
  this.transition = this.defaultTransition;
82
+ this.itemOffsets = [];
83
+ this.itemWidths = [];
84
+ }
85
+ ngAfterViewInit() {
86
+ // Wait for initial render
87
+ setTimeout(() => {
88
+ this.calculateItemOffsets();
89
+ this.updateTransform();
90
+ if (this.autoPlay) {
91
+ this.startAutoplay();
92
+ }
93
+ });
94
+ }
95
+ ngOnDestroy() {
96
+ this.clearAutoplay();
65
97
  }
66
98
  initializeCarousel() {
67
- this.carouselItems = [..._takeRight(this.items, this.itemsCount), ...this.items, ..._take(this.items, this.itemsCount)];
68
- this.updateTransform();
99
+ if (this.modeType === 'loop') {
100
+ this.carouselItems = [
101
+ ...this._items.slice(-this.itemsCount),
102
+ ...this._items,
103
+ ...this._items.slice(0, this.itemsCount),
104
+ ];
105
+ this.activeIndex = this.itemsCount;
106
+ }
107
+ else {
108
+ this.carouselItems = [...this._items];
109
+ this.activeIndex = 0;
110
+ }
111
+ setTimeout(() => {
112
+ this.calculateItemOffsets();
113
+ this.updateTransform();
114
+ });
115
+ }
116
+ calculateItemOffsets() {
117
+ this.itemOffsets = [];
118
+ this.itemWidths = [];
119
+ let offset = 0;
120
+ const elements = this.itemElements.toArray();
121
+ for (const el of elements) {
122
+ const width = el.nativeElement.offsetWidth;
123
+ this.itemOffsets.push(offset);
124
+ this.itemWidths.push(width);
125
+ offset += width;
126
+ }
69
127
  }
70
128
  getStyle() {
71
129
  const percent = `calc(${100 / this.itemsCount}%)`;
@@ -76,21 +134,62 @@ export class DrGalleryComponent {
76
134
  };
77
135
  }
78
136
  prev() {
79
- this.activeIndex--;
80
- this.transition = this.defaultTransition;
81
- this.updateTransform();
82
- if (this.activeIndex <= 0) {
83
- this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);
137
+ if (this.modeType === 'loop') {
138
+ this.activeIndex--;
139
+ this.transition = this.defaultTransition;
140
+ this.updateTransform();
141
+ if (this.activeIndex <= 0) {
142
+ this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);
143
+ }
144
+ }
145
+ else {
146
+ if (this.activeIndex > 0) {
147
+ this.activeIndex--;
148
+ this.updateTransform();
149
+ }
84
150
  }
85
151
  }
86
152
  next() {
87
- this.activeIndex++;
88
- this.transition = this.defaultTransition;
153
+ if (this.modeType === 'loop') {
154
+ this.activeIndex++;
155
+ this.transition = this.defaultTransition;
156
+ this.updateTransform();
157
+ if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {
158
+ this.resetIndexAfterDelay(this.itemsCount);
159
+ }
160
+ }
161
+ else {
162
+ if (this.activeIndex + 1 < this.carouselItems.length) {
163
+ this.activeIndex++;
164
+ this.updateTransform();
165
+ }
166
+ else {
167
+ this.activeIndex = 0;
168
+ this.updateTransform();
169
+ }
170
+ }
171
+ }
172
+ navigate(index) {
173
+ this.activeIndex = index;
89
174
  this.updateTransform();
90
- if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {
91
- this.resetIndexAfterDelay(this.itemsCount);
175
+ if (this.autoPlay) {
176
+ this.startAutoplay();
92
177
  }
93
178
  }
179
+ get canGoPrev() {
180
+ if (this.modeType === 'loop')
181
+ return true;
182
+ return !!(this.activeIndex > 0);
183
+ }
184
+ get canGoNext() {
185
+ if (this.modeType === 'loop')
186
+ return true;
187
+ const containerWidth = this.containerRef?.nativeElement?.offsetWidth || 0;
188
+ const currentOffset = this.itemOffsets[this.activeIndex] || 0;
189
+ const lastIndex = this.itemOffsets.length - 1;
190
+ const totalContentWidth = this.itemOffsets[lastIndex] + this.itemWidths[lastIndex];
191
+ return currentOffset + containerWidth < totalContentWidth - 1;
192
+ }
94
193
  resetIndexAfterDelay(newIndex) {
95
194
  setTimeout(() => {
96
195
  this.transition = this.noTransition;
@@ -99,46 +198,88 @@ export class DrGalleryComponent {
99
198
  }, 250);
100
199
  }
101
200
  updateTransform(skipTransition = false) {
102
- this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;
201
+ if (this.modeType === 'loop') {
202
+ this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;
203
+ }
204
+ else {
205
+ const offset = this.itemOffsets[this.activeIndex] || 0;
206
+ this.transform = `translateX(-${offset}px)`;
207
+ }
103
208
  if (skipTransition)
104
209
  this.transition = this.noTransition;
210
+ else
211
+ this.transition = this.defaultTransition;
105
212
  this.cdr.markForCheck();
106
213
  }
214
+ startAutoplay() {
215
+ this.clearAutoplay();
216
+ this.autoplayTimer = setInterval(() => {
217
+ this.next();
218
+ }, this.autoplayInterval);
219
+ }
220
+ clearAutoplay() {
221
+ if (this.autoplayTimer) {
222
+ clearInterval(this.autoplayTimer);
223
+ this.autoplayTimer = null;
224
+ }
225
+ }
107
226
  /** @nocollapse */ static { this.ɵfac = function DrGalleryComponent_Factory(t) { return new (t || DrGalleryComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
108
227
  /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrGalleryComponent, selectors: [["dr-gallery"]], contentQueries: function DrGalleryComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
109
228
  i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);
110
229
  } if (rf & 2) {
111
230
  let _t;
112
231
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.template = _t.first);
113
- } }, inputs: { items: "items", itemsCount: "itemsCount" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 5, vars: 8, consts: [["theme", "icon", 1, "dr-gallery-btn", "dr-gallery-btn_left", 3, "icon", "click"], [1, "dr-gallery-caroousel"], [1, "dr-gallery-items"], ["class", "dr-gallery-item", 3, "transition", "ngClass", "style", 4, "ngFor", "ngForOf"], ["theme", "icon", 1, "dr-gallery-btn", "dr-gallery-btn_right", 3, "iconSize", "icon", "click"], [1, "dr-gallery-item", 3, "ngClass"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrGalleryComponent_Template(rf, ctx) { if (rf & 1) {
114
- i0.ɵɵelementStart(0, "dr-button", 0);
115
- i0.ɵɵlistener("click", function DrGalleryComponent_Template_dr_button_click_0_listener() { return ctx.prev(); });
116
- i0.ɵɵelementEnd();
117
- i0.ɵɵelementStart(1, "div", 1)(2, "div", 2);
118
- i0.ɵɵtemplate(3, DrGalleryComponent_div_3_Template, 2, 11, "div", 3);
232
+ } }, viewQuery: function DrGalleryComponent_Query(rf, ctx) { if (rf & 1) {
233
+ i0.ɵɵviewQuery(_c0, 5);
234
+ i0.ɵɵviewQuery(_c1, 5);
235
+ } if (rf & 2) {
236
+ let _t;
237
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.containerRef = _t.first);
238
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.itemElements = _t);
239
+ } }, inputs: { modeType: "modeType", isOutsideBtns: "isOutsideBtns", fadeIn: "fadeIn", autoPlay: "autoPlay", autoplayInterval: "autoplayInterval", items: "items", itemsCount: "itemsCount" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 12, consts: [["class", "dr-gallery-btn dr-gallery-btn_left", "theme", "icon", 3, "icon", "click", 4, "ngIf"], ["carouselContainer", ""], [1, "dr-gallery-items"], ["class", "dr-gallery-item", 3, "transition", "dr-gallery-item_active", "dr-gallery-item_fadein", "ngStyle", 4, "ngFor", "ngForOf"], ["class", "dr-gallery-btn dr-gallery-btn_right", "theme", "icon", 3, "iconSize", "icon", "click", 4, "ngIf"], ["theme", "icon", 1, "dr-gallery-btn", "dr-gallery-btn_left", 3, "icon", "click"], [1, "dr-gallery-item", 3, "ngStyle"], ["carouselItem", ""], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["theme", "icon", 1, "dr-gallery-btn", "dr-gallery-btn_right", 3, "iconSize", "icon", "click"]], template: function DrGalleryComponent_Template(rf, ctx) { if (rf & 1) {
240
+ i0.ɵɵtemplate(0, DrGalleryComponent_dr_button_0_Template, 1, 1, "dr-button", 0);
241
+ i0.ɵɵelementStart(1, "div", null, 1)(3, "div", 2);
242
+ i0.ɵɵtemplate(4, DrGalleryComponent_div_4_Template, 3, 12, "div", 3);
119
243
  i0.ɵɵelementEnd()();
120
- i0.ɵɵelementStart(4, "dr-button", 4);
121
- i0.ɵɵlistener("click", function DrGalleryComponent_Template_dr_button_click_4_listener() { return ctx.next(); });
122
- i0.ɵɵelementEnd();
244
+ i0.ɵɵtemplate(5, DrGalleryComponent_dr_button_5_Template, 1, 2, "dr-button", 4);
123
245
  } if (rf & 2) {
124
- i0.ɵɵproperty("icon", "dr-icon-arrow-left");
246
+ i0.ɵɵproperty("ngIf", !ctx.isOutsideBtns);
247
+ i0.ɵɵadvance(1);
248
+ i0.ɵɵclassMapInterpolate1("dr-gallery-caroousel dr-gallery-caroousel_", ctx.modeType, "");
249
+ i0.ɵɵclassProp("dr-gallery-caroousel_fadein", ctx.fadeIn);
125
250
  i0.ɵɵadvance(2);
126
251
  i0.ɵɵstyleProp("transition", ctx.transition)("transform", ctx.transform);
127
252
  i0.ɵɵadvance(1);
128
253
  i0.ɵɵproperty("ngForOf", ctx.carouselItems);
129
254
  i0.ɵɵadvance(1);
130
- i0.ɵɵproperty("iconSize", "24px")("icon", "dr-icon-arrow-right");
131
- } }, dependencies: [CommonModule, i1.NgClass, i1.NgForOf, i1.NgTemplateOutlet, DrInputsModule, i2.DrButtonComponent], styles: [".dr-gallery-caroousel[_ngcontent-%COMP%]{display:block;position:relative;overflow:hidden}.dr-gallery-items[_ngcontent-%COMP%]{display:flex;position:relative;align-items:flex-end;will-change:transform}.dr-gallery-item[_ngcontent-%COMP%]{box-sizing:border-box;position:relative;padding:42px 24px;margin-top:-8px;flex-grow:1;width:100%;min-height:240px}.dr-gallery-item_active[_ngcontent-%COMP%]{transform:scale(1.2)}.dr-gallery-btn[_ngcontent-%COMP%]{position:absolute;top:50%;transform:translateY(-50%);z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;box-shadow:0 4px 4px #00000040}.dr-gallery-btn[_ngcontent-%COMP%] button[_ngcontent-%COMP%]{width:40px!important;height:40px!important}.dr-gallery-btn[_ngcontent-%COMP%] button[_ngcontent-%COMP%]:hover{border-radius:50%}.dr-gallery-btn_left[_ngcontent-%COMP%]{left:0}.dr-gallery-btn_right[_ngcontent-%COMP%]{right:0}"], changeDetection: 0 }); }
255
+ i0.ɵɵproperty("ngIf", !ctx.isOutsideBtns);
256
+ } }, dependencies: [CommonModule, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, i1.NgStyle, DrInputsModule, i2.DrButtonComponent], styles: [".dr-gallery-caroousel[_ngcontent-%COMP%]{display:block;position:relative;overflow:hidden}.dr-gallery-caroousel.dr-gallery-caroousel_loop[_ngcontent-%COMP%] .dr-gallery-item[_ngcontent-%COMP%]{width:100%;min-height:240px}.dr-gallery-caroousel.dr-gallery-caroousel_loop[_ngcontent-%COMP%] .dr-gallery-item_active[_ngcontent-%COMP%]{transform:scale(1.2)}.dr-gallery-caroousel.dr-gallery-caroousel_fadein[_ngcontent-%COMP%] .dr-gallery-item[_ngcontent-%COMP%]{opacity:0}.dr-gallery-items[_ngcontent-%COMP%]{display:flex;position:relative;align-items:flex-end;will-change:transform}.dr-gallery-item[_ngcontent-%COMP%]{box-sizing:border-box;position:relative;flex-grow:1;padding:42px 24px;margin-top:-8px}.dr-gallery-item_fadein[_ngcontent-%COMP%]{animation:_ngcontent-%COMP%_fadeIn .3s ease-in .25s forwards}.dr-gallery-btn[_ngcontent-%COMP%]{position:absolute;top:50%;transform:translateY(-50%);z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;box-shadow:0 4px 4px #00000040}.dr-gallery-btn[_ngcontent-%COMP%] button[_ngcontent-%COMP%]{width:40px!important;height:40px!important}.dr-gallery-btn[_ngcontent-%COMP%] button[_ngcontent-%COMP%]:hover{border-radius:50%}.dr-gallery-btn_left[_ngcontent-%COMP%]{left:0}.dr-gallery-btn_right[_ngcontent-%COMP%]{right:0}@keyframes _ngcontent-%COMP%_fadeIn{0%{opacity:0}to{opacity:1}}"], changeDetection: 0 }); }
132
257
  }
133
258
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrGalleryComponent, [{
134
259
  type: Component,
135
- args: [{ selector: 'dr-gallery', imports: [CommonModule, DrInputsModule], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<dr-button class=\"dr-gallery-btn dr-gallery-btn_left\" (click)=\"prev()\" theme=\"icon\" [icon]=\"'dr-icon-arrow-left'\"> </dr-button>\n<div class=\"dr-gallery-caroousel\">\n <div class=\"dr-gallery-items\" [style.transition]=\"transition\" [style.transform]=\"transform\">\n <div\n *ngFor=\"let item of carouselItems; let i = index\"\n class=\"dr-gallery-item\"\n [style.transition]=\"transition\"\n [ngClass]=\"{ 'dr-gallery-item_active': centerIndex === i }\"\n [style]=\"getStyle()\">\n <ng-container *ngTemplateOutlet=\"template; context: { $implicit: item }\"></ng-container>\n </div>\n </div>\n</div>\n\n<dr-button\n class=\"dr-gallery-btn dr-gallery-btn_right\"\n (click)=\"next()\"\n [iconSize]=\"'24px'\"\n theme=\"icon\"\n [icon]=\"'dr-icon-arrow-right'\"></dr-button>\n", styles: [".dr-gallery-caroousel{display:block;position:relative;overflow:hidden}.dr-gallery-items{display:flex;position:relative;align-items:flex-end;will-change:transform}.dr-gallery-item{box-sizing:border-box;position:relative;padding:42px 24px;margin-top:-8px;flex-grow:1;width:100%;min-height:240px}.dr-gallery-item_active{transform:scale(1.2)}.dr-gallery-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;box-shadow:0 4px 4px #00000040}.dr-gallery-btn button{width:40px!important;height:40px!important}.dr-gallery-btn button:hover{border-radius:50%}.dr-gallery-btn_left{left:0}.dr-gallery-btn_right{right:0}\n"] }]
260
+ args: [{ selector: 'dr-gallery', imports: [CommonModule, DrInputsModule], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<dr-button\n *ngIf=\"!isOutsideBtns\"\n class=\"dr-gallery-btn dr-gallery-btn_left\"\n (click)=\"prev()\"\n theme=\"icon\"\n [icon]=\"'dr-icon-arrow-left'\">\n</dr-button>\n\n<div\n #carouselContainer\n class=\"dr-gallery-caroousel dr-gallery-caroousel_{{ modeType }}\"\n [class.dr-gallery-caroousel_fadein]=\"fadeIn\">\n <div class=\"dr-gallery-items\" [style.transition]=\"transition\" [style.transform]=\"transform\">\n <div\n #carouselItem\n *ngFor=\"let item of carouselItems; let i = index\"\n class=\"dr-gallery-item\"\n [style.transition]=\"transition\"\n [class.dr-gallery-item_active]=\"centerIndex === i\"\n [class.dr-gallery-item_fadein]=\"fadeIn && centerIndex === i + 1\"\n [ngStyle]=\"modeType === 'loop' ? getStyle() : {}\">\n <ng-container *ngTemplateOutlet=\"template; context: { $implicit: item }\"></ng-container>\n </div>\n </div>\n</div>\n\n<dr-button\n *ngIf=\"!isOutsideBtns\"\n class=\"dr-gallery-btn dr-gallery-btn_right\"\n (click)=\"next()\"\n [iconSize]=\"'24px'\"\n theme=\"icon\"\n [icon]=\"'dr-icon-arrow-right'\">\n</dr-button>\n", styles: [".dr-gallery-caroousel{display:block;position:relative;overflow:hidden}.dr-gallery-caroousel.dr-gallery-caroousel_loop .dr-gallery-item{width:100%;min-height:240px}.dr-gallery-caroousel.dr-gallery-caroousel_loop .dr-gallery-item_active{transform:scale(1.2)}.dr-gallery-caroousel.dr-gallery-caroousel_fadein .dr-gallery-item{opacity:0}.dr-gallery-items{display:flex;position:relative;align-items:flex-end;will-change:transform}.dr-gallery-item{box-sizing:border-box;position:relative;flex-grow:1;padding:42px 24px;margin-top:-8px}.dr-gallery-item_fadein{animation:fadeIn .3s ease-in .25s forwards}.dr-gallery-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;box-shadow:0 4px 4px #00000040}.dr-gallery-btn button{width:40px!important;height:40px!important}.dr-gallery-btn button:hover{border-radius:50%}.dr-gallery-btn_left{left:0}.dr-gallery-btn_right{right:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}\n"] }]
136
261
  }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { template: [{
137
262
  type: ContentChild,
138
263
  args: [TemplateRef]
264
+ }], modeType: [{
265
+ type: Input
266
+ }], isOutsideBtns: [{
267
+ type: Input
268
+ }], fadeIn: [{
269
+ type: Input
270
+ }], autoPlay: [{
271
+ type: Input
272
+ }], autoplayInterval: [{
273
+ type: Input
139
274
  }], items: [{
140
275
  type: Input
141
276
  }], itemsCount: [{
142
277
  type: Input
278
+ }], containerRef: [{
279
+ type: ViewChild,
280
+ args: ['carouselContainer']
281
+ }], itemElements: [{
282
+ type: ViewChildren,
283
+ args: ['carouselItem']
143
284
  }] }); })();
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-gallery.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-gallery/dr-gallery.component.ts","../../../../../projects/datarailsshared/src/lib/dr-gallery/dr-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    Input,\n    OnChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { take as _take, takeRight as _takeRight } from 'lodash';\nimport { DrInputsModule } from '../dr-inputs/dr-inputs.module';\n@Component({\n    selector: 'dr-gallery',\n    templateUrl: './dr-gallery.component.html',\n    styleUrls: ['./dr-gallery.component.scss'],\n    imports: [CommonModule, DrInputsModule],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrGalleryComponent<T = any> implements OnChanges {\n    @ContentChild(TemplateRef) template: TemplateRef<{ $implicit: T }>;\n    private _items: any[] = [];\n    private _itemsCount = 3;\n    readonly defaultTransition = '250ms ease-in-out';\n    readonly noTransition = '0ms';\n\n    @Input()\n    set items(value: any[]) {\n        if (value?.length) {\n            this._items = value;\n            this.initializeCarousel();\n        }\n    }\n\n    @Input() set itemsCount(value: number) {\n        if (!this.items?.length) {\n            this._itemsCount = value;\n            return;\n        }\n\n        this._itemsCount = value > this.items.length - 1 ? this.items.length : value;\n    }\n\n    get items(): any[] {\n        return this._items;\n    }\n\n    get itemsCount() {\n        return this._itemsCount;\n    }\n\n    get centerIndex(): number | null {\n        return this.itemsCount > 1 && this.itemsCount % 2 !== 0 ? this.activeIndex + Math.floor(this.itemsCount / 2) : null;\n    }\n\n    activeIndex = 0;\n    carouselItems: any[] = [];\n    transform = `translateX(0%)`;\n    transition = this.defaultTransition;\n\n    ngOnChanges() {\n        this.activeIndex = this.itemsCount;\n        this.initializeCarousel();\n        this.updateTransform();\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    private initializeCarousel() {\n        this.carouselItems = [..._takeRight(this.items, this.itemsCount), ...this.items, ..._take(this.items, this.itemsCount)];\n        this.updateTransform();\n    }\n\n    getStyle(): Partial<CSSStyleDeclaration> {\n        const percent = `calc(${100 / this.itemsCount}%)`;\n        return {\n            minWidth: percent,\n            maxWidth: percent,\n            flexBasis: percent,\n        };\n    }\n\n    prev() {\n        this.activeIndex--;\n        this.transition = this.defaultTransition;\n        this.updateTransform();\n\n        if (this.activeIndex <= 0) {\n            this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);\n        }\n    }\n\n    next() {\n        this.activeIndex++;\n        this.transition = this.defaultTransition;\n        this.updateTransform();\n\n        if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {\n            this.resetIndexAfterDelay(this.itemsCount);\n        }\n    }\n\n    private resetIndexAfterDelay(newIndex: number) {\n        setTimeout(() => {\n            this.transition = this.noTransition;\n            this.activeIndex = newIndex;\n            this.updateTransform(true);\n        }, 250);\n    }\n\n    private updateTransform(skipTransition = false) {\n        this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;\n        if (skipTransition) this.transition = this.noTransition;\n        this.cdr.markForCheck();\n    }\n}\n","<dr-button class=\"dr-gallery-btn dr-gallery-btn_left\" (click)=\"prev()\" theme=\"icon\" [icon]=\"'dr-icon-arrow-left'\"> </dr-button>\n<div class=\"dr-gallery-caroousel\">\n    <div class=\"dr-gallery-items\" [style.transition]=\"transition\" [style.transform]=\"transform\">\n        <div\n            *ngFor=\"let item of carouselItems; let i = index\"\n            class=\"dr-gallery-item\"\n            [style.transition]=\"transition\"\n            [ngClass]=\"{ 'dr-gallery-item_active': centerIndex === i }\"\n            [style]=\"getStyle()\">\n            <ng-container *ngTemplateOutlet=\"template; context: { $implicit: item }\"></ng-container>\n        </div>\n    </div>\n</div>\n\n<dr-button\n    class=\"dr-gallery-btn dr-gallery-btn_right\"\n    (click)=\"next()\"\n    [iconSize]=\"'24px'\"\n    theme=\"icon\"\n    [icon]=\"'dr-icon-arrow-right'\"></dr-button>\n"]}
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-gallery.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-gallery/dr-gallery.component.ts","../../../../../projects/datarailsshared/src/lib/dr-gallery/dr-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    Input,\n    OnDestroy,\n    QueryList,\n    TemplateRef,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport { take as _take, takeRight as _takeRight } from 'lodash';\nimport { DrInputsModule } from '../dr-inputs/dr-inputs.module';\n@Component({\n    selector: 'dr-gallery',\n    templateUrl: './dr-gallery.component.html',\n    styleUrls: ['./dr-gallery.component.scss'],\n    imports: [CommonModule, DrInputsModule],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrGalleryComponent<T = any> implements AfterViewInit, OnDestroy {\n    @ContentChild(TemplateRef) template!: TemplateRef<{ $implicit: T }>;\n\n    private _items: T[] = [];\n    private _itemsCount = 3;\n    private autoplayTimer: any;\n    readonly defaultTransition = '250ms ease-in-out';\n    readonly noTransition = '0ms';\n\n    @Input() modeType: 'loop' | 'dynamic' = 'loop';\n    @Input() isOutsideBtns = false;\n    @Input() fadeIn = false;\n    @Input() autoPlay = false;\n    @Input() autoplayInterval = 5000; //5 seconds\n\n    @Input()\n    set items(value: T[]) {\n        if (value?.length) {\n            this._items = value;\n            this.initializeCarousel();\n        }\n    }\n\n    @Input()\n    set itemsCount(value: number) {\n        if (!this.items?.length) {\n            this._itemsCount = value;\n            return;\n        }\n\n        this._itemsCount = value > this.items.length - 1 ? this.items.length : value;\n    }\n\n    get items(): T[] {\n        return this._items;\n    }\n\n    get itemsCount(): number {\n        return this._itemsCount;\n    }\n\n    get centerIndex(): number | null {\n        return this.itemsCount > 1 && this.itemsCount % 2 !== 0 ? this.activeIndex + Math.floor(this.itemsCount / 2) : null;\n    }\n\n    activeIndex = 0;\n    carouselItems: T[] = [];\n    transform = 'translateX(0%)';\n    transition = this.defaultTransition;\n\n    @ViewChild('carouselContainer') containerRef!: ElementRef<HTMLElement>;\n    @ViewChildren('carouselItem') itemElements!: QueryList<ElementRef<HTMLElement>>;\n    private itemOffsets: number[] = [];\n    private itemWidths: number[] = [];\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit() {\n        // Wait for initial render\n        setTimeout(() => {\n            this.calculateItemOffsets();\n            this.updateTransform();\n            if (this.autoPlay) {\n                this.startAutoplay();\n            }\n        });\n    }\n\n    ngOnDestroy() {\n        this.clearAutoplay();\n    }\n\n    private initializeCarousel() {\n        if (this.modeType === 'loop') {\n            this.carouselItems = [\n                ...this._items.slice(-this.itemsCount),\n                ...this._items,\n                ...this._items.slice(0, this.itemsCount),\n            ];\n            this.activeIndex = this.itemsCount;\n        } else {\n            this.carouselItems = [...this._items];\n            this.activeIndex = 0;\n        }\n\n        setTimeout(() => {\n            this.calculateItemOffsets();\n            this.updateTransform();\n        });\n    }\n\n    private calculateItemOffsets() {\n        this.itemOffsets = [];\n        this.itemWidths = [];\n\n        let offset = 0;\n        const elements = this.itemElements.toArray();\n\n        for (const el of elements) {\n            const width = el.nativeElement.offsetWidth;\n            this.itemOffsets.push(offset);\n            this.itemWidths.push(width);\n            offset += width;\n        }\n    }\n\n    getStyle(): Partial<CSSStyleDeclaration> {\n        const percent = `calc(${100 / this.itemsCount}%)`;\n        return {\n            minWidth: percent,\n            maxWidth: percent,\n            flexBasis: percent,\n        };\n    }\n\n    prev() {\n        if (this.modeType === 'loop') {\n            this.activeIndex--;\n            this.transition = this.defaultTransition;\n            this.updateTransform();\n\n            if (this.activeIndex <= 0) {\n                this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);\n            }\n        } else {\n            if (this.activeIndex > 0) {\n                this.activeIndex--;\n                this.updateTransform();\n            }\n        }\n    }\n\n    next() {\n        if (this.modeType === 'loop') {\n            this.activeIndex++;\n            this.transition = this.defaultTransition;\n            this.updateTransform();\n\n            if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {\n                this.resetIndexAfterDelay(this.itemsCount);\n            }\n        } else {\n            if (this.activeIndex + 1 < this.carouselItems.length) {\n                this.activeIndex++;\n                this.updateTransform();\n            } else {\n                this.activeIndex = 0;\n                this.updateTransform();\n            }\n        }\n    }\n\n    navigate(index: number) {\n        this.activeIndex = index;\n        this.updateTransform();\n        if (this.autoPlay) {\n            this.startAutoplay();\n        }\n    }\n\n    get canGoPrev() {\n        if (this.modeType === 'loop') return true;\n        return !!(this.activeIndex > 0);\n    }\n\n    get canGoNext() {\n        if (this.modeType === 'loop') return true;\n        const containerWidth = this.containerRef?.nativeElement?.offsetWidth || 0;\n        const currentOffset = this.itemOffsets[this.activeIndex] || 0;\n        const lastIndex = this.itemOffsets.length - 1;\n        const totalContentWidth = this.itemOffsets[lastIndex] + this.itemWidths[lastIndex];\n\n        return currentOffset + containerWidth < totalContentWidth - 1;\n    }\n\n    private resetIndexAfterDelay(newIndex: number) {\n        setTimeout(() => {\n            this.transition = this.noTransition;\n            this.activeIndex = newIndex;\n            this.updateTransform(true);\n        }, 250);\n    }\n\n    private updateTransform(skipTransition = false) {\n        if (this.modeType === 'loop') {\n            this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;\n        } else {\n            const offset = this.itemOffsets[this.activeIndex] || 0;\n            this.transform = `translateX(-${offset}px)`;\n        }\n        if (skipTransition) this.transition = this.noTransition;\n        else this.transition = this.defaultTransition;\n        this.cdr.markForCheck();\n    }\n\n    private startAutoplay() {\n        this.clearAutoplay();\n        this.autoplayTimer = setInterval(() => {\n            this.next();\n        }, this.autoplayInterval);\n    }\n\n    private clearAutoplay() {\n        if (this.autoplayTimer) {\n            clearInterval(this.autoplayTimer);\n            this.autoplayTimer = null;\n        }\n    }\n}\n","<dr-button\n    *ngIf=\"!isOutsideBtns\"\n    class=\"dr-gallery-btn dr-gallery-btn_left\"\n    (click)=\"prev()\"\n    theme=\"icon\"\n    [icon]=\"'dr-icon-arrow-left'\">\n</dr-button>\n\n<div\n    #carouselContainer\n    class=\"dr-gallery-caroousel dr-gallery-caroousel_{{ modeType }}\"\n    [class.dr-gallery-caroousel_fadein]=\"fadeIn\">\n    <div class=\"dr-gallery-items\" [style.transition]=\"transition\" [style.transform]=\"transform\">\n        <div\n            #carouselItem\n            *ngFor=\"let item of carouselItems; let i = index\"\n            class=\"dr-gallery-item\"\n            [style.transition]=\"transition\"\n            [class.dr-gallery-item_active]=\"centerIndex === i\"\n            [class.dr-gallery-item_fadein]=\"fadeIn && centerIndex === i + 1\"\n            [ngStyle]=\"modeType === 'loop' ? getStyle() : {}\">\n            <ng-container *ngTemplateOutlet=\"template; context: { $implicit: item }\"></ng-container>\n        </div>\n    </div>\n</div>\n\n<dr-button\n    *ngIf=\"!isOutsideBtns\"\n    class=\"dr-gallery-btn dr-gallery-btn_right\"\n    (click)=\"next()\"\n    [iconSize]=\"'24px'\"\n    theme=\"icon\"\n    [icon]=\"'dr-icon-arrow-right'\">\n</dr-button>\n"]}