@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.
- package/datarailsshared-datarailsshared-1.6.77.tgz +0 -0
- package/esm2022/lib/dr-gallery/dr-gallery.component.mjs +189 -48
- package/fesm2022/datarailsshared-datarailsshared.mjs +226 -84
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-gallery/dr-gallery.component.d.ts +24 -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
|
-
i0.ɵɵelementStart(0, "div",
|
|
15
|
-
i0.ɵɵtemplate(
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
68
|
-
|
|
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.
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
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.
|
|
88
|
-
|
|
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.
|
|
91
|
-
this.
|
|
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
|
-
|
|
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
|
-
} },
|
|
114
|
-
i0.ɵɵ
|
|
115
|
-
i0.ɵɵ
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
i0.ɵɵ
|
|
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.ɵɵ
|
|
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("
|
|
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("
|
|
131
|
-
} }, dependencies: [CommonModule, i1.
|
|
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
|
|
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"]}
|