@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.
@@ -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 (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 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));
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 = `translateX(0%)`;
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
- this.carouselItems = [..._takeRight(this.items, this.itemsCount), ...this.items, ..._take(this.items, this.itemsCount)];
68
- this.updateTransform();
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.activeIndex--;
80
- this.transition = this.defaultTransition;
81
- this.updateTransform();
82
- if (this.activeIndex <= 0) {
83
- this.resetIndexAfterDelay(this.carouselItems.length - this.items.length);
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.activeIndex++;
88
- this.transition = this.defaultTransition;
89
- this.updateTransform();
90
- if (this.activeIndex + this.itemsCount > this.carouselItems.length - 1) {
91
- this.resetIndexAfterDelay(this.itemsCount);
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
- this.transform = `translateX(${-100 * (this.activeIndex / this.itemsCount)}%)`;
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
- } }, 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);
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.ɵɵelementStart(4, "dr-button", 4);
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("icon", "dr-icon-arrow-left");
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("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 }); }
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 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"] }]
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"]}