@datarailsshared/datarailsshared 1.6.73 → 1.6.75
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/datarailsshared-datarailsshared-1.6.75.tgz +0 -0
- package/esm2022/lib/dr-gallery/dr-gallery.component.mjs +155 -49
- package/fesm2022/datarailsshared-datarailsshared.mjs +202 -95
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-gallery/dr-gallery.component.d.ts +17 -7
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.6.73.tgz +0 -0
|
Binary file
|
|
@@ -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
|
-
|
|
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
|
|
12
|
-
const
|
|
13
|
-
function
|
|
14
|
-
|
|
15
|
-
i0.ɵɵ
|
|
20
|
+
const _c2 = function (a0) { return { "dr-gallery-item_active": a0 }; };
|
|
21
|
+
const _c3 = function () { return {}; };
|
|
22
|
+
const _c4 = function (a0) { return { $implicit: a0 }; };
|
|
23
|
+
function DrGalleryComponent_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
24
|
+
i0.ɵɵelementStart(0, "div", 6, 7);
|
|
25
|
+
i0.ɵɵtemplate(2, DrGalleryComponent_div_4_ng_container_2_Template, 1, 0, "ng-container", 8);
|
|
16
26
|
i0.ɵɵelementEnd();
|
|
17
27
|
} if (rf & 2) {
|
|
18
|
-
const
|
|
19
|
-
const
|
|
20
|
-
const
|
|
21
|
-
i0.ɵɵ
|
|
22
|
-
i0.ɵɵ
|
|
23
|
-
i0.ɵɵ
|
|
24
|
-
i0.ɵɵ
|
|
25
|
-
|
|
28
|
+
const item_r6 = ctx.$implicit;
|
|
29
|
+
const i_r7 = ctx.index;
|
|
30
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
31
|
+
i0.ɵɵstyleProp("transition", ctx_r2.transition);
|
|
32
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(6, _c2, ctx_r2.centerIndex === i_r7))("ngStyle", ctx_r2.modeType === "loop" ? ctx_r2.getStyle() : i0.ɵɵpureFunction0(8, _c3));
|
|
33
|
+
i0.ɵɵadvance(2);
|
|
34
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r2.template)("ngTemplateOutletContext", i0.ɵɵpureFunction1(9, _c4, 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()); });
|
|
40
|
+
i0.ɵɵelementEnd();
|
|
41
|
+
} if (rf & 2) {
|
|
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,57 @@ 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;
|
|
61
75
|
this.activeIndex = 0;
|
|
62
76
|
this.carouselItems = [];
|
|
63
|
-
this.transform =
|
|
77
|
+
this.transform = 'translateX(0%)';
|
|
64
78
|
this.transition = this.defaultTransition;
|
|
79
|
+
this.itemOffsets = [];
|
|
80
|
+
this.itemWidths = [];
|
|
81
|
+
}
|
|
82
|
+
ngAfterViewInit() {
|
|
83
|
+
// Wait for initial render
|
|
84
|
+
setTimeout(() => {
|
|
85
|
+
this.calculateItemOffsets();
|
|
86
|
+
this.updateTransform();
|
|
87
|
+
});
|
|
65
88
|
}
|
|
66
89
|
initializeCarousel() {
|
|
67
|
-
|
|
68
|
-
|
|
90
|
+
if (this.modeType === 'loop') {
|
|
91
|
+
this.carouselItems = [
|
|
92
|
+
...this._items.slice(-this.itemsCount),
|
|
93
|
+
...this._items,
|
|
94
|
+
...this._items.slice(0, this.itemsCount),
|
|
95
|
+
];
|
|
96
|
+
this.activeIndex = this.itemsCount;
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
this.carouselItems = [...this._items];
|
|
100
|
+
this.activeIndex = 0;
|
|
101
|
+
}
|
|
102
|
+
setTimeout(() => {
|
|
103
|
+
this.calculateItemOffsets();
|
|
104
|
+
this.updateTransform();
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
calculateItemOffsets() {
|
|
108
|
+
this.itemOffsets = [];
|
|
109
|
+
this.itemWidths = [];
|
|
110
|
+
let offset = 0;
|
|
111
|
+
const elements = this.itemElements.toArray();
|
|
112
|
+
for (const el of elements) {
|
|
113
|
+
const width = el.nativeElement.offsetWidth;
|
|
114
|
+
this.itemOffsets.push(offset);
|
|
115
|
+
this.itemWidths.push(width);
|
|
116
|
+
offset += width;
|
|
117
|
+
}
|
|
69
118
|
}
|
|
70
119
|
getStyle() {
|
|
71
120
|
const percent = `calc(${100 / this.itemsCount}%)`;
|
|
@@ -76,20 +125,54 @@ export class DrGalleryComponent {
|
|
|
76
125
|
};
|
|
77
126
|
}
|
|
78
127
|
prev() {
|
|
79
|
-
this.
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
128
|
+
if (this.modeType === 'loop') {
|
|
129
|
+
this.activeIndex--;
|
|
130
|
+
this.transition = this.defaultTransition;
|
|
131
|
+
this.updateTransform();
|
|
132
|
+
if (this.activeIndex <= 0) {
|
|
133
|
+
this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
if (this.activeIndex > 0) {
|
|
138
|
+
this.activeIndex--;
|
|
139
|
+
this.updateTransform();
|
|
140
|
+
}
|
|
84
141
|
}
|
|
85
142
|
}
|
|
86
143
|
next() {
|
|
87
|
-
this.
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
this.
|
|
144
|
+
if (this.modeType === 'loop') {
|
|
145
|
+
this.activeIndex++;
|
|
146
|
+
this.transition = this.defaultTransition;
|
|
147
|
+
this.updateTransform();
|
|
148
|
+
if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {
|
|
149
|
+
this.resetIndexAfterDelay(this.itemsCount);
|
|
150
|
+
}
|
|
92
151
|
}
|
|
152
|
+
else {
|
|
153
|
+
if (this.activeIndex + 1 < this.carouselItems.length) {
|
|
154
|
+
this.activeIndex++;
|
|
155
|
+
this.updateTransform();
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
navigate(index) {
|
|
160
|
+
this.activeIndex = index;
|
|
161
|
+
this.updateTransform();
|
|
162
|
+
}
|
|
163
|
+
get canGoPrev() {
|
|
164
|
+
if (this.modeType === 'loop')
|
|
165
|
+
return true;
|
|
166
|
+
return !!(this.activeIndex > 0);
|
|
167
|
+
}
|
|
168
|
+
get canGoNext() {
|
|
169
|
+
if (this.modeType === 'loop')
|
|
170
|
+
return true;
|
|
171
|
+
const containerWidth = this.containerRef?.nativeElement?.offsetWidth || 0;
|
|
172
|
+
const currentOffset = this.itemOffsets[this.activeIndex] || 0;
|
|
173
|
+
const lastIndex = this.itemOffsets.length - 1;
|
|
174
|
+
const totalContentWidth = this.itemOffsets[lastIndex] + this.itemWidths[lastIndex];
|
|
175
|
+
return currentOffset + containerWidth < totalContentWidth - 1;
|
|
93
176
|
}
|
|
94
177
|
resetIndexAfterDelay(newIndex) {
|
|
95
178
|
setTimeout(() => {
|
|
@@ -99,9 +182,17 @@ export class DrGalleryComponent {
|
|
|
99
182
|
}, 250);
|
|
100
183
|
}
|
|
101
184
|
updateTransform(skipTransition = false) {
|
|
102
|
-
|
|
185
|
+
if (this.modeType === 'loop') {
|
|
186
|
+
this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
const offset = this.itemOffsets[this.activeIndex] || 0;
|
|
190
|
+
this.transform = `translateX(-${offset}px)`;
|
|
191
|
+
}
|
|
103
192
|
if (skipTransition)
|
|
104
193
|
this.transition = this.noTransition;
|
|
194
|
+
else
|
|
195
|
+
this.transition = this.defaultTransition;
|
|
105
196
|
this.cdr.markForCheck();
|
|
106
197
|
}
|
|
107
198
|
/** @nocollapse */ static { this.ɵfac = function DrGalleryComponent_Factory(t) { return new (t || DrGalleryComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
|
|
@@ -110,35 +201,50 @@ export class DrGalleryComponent {
|
|
|
110
201
|
} if (rf & 2) {
|
|
111
202
|
let _t;
|
|
112
203
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.template = _t.first);
|
|
113
|
-
} },
|
|
114
|
-
i0.ɵɵ
|
|
115
|
-
i0.ɵɵ
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
i0.ɵɵ
|
|
204
|
+
} }, viewQuery: function DrGalleryComponent_Query(rf, ctx) { if (rf & 1) {
|
|
205
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
206
|
+
i0.ɵɵviewQuery(_c1, 5);
|
|
207
|
+
} if (rf & 2) {
|
|
208
|
+
let _t;
|
|
209
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.containerRef = _t.first);
|
|
210
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.itemElements = _t);
|
|
211
|
+
} }, inputs: { modeType: "modeType", isOutsideBtns: "isOutsideBtns", items: "items", itemsCount: "itemsCount" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 10, 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", "ngClass", "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, "ngClass", "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) {
|
|
212
|
+
i0.ɵɵtemplate(0, DrGalleryComponent_dr_button_0_Template, 1, 1, "dr-button", 0);
|
|
213
|
+
i0.ɵɵelementStart(1, "div", null, 1)(3, "div", 2);
|
|
214
|
+
i0.ɵɵtemplate(4, DrGalleryComponent_div_4_Template, 3, 11, "div", 3);
|
|
119
215
|
i0.ɵɵelementEnd()();
|
|
120
|
-
i0.ɵɵ
|
|
121
|
-
i0.ɵɵlistener("click", function DrGalleryComponent_Template_dr_button_click_4_listener() { return ctx.next(); });
|
|
122
|
-
i0.ɵɵelementEnd();
|
|
216
|
+
i0.ɵɵtemplate(5, DrGalleryComponent_dr_button_5_Template, 1, 2, "dr-button", 4);
|
|
123
217
|
} if (rf & 2) {
|
|
124
|
-
i0.ɵɵproperty("
|
|
218
|
+
i0.ɵɵproperty("ngIf", !ctx.isOutsideBtns);
|
|
219
|
+
i0.ɵɵadvance(1);
|
|
220
|
+
i0.ɵɵclassMapInterpolate1("dr-gallery-caroousel dr-gallery-caroousel_", ctx.modeType, "");
|
|
125
221
|
i0.ɵɵadvance(2);
|
|
126
222
|
i0.ɵɵstyleProp("transition", ctx.transition)("transform", ctx.transform);
|
|
127
223
|
i0.ɵɵadvance(1);
|
|
128
224
|
i0.ɵɵproperty("ngForOf", ctx.carouselItems);
|
|
129
225
|
i0.ɵɵadvance(1);
|
|
130
|
-
i0.ɵɵproperty("
|
|
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
|
|
226
|
+
i0.ɵɵproperty("ngIf", !ctx.isOutsideBtns);
|
|
227
|
+
} }, dependencies: [CommonModule, i1.NgClass, 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-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}.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}.dr-gallery-caroousel_loop[_ngcontent-%COMP%] .dr-gallery-item[_ngcontent-%COMP%]{width:100%;min-height:240px}.dr-gallery-caroousel_loop[_ngcontent-%COMP%] .dr-gallery-item_active[_ngcontent-%COMP%]{transform:scale(1.2)}"], changeDetection: 0 }); }
|
|
132
228
|
}
|
|
133
229
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrGalleryComponent, [{
|
|
134
230
|
type: Component,
|
|
135
|
-
args: [{ selector: 'dr-gallery', imports: [CommonModule, DrInputsModule], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<dr-button
|
|
231
|
+
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 #carouselContainer class=\"dr-gallery-caroousel dr-gallery-caroousel_{{ modeType }}\">\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 [ngClass]=\"{ 'dr-gallery-item_active': centerIndex === i }\"\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-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}.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}.dr-gallery-caroousel_loop .dr-gallery-item{width:100%;min-height:240px}.dr-gallery-caroousel_loop .dr-gallery-item_active{transform:scale(1.2)}\n"] }]
|
|
136
232
|
}], function () { return [{ type: i0.ChangeDetectorRef }]; }, { template: [{
|
|
137
233
|
type: ContentChild,
|
|
138
234
|
args: [TemplateRef]
|
|
235
|
+
}], modeType: [{
|
|
236
|
+
type: Input
|
|
237
|
+
}], isOutsideBtns: [{
|
|
238
|
+
type: Input
|
|
139
239
|
}], items: [{
|
|
140
240
|
type: Input
|
|
141
241
|
}], itemsCount: [{
|
|
142
242
|
type: Input
|
|
243
|
+
}], containerRef: [{
|
|
244
|
+
type: ViewChild,
|
|
245
|
+
args: ['carouselContainer']
|
|
246
|
+
}], itemElements: [{
|
|
247
|
+
type: ViewChildren,
|
|
248
|
+
args: ['carouselItem']
|
|
143
249
|
}] }); })();
|
|
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"]}
|
|
250
|
+
//# 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    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> {\n    @ContentChild(TemplateRef) template!: TemplateRef<{ $implicit: T }>;\n\n    private _items: T[] = [];\n    private _itemsCount = 3;\n    readonly defaultTransition = '250ms ease-in-out';\n    readonly noTransition = '0ms';\n\n    @Input() modeType: 'loop' | 'dynamic' = 'loop';\n    @Input() isOutsideBtns = false;\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        });\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            }\n        }\n    }\n\n    navigate(index: number) {\n        this.activeIndex = index;\n        this.updateTransform();\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","<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 #carouselContainer class=\"dr-gallery-caroousel dr-gallery-caroousel_{{ modeType }}\">\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            [ngClass]=\"{ 'dr-gallery-item_active': centerIndex === i }\"\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"]}
|