@datarailsshared/datarailsshared 1.5.572 → 1.5.576

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.
@@ -0,0 +1,380 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, } from '@angular/core';
2
+ import { DomSanitizer } from '@angular/platform-browser';
3
+ import { IMAGE_TYPES } from '../../models/chat';
4
+ import { trigger, state, style, transition, animate, query, animateChild } from '@angular/animations';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/platform-browser";
7
+ import * as i2 from "@angular/forms";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "../../dr-inputs/button/button.component";
10
+ import * as i5 from "../../directives/click-outside/click-outside.directive";
11
+ import * as i6 from "../dr-dot-flashing/dr-dot-flashing.component";
12
+ const _c0 = ["textAreaElement"];
13
+ function DrChatFormWithHistoryComponent_div_2_div_1_Template(rf, ctx) { if (rf & 1) {
14
+ const _r11 = i0.ɵɵgetCurrentView();
15
+ i0.ɵɵelementStart(0, "div", 18);
16
+ i0.ɵɵelement(1, "i", 19);
17
+ i0.ɵɵelementStart(2, "div", 20);
18
+ i0.ɵɵtext(3);
19
+ i0.ɵɵelementEnd();
20
+ i0.ɵɵelementStart(4, "i", 21);
21
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_div_2_div_1_Template_i_click_4_listener() { const restoredCtx = i0.ɵɵrestoreView(_r11); const file_r9 = restoredCtx.$implicit; const ctx_r10 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r10.removeFile(file_r9)); });
22
+ i0.ɵɵelementEnd()();
23
+ } if (rf & 2) {
24
+ const file_r9 = ctx.$implicit;
25
+ i0.ɵɵadvance(3);
26
+ i0.ɵɵtextInterpolate(file_r9.name);
27
+ } }
28
+ function DrChatFormWithHistoryComponent_div_2_Template(rf, ctx) { if (rf & 1) {
29
+ i0.ɵɵelementStart(0, "div", 16);
30
+ i0.ɵɵtemplate(1, DrChatFormWithHistoryComponent_div_2_div_1_Template, 5, 1, "div", 17);
31
+ i0.ɵɵelementEnd();
32
+ } if (rf & 2) {
33
+ const ctx_r0 = i0.ɵɵnextContext();
34
+ i0.ɵɵadvance(1);
35
+ i0.ɵɵproperty("ngForOf", ctx_r0.droppedFiles);
36
+ } }
37
+ function DrChatFormWithHistoryComponent_i_13_Template(rf, ctx) { if (rf & 1) {
38
+ const _r13 = i0.ɵɵgetCurrentView();
39
+ i0.ɵɵelementStart(0, "i", 22);
40
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_i_13_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r12.sendMessage($event)); });
41
+ i0.ɵɵelementEnd();
42
+ } if (rf & 2) {
43
+ const ctx_r3 = i0.ɵɵnextContext();
44
+ const _r1 = i0.ɵɵreference(5);
45
+ i0.ɵɵstyleMap(ctx_r3.getSendButtonPosition(_r1));
46
+ } }
47
+ function DrChatFormWithHistoryComponent_i_14_Template(rf, ctx) { if (rf & 1) {
48
+ const _r15 = i0.ɵɵgetCurrentView();
49
+ i0.ɵɵelementStart(0, "i", 23);
50
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_i_14_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r14 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r14.sendMessage($event)); });
51
+ i0.ɵɵelementEnd();
52
+ } }
53
+ function DrChatFormWithHistoryComponent_dr_dot_flashing_15_Template(rf, ctx) { if (rf & 1) {
54
+ i0.ɵɵelement(0, "dr-dot-flashing", 24);
55
+ } }
56
+ function DrChatFormWithHistoryComponent_dr_button_16_Template(rf, ctx) { if (rf & 1) {
57
+ const _r17 = i0.ɵɵgetCurrentView();
58
+ i0.ɵɵelementStart(0, "dr-button", 25);
59
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_dr_button_16_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r17); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.abortMessage()); });
60
+ i0.ɵɵtext(1, "Stop generating");
61
+ i0.ɵɵelementEnd();
62
+ } }
63
+ function DrChatFormWithHistoryComponent_ng_container_17_Template(rf, ctx) { if (rf & 1) {
64
+ const _r19 = i0.ɵɵgetCurrentView();
65
+ i0.ɵɵelementContainerStart(0);
66
+ i0.ɵɵelementStart(1, "div", 26);
67
+ i0.ɵɵlistener("clickOutside", function DrChatFormWithHistoryComponent_ng_container_17_Template_div_clickOutside_1_listener() { i0.ɵɵrestoreView(_r19); const ctx_r18 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r18.closeHistory()); });
68
+ i0.ɵɵprojection(2);
69
+ i0.ɵɵelementEnd();
70
+ i0.ɵɵelementContainerEnd();
71
+ } if (rf & 2) {
72
+ const ctx_r7 = i0.ɵɵnextContext();
73
+ i0.ɵɵadvance(1);
74
+ i0.ɵɵproperty("@dropdownAnimation", ctx_r7.isShowedHistory ? "visible" : "hidden")("exclude", ".dr-icon-history");
75
+ } }
76
+ const _c1 = function (a0) { return { height: a0 }; };
77
+ const _c2 = function (a0, a1) { return { value: a0, params: a1 }; };
78
+ const _c3 = function (a0, a1, a2) { return { "message-row__input--focused": a0, "message-row__input--filled": a1, "showed-dropdown": a2 }; };
79
+ const _c4 = ["*"];
80
+ export class DrChatFormWithHistoryComponent {
81
+ constructor(cdr, domSanitizer) {
82
+ this.cdr = cdr;
83
+ this.domSanitizer = domSanitizer;
84
+ this._textareaInitialHeight = true;
85
+ this.inputFocus = false;
86
+ this.inputHover = false;
87
+ this.droppedFiles = [];
88
+ this.isShowedHistory = false;
89
+ this.isChatMode = false;
90
+ /**
91
+ * Predefined message text
92
+ *
93
+ * @type {string}
94
+ */
95
+ this.message = '';
96
+ /**
97
+ * Message placeholder text
98
+ *
99
+ * @type {string}
100
+ */
101
+ this.messagePlaceholder = 'Type a message';
102
+ /**
103
+ * Show send button
104
+ *
105
+ * @type {boolean}
106
+ */
107
+ this.dropFiles = false;
108
+ /**
109
+ * File drop placeholder text
110
+ *
111
+ * @type {string}
112
+ */
113
+ this.dropFilePlaceholder = 'Drop file to send';
114
+ /**
115
+ * Parameter to check is send message function available
116
+ *
117
+ * @type {boolean}
118
+ */
119
+ this.waitForReply = false;
120
+ /**
121
+ * Parameter to check is send message function available
122
+ *
123
+ * @type {boolean}
124
+ */
125
+ this.showDisabledButtonInsteadOfDotFlashing = false;
126
+ /**
127
+ *
128
+ * @type {EventEmitter<{ message: string, files: File[] }>}
129
+ */
130
+ this.send = new EventEmitter();
131
+ this.abort = new EventEmitter();
132
+ /**
133
+ * Emits when message input value has been changed
134
+ *
135
+ * @type {EventEmitter<string>}
136
+ */
137
+ this.inputChange = new EventEmitter();
138
+ this.fileOver = false;
139
+ }
140
+ onDrop(event) {
141
+ if (this.dropFiles) {
142
+ event.preventDefault();
143
+ event.stopPropagation();
144
+ this.fileOver = false;
145
+ if (event.dataTransfer?.files) {
146
+ for (const file of event.dataTransfer.files) {
147
+ const res = file;
148
+ if (IMAGE_TYPES.includes(file.type)) {
149
+ const fr = new FileReader();
150
+ fr.onload = (e) => {
151
+ res.src = e.target.result;
152
+ res.urlStyle = this.domSanitizer.bypassSecurityTrustStyle(`url(${res.src})`);
153
+ this.cdr.detectChanges();
154
+ };
155
+ fr.readAsDataURL(file);
156
+ }
157
+ this.droppedFiles.push(res);
158
+ }
159
+ }
160
+ }
161
+ }
162
+ removeFile(file) {
163
+ const index = this.droppedFiles.indexOf(file);
164
+ if (index >= 0) {
165
+ this.droppedFiles.splice(index, 1);
166
+ }
167
+ }
168
+ onDragOver(event) {
169
+ event.preventDefault();
170
+ event.stopPropagation();
171
+ if (this.dropFiles) {
172
+ this.fileOver = true;
173
+ }
174
+ }
175
+ onDragLeave(event) {
176
+ event.preventDefault();
177
+ event.stopPropagation();
178
+ if (this.dropFiles) {
179
+ this.fileOver = false;
180
+ }
181
+ }
182
+ sendMessage($event) {
183
+ if (!$event || !$event.shiftKey) {
184
+ $event && $event.preventDefault();
185
+ if (this.waitForReply) {
186
+ return;
187
+ }
188
+ if (this.droppedFiles.length || String(this.message).trim().length) {
189
+ this._textareaInitialHeight = true;
190
+ this.send.emit({ message: this.message, files: this.droppedFiles });
191
+ this.message = '';
192
+ this.droppedFiles = [];
193
+ this.cdr.markForCheck();
194
+ }
195
+ }
196
+ }
197
+ abortMessage() {
198
+ this.abort.emit();
199
+ }
200
+ onModelChange(value) {
201
+ this._textareaInitialHeight = false;
202
+ this.inputChange.emit(value);
203
+ }
204
+ getTextAreaHeight(textAreaElement) {
205
+ if (this._textareaInitialHeight) {
206
+ textAreaElement.style.height = '48px';
207
+ }
208
+ else {
209
+ textAreaElement.style.height = 'auto';
210
+ textAreaElement.style.height = textAreaElement.scrollHeight + 'px';
211
+ }
212
+ return `${textAreaElement.style.height}`;
213
+ }
214
+ getSendButtonPosition(textAreaElement) {
215
+ return `top: calc(${this.getTextAreaHeight(textAreaElement)} - var(--send-button-offset));`;
216
+ }
217
+ showHistory() {
218
+ this.isShowedHistory = !this.isShowedHistory;
219
+ }
220
+ closeHistory() {
221
+ this.isShowedHistory = false;
222
+ this.cdr.markForCheck();
223
+ }
224
+ onFileSelected(event) {
225
+ const input = event.target;
226
+ }
227
+ /** @nocollapse */ static { this.ɵfac = function DrChatFormWithHistoryComponent_Factory(t) { return new (t || DrChatFormWithHistoryComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DomSanitizer)); }; }
228
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrChatFormWithHistoryComponent, selectors: [["dr-chat-form-with-history"]], viewQuery: function DrChatFormWithHistoryComponent_Query(rf, ctx) { if (rf & 1) {
229
+ i0.ɵɵviewQuery(_c0, 5);
230
+ } if (rf & 2) {
231
+ let _t;
232
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.textAreaElementRef = _t.first);
233
+ } }, hostVars: 2, hostBindings: function DrChatFormWithHistoryComponent_HostBindings(rf, ctx) { if (rf & 1) {
234
+ i0.ɵɵlistener("drop", function DrChatFormWithHistoryComponent_drop_HostBindingHandler($event) { return ctx.onDrop($event); })("dragover", function DrChatFormWithHistoryComponent_dragover_HostBindingHandler($event) { return ctx.onDragOver($event); })("dragleave", function DrChatFormWithHistoryComponent_dragleave_HostBindingHandler($event) { return ctx.onDragLeave($event); });
235
+ } if (rf & 2) {
236
+ i0.ɵɵclassProp("file-over", ctx.fileOver);
237
+ } }, inputs: { isChatMode: "isChatMode", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDisabledButtonInsteadOfDotFlashing: "showDisabledButtonInsteadOfDotFlashing" }, outputs: { send: "send", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c4, decls: 18, vars: 23, consts: [[1, "message-row"], [1, "message-row__input", 3, "ngClass"], ["class", "dropped-files", 4, "ngIf"], [1, "message-row__input-textarea-wrap"], ["type", "text", 3, "ngModel", "rows", "placeholder", "focus", "blur", "mouseenter", "mouseleave", "ngModelChange", "keydown.enter"], ["textAreaElement", ""], [1, "message-input-tmp"], ["type", "file", "hidden", "", "multiple", "", 3, "change"], ["fileInput", ""], [1, "dr-icon-history", 3, "click"], [1, "dr-icon-attachment", 3, "click"], ["class", "dr-icon-send-arrow-up send-button", 3, "style", "click", 4, "ngIf"], ["class", "dr-icon-send-arrow-up send-button-disabled", 3, "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 4, "ngIf"], ["theme", "ghost", "class", "abort-button", 3, "click", 4, "ngIf"], [4, "ngIf"], [1, "dropped-files"], ["class", "dropped-files__item", 4, "ngFor", "ngForOf"], [1, "dropped-files__item"], [1, "dr-icon-file"], [1, "dropped-files__item-name"], [1, "dr-icon-noty-error", "dropped-files__item-remove", 3, "click"], [1, "dr-icon-send-arrow-up", "send-button", 3, "click"], [1, "dr-icon-send-arrow-up", "send-button-disabled", 3, "click"], [1, "wait-reply-dot-flashing"], ["theme", "ghost", 1, "abort-button", 3, "click"], [1, "history-dropdown", 3, "exclude", "clickOutside"]], template: function DrChatFormWithHistoryComponent_Template(rf, ctx) { if (rf & 1) {
238
+ const _r20 = i0.ɵɵgetCurrentView();
239
+ i0.ɵɵprojectionDef();
240
+ i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
241
+ i0.ɵɵtemplate(2, DrChatFormWithHistoryComponent_div_2_Template, 2, 1, "div", 2);
242
+ i0.ɵɵelementStart(3, "div", 3)(4, "textarea", 4, 5);
243
+ i0.ɵɵlistener("focus", function DrChatFormWithHistoryComponent_Template_textarea_focus_4_listener() { return ctx.inputFocus = true; })("blur", function DrChatFormWithHistoryComponent_Template_textarea_blur_4_listener() { return ctx.inputFocus = false; })("mouseenter", function DrChatFormWithHistoryComponent_Template_textarea_mouseenter_4_listener() { return ctx.inputHover = true; })("mouseleave", function DrChatFormWithHistoryComponent_Template_textarea_mouseleave_4_listener() { return ctx.inputHover = false; })("ngModelChange", function DrChatFormWithHistoryComponent_Template_textarea_ngModelChange_4_listener($event) { return ctx.message = $event; })("ngModelChange", function DrChatFormWithHistoryComponent_Template_textarea_ngModelChange_4_listener($event) { return ctx.onModelChange($event); })("keydown.enter", function DrChatFormWithHistoryComponent_Template_textarea_keydown_enter_4_listener($event) { return ctx.sendMessage($event); });
244
+ i0.ɵɵtext(6, " ");
245
+ i0.ɵɵelementEnd();
246
+ i0.ɵɵelementStart(7, "div", 6);
247
+ i0.ɵɵtext(8);
248
+ i0.ɵɵelementEnd();
249
+ i0.ɵɵelementStart(9, "input", 7, 8);
250
+ i0.ɵɵlistener("change", function DrChatFormWithHistoryComponent_Template_input_change_9_listener($event) { return ctx.onFileSelected($event); });
251
+ i0.ɵɵelementEnd();
252
+ i0.ɵɵelementStart(11, "i", 9);
253
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_Template_i_click_11_listener() { return ctx.showHistory(); });
254
+ i0.ɵɵelementEnd();
255
+ i0.ɵɵelementStart(12, "i", 10);
256
+ i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_Template_i_click_12_listener() { i0.ɵɵrestoreView(_r20); const _r2 = i0.ɵɵreference(10); return i0.ɵɵresetView(_r2.click()); });
257
+ i0.ɵɵelementEnd();
258
+ i0.ɵɵtemplate(13, DrChatFormWithHistoryComponent_i_13_Template, 1, 2, "i", 11);
259
+ i0.ɵɵtemplate(14, DrChatFormWithHistoryComponent_i_14_Template, 1, 0, "i", 12);
260
+ i0.ɵɵtemplate(15, DrChatFormWithHistoryComponent_dr_dot_flashing_15_Template, 1, 0, "dr-dot-flashing", 13);
261
+ i0.ɵɵtemplate(16, DrChatFormWithHistoryComponent_dr_button_16_Template, 2, 0, "dr-button", 14);
262
+ i0.ɵɵelementEnd();
263
+ i0.ɵɵtemplate(17, DrChatFormWithHistoryComponent_ng_container_17_Template, 3, 2, "ng-container", 15);
264
+ i0.ɵɵelementEnd()();
265
+ } if (rf & 2) {
266
+ const _r1 = i0.ɵɵreference(5);
267
+ i0.ɵɵadvance(1);
268
+ i0.ɵɵproperty("@containerHeightAnimation", i0.ɵɵpureFunction2(16, _c2, ctx.showHistory ? "expanded" : "collapsed", i0.ɵɵpureFunction1(14, _c1, ctx.getTextAreaHeight(_r1))))("ngClass", i0.ɵɵpureFunction3(19, _c3, ctx.inputFocus, !!(ctx.message == null ? null : ctx.message.length), ctx.isShowedHistory));
269
+ i0.ɵɵadvance(1);
270
+ i0.ɵɵproperty("ngIf", ctx.droppedFiles == null ? null : ctx.droppedFiles.length);
271
+ i0.ɵɵadvance(2);
272
+ i0.ɵɵstyleMap(ctx.getTextAreaHeight(_r1));
273
+ i0.ɵɵpropertyInterpolate("placeholder", ctx.fileOver ? ctx.dropFilePlaceholder : ctx.messagePlaceholder);
274
+ i0.ɵɵproperty("ngModel", ctx.message)("rows", 1);
275
+ i0.ɵɵadvance(4);
276
+ i0.ɵɵtextInterpolate(_r1.value);
277
+ i0.ɵɵadvance(5);
278
+ i0.ɵɵproperty("ngIf", !ctx.waitForReply);
279
+ i0.ɵɵadvance(1);
280
+ i0.ɵɵproperty("ngIf", ctx.waitForReply && ctx.showDisabledButtonInsteadOfDotFlashing);
281
+ i0.ɵɵadvance(1);
282
+ i0.ɵɵproperty("ngIf", ctx.waitForReply && !ctx.showDisabledButtonInsteadOfDotFlashing);
283
+ i0.ɵɵadvance(1);
284
+ i0.ɵɵproperty("ngIf", ctx.waitForReply);
285
+ i0.ɵɵadvance(1);
286
+ i0.ɵɵproperty("ngIf", !ctx.isChatMode);
287
+ } }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgForOf, i3.NgIf, i4.DrButtonComponent, i5.ClickOutsideDirective, i6.DrDotFlashingComponent], styles: ["[_nghost-%COMP%]{--send-button-offset: 42px;display:flex;flex-direction:column;align-items:center;padding:0 16px}[_nghost-%COMP%] .message-row[_ngcontent-%COMP%]{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%]{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .send-button[_ngcontent-%COMP%], [_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .send-button-disabled[_ngcontent-%COMP%]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:absolute;top:2.5px;right:8px;cursor:pointer;font-size:24px;border-radius:100px;background:#f0f1f4;color:#aeabac;transition:.15s ease-in-out}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .dr-icon-history[_ngcontent-%COMP%], [_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .dr-icon-attachment[_ngcontent-%COMP%]{display:flex;align-items:center;position:absolute;cursor:pointer;width:32px;height:48px;left:16px;top:-1px}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .dr-icon-attachment[_ngcontent-%COMP%]{left:52px}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .send-button[_ngcontent-%COMP%]{color:#fff;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;opacity:.5}[_nghost-%COMP%] .message-row__input--focused[_ngcontent-%COMP%]{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}[_nghost-%COMP%] .message-row__input--filled[_ngcontent-%COMP%]{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}[_nghost-%COMP%] .message-row__input--filled[_ngcontent-%COMP%] .send-button[_ngcontent-%COMP%]{opacity:1}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .message-input-tmp[_ngcontent-%COMP%]{display:none}[_nghost-%COMP%] .message-row__input.showed-dropdown[_ngcontent-%COMP%] .send-button[_ngcontent-%COMP%]{opacity:.5}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%]:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] textarea[_ngcontent-%COMP%], [_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .message-input-tmp[_ngcontent-%COMP%]{font-size:14px;color:#333;width:100%;outline:none;min-height:48px;line-height:19px;flex-grow:1;resize:none;padding:13px 55px 13px 88px;margin:auto;border:none;border-radius:22.5px}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] textarea[_ngcontent-%COMP%]:focus, [_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .message-input-tmp[_ngcontent-%COMP%]:focus{border:none}[_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] textarea[_ngcontent-%COMP%]::placeholder, [_nghost-%COMP%] .message-row__input[_ngcontent-%COMP%] .message-input-tmp[_ngcontent-%COMP%]::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__input-textarea-wrap[_ngcontent-%COMP%]{display:flex;width:100%;position:relative}[_nghost-%COMP%] .history-dropdown[_ngcontent-%COMP%]{width:100%;max-height:220px;overflow-y:auto;padding:12px 16px 0}[_nghost-%COMP%] .showed-dropdown[_ngcontent-%COMP%] textarea[_ngcontent-%COMP%]{visibility:hidden;position:absolute}[_nghost-%COMP%] .showed-dropdown[_ngcontent-%COMP%] .message-input-tmp[_ngcontent-%COMP%]{display:block;margin-left:inherit;white-space:nowrap;font-family:monospace;overflow:hidden;text-overflow:ellipsis}[_nghost-%COMP%] .showed-dropdown[_ngcontent-%COMP%] .send-button[_ngcontent-%COMP%]{top:2.5px!important}[_nghost-%COMP%] .dropped-files[_ngcontent-%COMP%]{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}[_nghost-%COMP%] .dropped-files__item[_ngcontent-%COMP%]{max-width:183px;display:flex;flex-direction:row;gap:4px;justify-content:space-between;align-items:center;margin-top:16px;padding:4px 8px;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}[_nghost-%COMP%] .dropped-files__item-name[_ngcontent-%COMP%]{font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[_nghost-%COMP%] .dropped-files__item-remove[_ngcontent-%COMP%]{cursor:pointer}"], data: { animation: [
288
+ trigger('containerHeightAnimation', [
289
+ state('collapsed', style({ height: '{{height}}' }), { params: { height: '48px' } }),
290
+ state('expanded', style({
291
+ height: '*',
292
+ })),
293
+ transition('collapsed => expanded', [animate('300ms ease-in-out')]),
294
+ transition('expanded => collapsed', [query('@dropdownAnimation', animateChild()), animate('300ms ease-in-out')]),
295
+ ]),
296
+ trigger('dropdownAnimation', [
297
+ state('hidden', style({
298
+ opacity: 0,
299
+ transform: 'translateY(-30px)',
300
+ display: 'none',
301
+ })),
302
+ state('visible', style({
303
+ opacity: 1,
304
+ transform: 'translateY(0)',
305
+ display: 'block',
306
+ })),
307
+ transition('hidden => visible', [style({ display: 'block' }), animate('300ms ease-in-out')]),
308
+ transition('visible => hidden', [
309
+ animate('300ms ease-in-out', style({ opacity: 0, transform: 'translateY(-30px)' })),
310
+ style({ display: 'none' }),
311
+ ]),
312
+ ]),
313
+ ] }, changeDetection: 0 }); }
314
+ }
315
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatFormWithHistoryComponent, [{
316
+ type: Component,
317
+ args: [{ selector: 'dr-chat-form-with-history', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
318
+ trigger('containerHeightAnimation', [
319
+ state('collapsed', style({ height: '{{height}}' }), { params: { height: '48px' } }),
320
+ state('expanded', style({
321
+ height: '*',
322
+ })),
323
+ transition('collapsed => expanded', [animate('300ms ease-in-out')]),
324
+ transition('expanded => collapsed', [query('@dropdownAnimation', animateChild()), animate('300ms ease-in-out')]),
325
+ ]),
326
+ trigger('dropdownAnimation', [
327
+ state('hidden', style({
328
+ opacity: 0,
329
+ transform: 'translateY(-30px)',
330
+ display: 'none',
331
+ })),
332
+ state('visible', style({
333
+ opacity: 1,
334
+ transform: 'translateY(0)',
335
+ display: 'block',
336
+ })),
337
+ transition('hidden => visible', [style({ display: 'block' }), animate('300ms ease-in-out')]),
338
+ transition('visible => hidden', [
339
+ animate('300ms ease-in-out', style({ opacity: 0, transform: 'translateY(-30px)' })),
340
+ style({ display: 'none' }),
341
+ ]),
342
+ ]),
343
+ ], template: "<div class=\"message-row\">\n <div\n [@containerHeightAnimation]=\"{\n value: showHistory ? 'expanded' : 'collapsed',\n params: { height: getTextAreaHeight(textAreaElement) },\n }\"\n class=\"message-row__input\"\n [ngClass]=\"{\n 'message-row__input--focused': inputFocus,\n 'message-row__input--filled': !!message?.length,\n 'showed-dropdown': isShowedHistory,\n }\">\n <div class=\"dropped-files\" *ngIf=\"droppedFiles?.length\">\n <div class=\"dropped-files__item\" *ngFor=\"let file of droppedFiles\">\n <i class=\"dr-icon-file\"></i>\n <div class=\"dropped-files__item-name\">{{ file.name }}</div>\n <i class=\"dr-icon-noty-error dropped-files__item-remove\" (click)=\"removeFile(file)\"></i>\n </div>\n </div>\n\n <div class=\"message-row__input-textarea-wrap\">\n <textarea\n #textAreaElement\n (focus)=\"inputFocus = true\"\n (blur)=\"inputFocus = false\"\n (mouseenter)=\"inputHover = true\"\n (mouseleave)=\"inputHover = false\"\n [(ngModel)]=\"message\"\n [rows]=\"1\"\n [style]=\"getTextAreaHeight(textAreaElement)\"\n (ngModelChange)=\"onModelChange($event)\"\n type=\"text\"\n placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n (keydown.enter)=\"sendMessage($event)\">\n </textarea>\n\n <div class=\"message-input-tmp\">{{ textAreaElement.value }}</div>\n\n <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n <i (click)=\"showHistory()\" class=\"dr-icon-history\"></i>\n <i (click)=\"fileInput.click()\" class=\"dr-icon-attachment\"></i>\n\n <i\n *ngIf=\"!waitForReply\"\n [style]=\"getSendButtonPosition(textAreaElement)\"\n (click)=\"sendMessage($event)\"\n class=\"dr-icon-send-arrow-up send-button\"></i>\n <i\n *ngIf=\"waitForReply && showDisabledButtonInsteadOfDotFlashing\"\n (click)=\"sendMessage($event)\"\n class=\"dr-icon-send-arrow-up send-button-disabled\"></i>\n\n <dr-dot-flashing\n *ngIf=\"waitForReply && !showDisabledButtonInsteadOfDotFlashing\"\n class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n <dr-button *ngIf=\"waitForReply\" (click)=\"abortMessage()\" theme=\"ghost\" class=\"abort-button\"\n >Stop generating</dr-button\n >\n </div>\n\n <ng-container *ngIf=\"!isChatMode\">\n <div\n [@dropdownAnimation]=\"isShowedHistory ? 'visible' : 'hidden'\"\n class=\"history-dropdown\"\n [exclude]=\"'.dr-icon-history'\"\n (clickOutside)=\"closeHistory()\">\n <ng-content></ng-content>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [":host{--send-button-offset: 42px;display:flex;flex-direction:column;align-items:center;padding:0 16px}:host .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}:host .message-row__input{flex-direction:column;background-color:#fff;position:relative;display:flex;align-items:center;flex-grow:1;height:auto;overflow:visible;min-width:265px;border-radius:24px;border:1.5px solid transparent;box-shadow:0 2px 16px -10px #603cff29;transition:.35s ease}:host .message-row__input .send-button,:host .message-row__input .send-button-disabled{width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:absolute;top:2.5px;right:8px;cursor:pointer;font-size:24px;border-radius:100px;background:#f0f1f4;color:#aeabac;transition:.15s ease-in-out}:host .message-row__input .dr-icon-history,:host .message-row__input .dr-icon-attachment{display:flex;align-items:center;position:absolute;cursor:pointer;width:32px;height:48px;left:16px;top:-1px}:host .message-row__input .dr-icon-attachment{left:52px}:host .message-row__input .send-button{color:#fff;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;opacity:.5}:host .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}:host .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}:host .message-row__input--filled .send-button{opacity:1}:host .message-row__input .message-input-tmp{display:none}:host .message-row__input.showed-dropdown .send-button{opacity:.5}:host .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}:host .message-row__input textarea,:host .message-row__input .message-input-tmp{font-size:14px;color:#333;width:100%;outline:none;min-height:48px;line-height:19px;flex-grow:1;resize:none;padding:13px 55px 13px 88px;margin:auto;border:none;border-radius:22.5px}:host .message-row__input textarea:focus,:host .message-row__input .message-input-tmp:focus{border:none}:host .message-row__input textarea::placeholder,:host .message-row__input .message-input-tmp::placeholder{color:#9ea1aa}:host .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host .history-dropdown{width:100%;max-height:220px;overflow-y:auto;padding:12px 16px 0}:host .showed-dropdown textarea{visibility:hidden;position:absolute}:host .showed-dropdown .message-input-tmp{display:block;margin-left:inherit;white-space:nowrap;font-family:monospace;overflow:hidden;text-overflow:ellipsis}:host .showed-dropdown .send-button{top:2.5px!important}:host .dropped-files{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}:host .dropped-files__item{max-width:183px;display:flex;flex-direction:row;gap:4px;justify-content:space-between;align-items:center;margin-top:16px;padding:4px 8px;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}:host .dropped-files__item-name{font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host .dropped-files__item-remove{cursor:pointer}\n"] }]
344
+ }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, { textAreaElementRef: [{
345
+ type: ViewChild,
346
+ args: ['textAreaElement']
347
+ }], isChatMode: [{
348
+ type: Input
349
+ }], message: [{
350
+ type: Input
351
+ }], messagePlaceholder: [{
352
+ type: Input
353
+ }], dropFiles: [{
354
+ type: Input
355
+ }], dropFilePlaceholder: [{
356
+ type: Input
357
+ }], waitForReply: [{
358
+ type: Input
359
+ }], showDisabledButtonInsteadOfDotFlashing: [{
360
+ type: Input
361
+ }], send: [{
362
+ type: Output
363
+ }], abort: [{
364
+ type: Output
365
+ }], inputChange: [{
366
+ type: Output
367
+ }], fileOver: [{
368
+ type: HostBinding,
369
+ args: ['class.file-over']
370
+ }], onDrop: [{
371
+ type: HostListener,
372
+ args: ['drop', ['$event']]
373
+ }], onDragOver: [{
374
+ type: HostListener,
375
+ args: ['dragover', ['$event']]
376
+ }], onDragLeave: [{
377
+ type: HostListener,
378
+ args: ['dragleave', ['$event']]
379
+ }] }); })();
380
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-form-with-history.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-with-history/chat-form-with-history.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-with-history/chat-form-with-history..component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IMAGE_TYPES } from '../../models/chat';\nimport { trigger, state, style, transition, animate, query, animateChild } from '@angular/animations';\n\n@Component({\n    selector: 'dr-chat-form-with-history',\n    templateUrl: './chat-form-with-history..component.html',\n    styleUrls: ['./chat-form-with-history..component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('containerHeightAnimation', [\n            state('collapsed', style({ height: '{{height}}' }), { params: { height: '48px' } }),\n            state(\n                'expanded',\n                style({\n                    height: '*',\n                }),\n            ),\n            transition('collapsed => expanded', [animate('300ms ease-in-out')]),\n            transition('expanded => collapsed', [query('@dropdownAnimation', animateChild()), animate('300ms ease-in-out')]),\n        ]),\n        trigger('dropdownAnimation', [\n            state(\n                'hidden',\n                style({\n                    opacity: 0,\n                    transform: 'translateY(-30px)',\n                    display: 'none',\n                }),\n            ),\n            state(\n                'visible',\n                style({\n                    opacity: 1,\n                    transform: 'translateY(0)',\n                    display: 'block',\n                }),\n            ),\n            transition('hidden => visible', [style({ display: 'block' }), animate('300ms ease-in-out')]),\n            transition('visible => hidden', [\n                animate('300ms ease-in-out', style({ opacity: 0, transform: 'translateY(-30px)' })),\n                style({ display: 'none' }),\n            ]),\n        ]),\n    ],\n})\nexport class DrChatFormWithHistoryComponent {\n    @ViewChild('textAreaElement') textAreaElementRef: ElementRef;\n    _textareaInitialHeight = true;\n    inputFocus = false;\n    inputHover = false;\n\n    droppedFiles: any[] = [];\n    isShowedHistory = false;\n\n    @Input() isChatMode = false;\n\n    /**\n     * Predefined message text\n     *\n     * @type {string}\n     */\n    @Input() message = '';\n\n    /**\n     * Message placeholder text\n     *\n     * @type {string}\n     */\n    @Input() messagePlaceholder = 'Type a message';\n\n    /**\n     * Show send button\n     *\n     * @type {boolean}\n     */\n    @Input() dropFiles = false;\n\n    /**\n     * File drop placeholder text\n     *\n     * @type {string}\n     */\n    @Input() dropFilePlaceholder = 'Drop file to send';\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() showDisabledButtonInsteadOfDotFlashing = false;\n\n    /**\n     *\n     * @type {EventEmitter<{ message: string, files: File[] }>}\n     */\n    @Output() send = new EventEmitter<{ message: string; files: File[] }>();\n    @Output() abort = new EventEmitter<any>();\n\n    /**\n     * Emits when message input value has been changed\n     *\n     * @type {EventEmitter<string>}\n     */\n\n    @Output() inputChange = new EventEmitter<string>();\n\n    @HostBinding('class.file-over') fileOver = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected domSanitizer: DomSanitizer,\n    ) {}\n\n    @HostListener('drop', ['$event'])\n    onDrop(event: any) {\n        if (this.dropFiles) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.fileOver = false;\n            if (event.dataTransfer?.files) {\n                for (const file of event.dataTransfer.files) {\n                    const res = file;\n\n                    if (IMAGE_TYPES.includes(file.type)) {\n                        const fr = new FileReader();\n                        fr.onload = (e: any) => {\n                            res.src = e.target.result;\n                            res.urlStyle = this.domSanitizer.bypassSecurityTrustStyle(`url(${res.src})`);\n                            this.cdr.detectChanges();\n                        };\n\n                        fr.readAsDataURL(file);\n                    }\n                    this.droppedFiles.push(res);\n                }\n            }\n        }\n    }\n\n    removeFile(file) {\n        const index = this.droppedFiles.indexOf(file);\n        if (index >= 0) {\n            this.droppedFiles.splice(index, 1);\n        }\n    }\n\n    @HostListener('dragover', ['$event'])\n    onDragOver(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = true;\n        }\n    }\n\n    @HostListener('dragleave', ['$event'])\n    onDragLeave(event: DragEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.dropFiles) {\n            this.fileOver = false;\n        }\n    }\n\n    sendMessage($event) {\n        if (!$event || !$event.shiftKey) {\n            $event && $event.preventDefault();\n            if (this.waitForReply) {\n                return;\n            }\n\n            if (this.droppedFiles.length || String(this.message).trim().length) {\n                this._textareaInitialHeight = true;\n                this.send.emit({ message: this.message, files: this.droppedFiles });\n                this.message = '';\n                this.droppedFiles = [];\n                this.cdr.markForCheck();\n            }\n        }\n    }\n\n    abortMessage() {\n        this.abort.emit();\n    }\n\n    onModelChange(value: string): void {\n        this._textareaInitialHeight = false;\n        this.inputChange.emit(value);\n    }\n\n    getTextAreaHeight(textAreaElement: HTMLTextAreaElement) {\n        if (this._textareaInitialHeight) {\n            textAreaElement.style.height = '48px';\n        } else {\n            textAreaElement.style.height = 'auto';\n            textAreaElement.style.height = textAreaElement.scrollHeight + 'px';\n        }\n\n        return `${textAreaElement.style.height}`;\n    }\n\n    getSendButtonPosition(textAreaElement: HTMLTextAreaElement) {\n        return `top: calc(${this.getTextAreaHeight(textAreaElement)} - var(--send-button-offset));`;\n    }\n\n    showHistory() {\n        this.isShowedHistory = !this.isShowedHistory;\n    }\n\n    closeHistory() {\n        this.isShowedHistory = false;\n        this.cdr.markForCheck();\n    }\n\n    onFileSelected(event: Event) {\n        const input = event.target as HTMLInputElement;\n    }\n}\n","<div class=\"message-row\">\n    <div\n        [@containerHeightAnimation]=\"{\n            value: showHistory ? 'expanded' : 'collapsed',\n            params: { height: getTextAreaHeight(textAreaElement) },\n        }\"\n        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.length,\n            'showed-dropdown': isShowedHistory,\n        }\">\n        <div class=\"dropped-files\" *ngIf=\"droppedFiles?.length\">\n            <div class=\"dropped-files__item\" *ngFor=\"let file of droppedFiles\">\n                <i class=\"dr-icon-file\"></i>\n                <div class=\"dropped-files__item-name\">{{ file.name }}</div>\n                <i class=\"dr-icon-noty-error dropped-files__item-remove\" (click)=\"removeFile(file)\"></i>\n            </div>\n        </div>\n\n        <div class=\"message-row__input-textarea-wrap\">\n            <textarea\n                #textAreaElement\n                (focus)=\"inputFocus = true\"\n                (blur)=\"inputFocus = false\"\n                (mouseenter)=\"inputHover = true\"\n                (mouseleave)=\"inputHover = false\"\n                [(ngModel)]=\"message\"\n                [rows]=\"1\"\n                [style]=\"getTextAreaHeight(textAreaElement)\"\n                (ngModelChange)=\"onModelChange($event)\"\n                type=\"text\"\n                placeholder=\"{{ fileOver ? dropFilePlaceholder : messagePlaceholder }}\"\n                (keydown.enter)=\"sendMessage($event)\">\n            </textarea>\n\n            <div class=\"message-input-tmp\">{{ textAreaElement.value }}</div>\n\n            <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n            <i (click)=\"showHistory()\" class=\"dr-icon-history\"></i>\n            <i (click)=\"fileInput.click()\" class=\"dr-icon-attachment\"></i>\n\n            <i\n                *ngIf=\"!waitForReply\"\n                [style]=\"getSendButtonPosition(textAreaElement)\"\n                (click)=\"sendMessage($event)\"\n                class=\"dr-icon-send-arrow-up send-button\"></i>\n            <i\n                *ngIf=\"waitForReply && showDisabledButtonInsteadOfDotFlashing\"\n                (click)=\"sendMessage($event)\"\n                class=\"dr-icon-send-arrow-up send-button-disabled\"></i>\n\n            <dr-dot-flashing\n                *ngIf=\"waitForReply && !showDisabledButtonInsteadOfDotFlashing\"\n                class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n            <dr-button *ngIf=\"waitForReply\" (click)=\"abortMessage()\" theme=\"ghost\" class=\"abort-button\"\n                >Stop generating</dr-button\n            >\n        </div>\n\n        <ng-container *ngIf=\"!isChatMode\">\n            <div\n                [@dropdownAnimation]=\"isShowedHistory ? 'visible' : 'hidden'\"\n                class=\"history-dropdown\"\n                [exclude]=\"'.dr-icon-history'\"\n                (clickOutside)=\"closeHistory()\">\n                <ng-content></ng-content>\n            </div>\n        </ng-container>\n    </div>\n</div>\n"]}
@@ -0,0 +1,48 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as _ from 'lodash';
3
+ import { DrSharedUtils } from '../../utils/dr-shared-utils';
4
+ import * as i0 from "@angular/core";
5
+ export class FilterPipe {
6
+ transform(arr, fn, type, refresh) {
7
+ if (!fn) {
8
+ return arr;
9
+ }
10
+ if (!_.isArray(arr)) {
11
+ return arr;
12
+ }
13
+ if (_.isFunction(fn)) {
14
+ return arr.filter(fn);
15
+ }
16
+ else if (_.isArray(fn)) {
17
+ const [key, value] = fn;
18
+ if (_.isUndefined(value)) {
19
+ return arr;
20
+ }
21
+ if (type === 'text') {
22
+ if (key) {
23
+ return arr.filter((item) => item[key].toLowerCase().includes(value.toLowerCase()));
24
+ }
25
+ else {
26
+ return arr.filter((item) => item.toString().toLowerCase().includes(value.toLowerCase()));
27
+ }
28
+ }
29
+ return arr.filter((item) => DrSharedUtils.getProperty(item, key) === value || item.system === 1);
30
+ }
31
+ else if (fn) {
32
+ return arr.filter((item) => item === fn);
33
+ }
34
+ else {
35
+ return arr;
36
+ }
37
+ }
38
+ /** @nocollapse */ static { this.ɵfac = function FilterPipe_Factory(t) { return new (t || FilterPipe)(); }; }
39
+ /** @nocollapse */ static { this.ɵpipe = /** @pureOrBreakMyCode */ i0.ɵɵdefinePipe({ name: "filter", type: FilterPipe, pure: true, standalone: true }); }
40
+ }
41
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterPipe, [{
42
+ type: Pipe,
43
+ args: [{
44
+ name: 'filter',
45
+ standalone: true,
46
+ }]
47
+ }], null, null); })();
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9waXBlcy9maWx0ZXIvZmlsdGVyLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDcEQsT0FBTyxLQUFLLENBQUMsTUFBTSxRQUFRLENBQUM7QUFDNUIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQU01RCxNQUFNLE9BQU8sVUFBVTtJQUNuQixTQUFTLENBQUksR0FBUSxFQUFFLEVBQU8sRUFBRSxJQUFhLEVBQUUsT0FBaUI7UUFDNUQsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNMLE9BQU8sR0FBRyxDQUFDO1NBQ2Q7UUFDRCxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNqQixPQUFPLEdBQUcsQ0FBQztTQUNkO1FBQ0QsSUFBSSxDQUFDLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxFQUFFO1lBQ2xCLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUN6QjthQUFNLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtZQUN0QixNQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ3RCLE9BQU8sR0FBRyxDQUFDO2FBQ2Q7WUFDRCxJQUFJLElBQUksS0FBSyxNQUFNLEVBQUU7Z0JBQ2pCLElBQUksR0FBRyxFQUFFO29CQUNMLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDO2lCQUMzRjtxQkFBTTtvQkFDSCxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztpQkFDakc7YUFDSjtZQUNELE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLEtBQUssS0FBSyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDekc7YUFBTSxJQUFJLEVBQUUsRUFBRTtZQUNYLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1NBQ2pEO2FBQU07WUFDSCxPQUFPLEdBQUcsQ0FBQztTQUNkO0lBQ0wsQ0FBQzs4RkE1QlEsVUFBVTsrR0FBVixVQUFVOzt1RkFBVixVQUFVO2NBSnRCLElBQUk7ZUFBQztnQkFDRixJQUFJLEVBQUUsUUFBUTtnQkFDZCxVQUFVLEVBQUUsSUFBSTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IERyU2hhcmVkVXRpbHMgfSBmcm9tICcuLi8uLi91dGlscy9kci1zaGFyZWQtdXRpbHMnO1xuXG5AUGlwZSh7XG4gICAgbmFtZTogJ2ZpbHRlcicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRmlsdGVyUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIHRyYW5zZm9ybTxUPihhcnI6IFRbXSwgZm46IGFueSwgdHlwZT86IHN0cmluZywgcmVmcmVzaD86IGJvb2xlYW4pOiBUW10ge1xuICAgICAgICBpZiAoIWZuKSB7XG4gICAgICAgICAgICByZXR1cm4gYXJyO1xuICAgICAgICB9XG4gICAgICAgIGlmICghXy5pc0FycmF5KGFycikpIHtcbiAgICAgICAgICAgIHJldHVybiBhcnI7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKF8uaXNGdW5jdGlvbihmbikpIHtcbiAgICAgICAgICAgIHJldHVybiBhcnIuZmlsdGVyKGZuKTtcbiAgICAgICAgfSBlbHNlIGlmIChfLmlzQXJyYXkoZm4pKSB7XG4gICAgICAgICAgICBjb25zdCBba2V5LCB2YWx1ZV0gPSBmbjtcbiAgICAgICAgICAgIGlmIChfLmlzVW5kZWZpbmVkKHZhbHVlKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBhcnI7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAodHlwZSA9PT0gJ3RleHQnKSB7XG4gICAgICAgICAgICAgICAgaWYgKGtleSkge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gYXJyLmZpbHRlcigoaXRlbTogYW55KSA9PiBpdGVtW2tleV0udG9Mb3dlckNhc2UoKS5pbmNsdWRlcyh2YWx1ZS50b0xvd2VyQ2FzZSgpKSk7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGFyci5maWx0ZXIoKGl0ZW06IGFueSkgPT4gaXRlbS50b1N0cmluZygpLnRvTG93ZXJDYXNlKCkuaW5jbHVkZXModmFsdWUudG9Mb3dlckNhc2UoKSkpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBhcnIuZmlsdGVyKChpdGVtOiBhbnkpID0+IERyU2hhcmVkVXRpbHMuZ2V0UHJvcGVydHkoaXRlbSwga2V5KSA9PT0gdmFsdWUgfHwgaXRlbS5zeXN0ZW0gPT09IDEpO1xuICAgICAgICB9IGVsc2UgaWYgKGZuKSB7XG4gICAgICAgICAgICByZXR1cm4gYXJyLmZpbHRlcigoaXRlbTogYW55KSA9PiBpdGVtID09PSBmbik7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gYXJyO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -0,0 +1,19 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class ImgPipe {
4
+ transform(value, ...args) {
5
+ const isLocalHost = STATIC_URL.indexOf('localhost') >= 0 || STATIC_URL.indexOf('127.0.0.1') >= 0;
6
+ const path = value.startsWith('./') ? value.replace('./', '/') : value.startsWith('/') ? value : '/' + value;
7
+ return isLocalHost ? value : document.staticFunc(path);
8
+ }
9
+ /** @nocollapse */ static { this.ɵfac = function ImgPipe_Factory(t) { return new (t || ImgPipe)(); }; }
10
+ /** @nocollapse */ static { this.ɵpipe = /** @pureOrBreakMyCode */ i0.ɵɵdefinePipe({ name: "img", type: ImgPipe, pure: true, standalone: true }); }
11
+ }
12
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ImgPipe, [{
13
+ type: Pipe,
14
+ args: [{
15
+ name: 'img',
16
+ standalone: true,
17
+ }]
18
+ }], null, null); })();
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1nLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9waXBlcy9pbWcvaW1nLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBUXBELE1BQU0sT0FBTyxPQUFPO0lBQ2hCLFNBQVMsQ0FBQyxLQUFhLEVBQUUsR0FBRyxJQUFlO1FBQ3ZDLE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLFVBQVUsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pHLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUM7UUFDN0csT0FBTyxXQUFXLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUUsUUFBZ0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEUsQ0FBQzsyRkFMUSxPQUFPOzRHQUFQLE9BQU87O3VGQUFQLE9BQU87Y0FKbkIsSUFBSTtlQUFDO2dCQUNGLElBQUksRUFBRSxLQUFLO2dCQUNYLFVBQVUsRUFBRSxJQUFJO2FBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5kZWNsYXJlIGNvbnN0IFNUQVRJQ19VUkw6IHN0cmluZztcblxuQFBpcGUoe1xuICAgIG5hbWU6ICdpbWcnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEltZ1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZywgLi4uYXJnczogdW5rbm93bltdKTogdW5rbm93biB7XG4gICAgICAgIGNvbnN0IGlzTG9jYWxIb3N0ID0gU1RBVElDX1VSTC5pbmRleE9mKCdsb2NhbGhvc3QnKSA+PSAwIHx8IFNUQVRJQ19VUkwuaW5kZXhPZignMTI3LjAuMC4xJykgPj0gMDtcbiAgICAgICAgY29uc3QgcGF0aCA9IHZhbHVlLnN0YXJ0c1dpdGgoJy4vJykgPyB2YWx1ZS5yZXBsYWNlKCcuLycsICcvJykgOiB2YWx1ZS5zdGFydHNXaXRoKCcvJykgPyB2YWx1ZSA6ICcvJyArIHZhbHVlO1xuICAgICAgICByZXR1cm4gaXNMb2NhbEhvc3QgPyB2YWx1ZSA6IChkb2N1bWVudCBhcyBhbnkpLnN0YXRpY0Z1bmMocGF0aCk7XG4gICAgfVxufVxuIl19
@@ -1,6 +1,7 @@
1
1
  import moment from 'moment';
2
2
  import { DateTags, TimeframeOption } from '../models/datePicker';
3
3
  import { Observable } from 'rxjs';
4
+ import { isNil, isObject } from 'lodash';
4
5
  export class DrSharedUtils {
5
6
  /**
6
7
  * Get timeframe (day, year, month, quarter) based on passed format
@@ -54,5 +55,31 @@ export class DrSharedUtils {
54
55
  static { this.normalizeLineEndings = (str) => {
55
56
  return str ? str.replace(/\r\n|\r/g, '\n') : str;
56
57
  }; }
58
+ static { this.isLocalhost = () => window.location.hostname === 'localhost' || window.location.hostname === '127.0.0.1'; }
59
+ static { this.getRouteDataAttributeValue = (activatedRoute, attribute, defaultValue) => {
60
+ if (activatedRoute.snapshot.data.hasOwnProperty(attribute)) {
61
+ defaultValue = activatedRoute.snapshot.data[attribute];
62
+ }
63
+ if (activatedRoute?.children?.length) {
64
+ activatedRoute.children.forEach((child) => {
65
+ defaultValue = DrSharedUtils.getRouteDataAttributeValue(child, attribute, defaultValue);
66
+ });
67
+ }
68
+ return defaultValue;
69
+ }; }
70
+ static { this.getProperty = (value, key) => {
71
+ if (isNil(value) || !isObject(value)) {
72
+ return undefined;
73
+ }
74
+ const keys = key.split('.');
75
+ let result = value[keys.shift()];
76
+ for (const k of keys) {
77
+ if (isNil(result) || !isObject(result)) {
78
+ return undefined;
79
+ }
80
+ result = result[k];
81
+ }
82
+ return result;
83
+ }; }
57
84
  }
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2hhcmVkLXV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvdXRpbHMvZHItc2hhcmVkLXV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTSxNQUFNLFFBQVEsQ0FBQztBQUM1QixPQUFPLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbEMsTUFBTSxPQUFPLGFBQWE7SUFDdEI7Ozs7T0FJRztJQUNJLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxNQUFjO1FBQ2pELE1BQU0sWUFBWSxHQUFHLGVBQWUsQ0FBQyxHQUFHLENBQUM7UUFFekMsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNULE9BQU8sWUFBWSxDQUFDO1NBQ3ZCO1FBRUQsTUFBTSxlQUFlLEdBQUcsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzdDLFFBQVEsSUFBSSxFQUFFO1lBQ1YsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsT0FBTyxDQUFDO1lBQ25DLEtBQUssZUFBZSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQzlCLE9BQU8sZUFBZSxDQUFDLEdBQUcsQ0FBQztZQUMvQixLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUM5QixPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUM7WUFDaEMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsS0FBSyxDQUFDO1lBQ2pDLEtBQUssZUFBZSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQzlCLE9BQU8sZUFBZSxDQUFDLElBQUksQ0FBQztZQUNoQztnQkFDSSxPQUFPLFlBQVksQ0FBQztTQUMzQjtJQUNMLENBQUM7SUFFTSxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQVc7UUFDbEMsTUFBTSxTQUFTLEdBQUcsTUFBTSxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzlDLFFBQVEsR0FBRyxFQUFFO1lBQ1QsS0FBSyxRQUFRLENBQUMsS0FBSztnQkFDZixPQUFPLFNBQVMsQ0FBQztZQUNyQixLQUFLLFFBQVEsQ0FBQyxTQUFTO2dCQUNuQixTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztnQkFDOUIsT0FBTyxTQUFTLENBQUM7WUFDckIsS0FBSyxRQUFRLENBQUMsVUFBVTtnQkFDcEIsU0FBUyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztnQkFDekIsT0FBTyxTQUFTLENBQUM7WUFDckIsS0FBSyxRQUFRLENBQUMsVUFBVTtnQkFDcEIsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUMvQyxPQUFPLFNBQVMsQ0FBQztTQUN4QjtJQUNMLENBQUM7YUFFYSx1QkFBa0IsR0FBRyxDQUFDLE1BQWUsRUFBcUMsRUFBRSxDQUN0RixJQUFJLFVBQVUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO1FBQ3hCLE1BQU0sY0FBYyxHQUFHLElBQUksY0FBYyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7UUFFL0UsY0FBYyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUUvQixPQUFPLEdBQUcsRUFBRTtZQUNSLGNBQWMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNoQyxDQUFDLENBQUM7SUFDTixDQUFDLENBQUMsQ0FBQzthQUVPLHlCQUFvQixHQUFHLENBQUMsR0FBVyxFQUFVLEVBQUU7UUFDekQsT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7SUFDckQsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IG1vbWVudCBmcm9tICdtb21lbnQnO1xuaW1wb3J0IHsgRGF0ZVRhZ3MsIFRpbWVmcmFtZU9wdGlvbiB9IGZyb20gJy4uL21vZGVscy9kYXRlUGlja2VyJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IGNsYXNzIERyU2hhcmVkVXRpbHMge1xuICAgIC8qKlxuICAgICAqIEdldCB0aW1lZnJhbWUgKGRheSwgeWVhciwgbW9udGgsIHF1YXJ0ZXIpIGJhc2VkIG9uIHBhc3NlZCBmb3JtYXRcbiAgICAgKlxuICAgICAqIEBwYXJhbSBmb3JtYXQgLSBkYXRlIGZvcm1hdCBzdHJpbmcuIEV4YW1wbGVzOiBNTS9ERC9ZWVlZLCBRL1lZWVlcbiAgICAgKi9cbiAgICBwdWJsaWMgc3RhdGljIGdldFRpbWVmcmFtZUJ5RGF0ZUZvcm1hdChmb3JtYXQ6IHN0cmluZyk6IFRpbWVmcmFtZU9wdGlvbiB7XG4gICAgICAgIGNvbnN0IGRlZmF1bHRGcmFtZSA9IFRpbWVmcmFtZU9wdGlvbi5EQVk7XG5cbiAgICAgICAgaWYgKCFmb3JtYXQpIHtcbiAgICAgICAgICAgIHJldHVybiBkZWZhdWx0RnJhbWU7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBsb3dlckNhc2VGb3JtYXQgPSBmb3JtYXQudG9Mb3dlckNhc2UoKTtcbiAgICAgICAgc3dpdGNoICh0cnVlKSB7XG4gICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygncScpOlxuICAgICAgICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uUVVBUlRFUjtcbiAgICAgICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCdkJyk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5EQVk7XG4gICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygndycpOlxuICAgICAgICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uV0VFSztcbiAgICAgICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCdtJyk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5NT05USDtcbiAgICAgICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCd5Jyk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5ZRUFSO1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICByZXR1cm4gZGVmYXVsdEZyYW1lO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBnZXREYXRlQnlUYWcodGFnOiBzdHJpbmcpOiBhbnkge1xuICAgICAgICBjb25zdCB0b2RheURhdGUgPSBtb21lbnQoKS51dGMoKS5lbmRPZignZGF5Jyk7XG4gICAgICAgIHN3aXRjaCAodGFnKSB7XG4gICAgICAgICAgICBjYXNlIERhdGVUYWdzLlRPREFZOlxuICAgICAgICAgICAgICAgIHJldHVybiB0b2RheURhdGU7XG4gICAgICAgICAgICBjYXNlIERhdGVUYWdzLllFU1RFUkRBWTpcbiAgICAgICAgICAgICAgICB0b2RheURhdGUuc3VidHJhY3QoMSwgJ2RheXMnKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gdG9kYXlEYXRlO1xuICAgICAgICAgICAgY2FzZSBEYXRlVGFncy5USElTX01PTlRIOlxuICAgICAgICAgICAgICAgIHRvZGF5RGF0ZS5lbmRPZignbW9udGgnKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gdG9kYXlEYXRlO1xuICAgICAgICAgICAgY2FzZSBEYXRlVGFncy5QUkVWX01PTlRIOlxuICAgICAgICAgICAgICAgIHRvZGF5RGF0ZS5zdWJ0cmFjdCgxLCAnbW9udGhzJykuZW5kT2YoJ21vbnRoJyk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRvZGF5RGF0ZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgZnJvbVJlc2l6ZU9ic2VydmVyID0gKHRhcmdldDogRWxlbWVudCk6IE9ic2VydmFibGU8UmVzaXplT2JzZXJ2ZXJFbnRyeVtdPiA9PlxuICAgICAgICBuZXcgT2JzZXJ2YWJsZSgob2JzZXJ2ZXIpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHJlc2l6ZU9ic2VydmVyID0gbmV3IFJlc2l6ZU9ic2VydmVyKChlbnRyaWVzKSA9PiBvYnNlcnZlci5uZXh0KGVudHJpZXMpKTtcblxuICAgICAgICAgICAgcmVzaXplT2JzZXJ2ZXIub2JzZXJ2ZSh0YXJnZXQpO1xuXG4gICAgICAgICAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICAgICAgICAgIHJlc2l6ZU9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0pO1xuXG4gICAgcHVibGljIHN0YXRpYyBub3JtYWxpemVMaW5lRW5kaW5ncyA9IChzdHI6IHN0cmluZyk6IHN0cmluZyA9PiB7XG4gICAgICAgIHJldHVybiBzdHIgPyBzdHIucmVwbGFjZSgvXFxyXFxufFxcci9nLCAnXFxuJykgOiBzdHI7XG4gICAgfTtcbn1cbiJdfQ==
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-shared-utils.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/utils/dr-shared-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import moment from 'moment';\nimport { DateTags, TimeframeOption } from '../models/datePicker';\nimport { Observable } from 'rxjs';\nimport { ActivatedRoute } from '@angular/router';\nimport { isNil, isObject } from 'lodash';\n\nexport class DrSharedUtils {\n    /**\n     * Get timeframe (day, year, month, quarter) based on passed format\n     *\n     * @param format - date format string. Examples: MM/DD/YYYY, Q/YYYY\n     */\n    public static getTimeframeByDateFormat(format: string): TimeframeOption {\n        const defaultFrame = TimeframeOption.DAY;\n\n        if (!format) {\n            return defaultFrame;\n        }\n\n        const lowerCaseFormat = format.toLowerCase();\n        switch (true) {\n            case lowerCaseFormat.includes('q'):\n                return TimeframeOption.QUARTER;\n            case lowerCaseFormat.includes('d'):\n                return TimeframeOption.DAY;\n            case lowerCaseFormat.includes('w'):\n                return TimeframeOption.WEEK;\n            case lowerCaseFormat.includes('m'):\n                return TimeframeOption.MONTH;\n            case lowerCaseFormat.includes('y'):\n                return TimeframeOption.YEAR;\n            default:\n                return defaultFrame;\n        }\n    }\n\n    public static getDateByTag(tag: string): any {\n        const todayDate = moment().utc().endOf('day');\n        switch (tag) {\n            case DateTags.TODAY:\n                return todayDate;\n            case DateTags.YESTERDAY:\n                todayDate.subtract(1, 'days');\n                return todayDate;\n            case DateTags.THIS_MONTH:\n                todayDate.endOf('month');\n                return todayDate;\n            case DateTags.PREV_MONTH:\n                todayDate.subtract(1, 'months').endOf('month');\n                return todayDate;\n        }\n    }\n\n    public static fromResizeObserver = (target: Element): Observable<ResizeObserverEntry[]> =>\n        new Observable((observer) => {\n            const resizeObserver = new ResizeObserver((entries) => observer.next(entries));\n\n            resizeObserver.observe(target);\n\n            return () => {\n                resizeObserver.disconnect();\n            };\n        });\n\n    public static normalizeLineEndings = (str: string): string => {\n        return str ? str.replace(/\\r\\n|\\r/g, '\\n') : str;\n    };\n\n    public static isLocalhost = (): boolean =>\n        window.location.hostname === 'localhost' || window.location.hostname === '127.0.0.1';\n\n    public static getRouteDataAttributeValue = <T>(\n        activatedRoute: ActivatedRoute,\n        attribute: string,\n        defaultValue?: T,\n    ): T | undefined => {\n        if (activatedRoute.snapshot.data.hasOwnProperty(attribute)) {\n            defaultValue = activatedRoute.snapshot.data[attribute];\n        }\n\n        if (activatedRoute?.children?.length) {\n            activatedRoute.children.forEach((child) => {\n                defaultValue = DrSharedUtils.getRouteDataAttributeValue(child, attribute, defaultValue);\n            });\n        }\n\n        return defaultValue;\n    };\n\n    public static getProperty = (value: { [key: string]: any }, key: string): any => {\n        if (isNil(value) || !isObject(value)) {\n            return undefined;\n        }\n\n        const keys: string[] = key.split('.');\n        let result: any = value[keys.shift()!];\n\n        for (const k of keys) {\n            if (isNil(result) || !isObject(result)) {\n                return undefined;\n            }\n\n            result = result[k];\n        }\n\n        return result;\n    };\n}\n"]}