@datarailsshared/datarailsshared 1.5.576 → 1.6.21
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.21.tgz +0 -0
- package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +4 -4
- package/esm2022/lib/dr-chat/chat.module.mjs +10 -4
- package/esm2022/lib/dr-chat/dr-chat-dropped-files/dr-chat-dropped-files.component.mjs +61 -0
- package/esm2022/lib/dr-chat/dr-chat-dropped-files/pipes/shorter-naming.pipe.mjs +29 -0
- package/esm2022/lib/dr-chat/dr-chat-form-with-history/chat-form-with-history.component.mjs +117 -105
- package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +18 -18
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +8 -59
- package/esm2022/lib/models/chat.mjs +4 -1
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +232 -179
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-chat/chat.module.d.ts +10 -8
- package/lib/dr-chat/dr-chat-dropped-files/dr-chat-dropped-files.component.d.ts +12 -0
- package/lib/dr-chat/dr-chat-dropped-files/pipes/shorter-naming.pipe.d.ts +7 -0
- package/lib/dr-chat/dr-chat-form-with-history/chat-form-with-history.component.d.ts +12 -5
- package/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.d.ts +3 -16
- package/lib/models/chat.d.ts +9 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/datarailsshared-datarailsshared-1.5.576.tgz +0 -0
|
@@ -1,82 +1,67 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
-
import { IMAGE_TYPES } from '../../models/chat';
|
|
4
3
|
import { trigger, state, style, transition, animate, query, animateChild } from '@angular/animations';
|
|
4
|
+
import { BehaviorSubject } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/platform-browser";
|
|
7
7
|
import * as i2 from "@angular/forms";
|
|
8
8
|
import * as i3 from "@angular/common";
|
|
9
|
-
import * as i4 from "../../
|
|
10
|
-
import * as i5 from "
|
|
11
|
-
import * as i6 from "../dr-
|
|
9
|
+
import * as i4 from "../../directives/click-outside/click-outside.directive";
|
|
10
|
+
import * as i5 from "../dr-dot-flashing/dr-dot-flashing.component";
|
|
11
|
+
import * as i6 from "../dr-chat-dropped-files/dr-chat-dropped-files.component";
|
|
12
12
|
const _c0 = ["textAreaElement"];
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
i0.ɵɵ
|
|
16
|
-
i0.ɵɵ
|
|
17
|
-
i0.ɵɵ
|
|
18
|
-
i0.ɵɵ
|
|
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);
|
|
13
|
+
const _c1 = ["fileInput"];
|
|
14
|
+
function DrChatFormWithHistoryComponent_dr_chat_dropped_files_2_Template(rf, ctx) { if (rf & 1) {
|
|
15
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
16
|
+
i0.ɵɵelementStart(0, "dr-chat-dropped-files", 15);
|
|
17
|
+
i0.ɵɵlistener("removeFileEvent", function DrChatFormWithHistoryComponent_dr_chat_dropped_files_2_Template_dr_chat_dropped_files_removeFileEvent_0_listener($event) { i0.ɵɵrestoreView(_r8); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.removeFile($event)); });
|
|
18
|
+
i0.ɵɵpipe(1, "async");
|
|
31
19
|
i0.ɵɵelementEnd();
|
|
32
20
|
} if (rf & 2) {
|
|
33
21
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
34
|
-
i0.ɵɵ
|
|
35
|
-
i0.ɵɵproperty("ngForOf", ctx_r0.droppedFiles);
|
|
22
|
+
i0.ɵɵproperty("files", i0.ɵɵpipeBind1(1, 3, ctx_r0.droppedFiles$))("isRemovable", true)("maxLengthText", 15);
|
|
36
23
|
} }
|
|
37
|
-
function
|
|
38
|
-
const
|
|
39
|
-
i0.ɵɵelementStart(0, "i",
|
|
40
|
-
i0.ɵɵlistener("click", function
|
|
24
|
+
function DrChatFormWithHistoryComponent_i_14_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
26
|
+
i0.ɵɵelementStart(0, "i", 16);
|
|
27
|
+
i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_i_14_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r10); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.sendMessage($event)); });
|
|
41
28
|
i0.ɵɵelementEnd();
|
|
42
29
|
} if (rf & 2) {
|
|
43
30
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
44
|
-
const _r1 = i0.ɵɵreference(
|
|
31
|
+
const _r1 = i0.ɵɵreference(6);
|
|
45
32
|
i0.ɵɵstyleMap(ctx_r3.getSendButtonPosition(_r1));
|
|
46
33
|
} }
|
|
47
|
-
function
|
|
48
|
-
const
|
|
49
|
-
i0.ɵɵelementStart(0, "i",
|
|
50
|
-
i0.ɵɵlistener("click", function
|
|
34
|
+
function DrChatFormWithHistoryComponent_i_15_Template(rf, ctx) { if (rf & 1) {
|
|
35
|
+
const _r12 = i0.ɵɵgetCurrentView();
|
|
36
|
+
i0.ɵɵelementStart(0, "i", 17);
|
|
37
|
+
i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_i_15_Template_i_click_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r11 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r11.abortMessage()); });
|
|
51
38
|
i0.ɵɵelementEnd();
|
|
39
|
+
} if (rf & 2) {
|
|
40
|
+
const ctx_r4 = i0.ɵɵnextContext();
|
|
41
|
+
const _r1 = i0.ɵɵreference(6);
|
|
42
|
+
i0.ɵɵstyleMap(ctx_r4.getSendButtonPosition(_r1));
|
|
52
43
|
} }
|
|
53
|
-
function
|
|
54
|
-
i0.ɵɵelement(0, "dr-dot-flashing",
|
|
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();
|
|
44
|
+
function DrChatFormWithHistoryComponent_dr_dot_flashing_16_Template(rf, ctx) { if (rf & 1) {
|
|
45
|
+
i0.ɵɵelement(0, "dr-dot-flashing", 18);
|
|
62
46
|
} }
|
|
63
47
|
function DrChatFormWithHistoryComponent_ng_container_17_Template(rf, ctx) { if (rf & 1) {
|
|
64
|
-
const
|
|
48
|
+
const _r14 = i0.ɵɵgetCurrentView();
|
|
65
49
|
i0.ɵɵelementContainerStart(0);
|
|
66
|
-
i0.ɵɵelementStart(1, "div",
|
|
67
|
-
i0.ɵɵlistener("clickOutside", function DrChatFormWithHistoryComponent_ng_container_17_Template_div_clickOutside_1_listener() { i0.ɵɵrestoreView(
|
|
50
|
+
i0.ɵɵelementStart(1, "div", 19);
|
|
51
|
+
i0.ɵɵlistener("clickOutside", function DrChatFormWithHistoryComponent_ng_container_17_Template_div_clickOutside_1_listener() { i0.ɵɵrestoreView(_r14); const ctx_r13 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r13.closeHistory()); });
|
|
68
52
|
i0.ɵɵprojection(2);
|
|
69
53
|
i0.ɵɵelementEnd();
|
|
70
54
|
i0.ɵɵelementContainerEnd();
|
|
71
55
|
} if (rf & 2) {
|
|
72
|
-
const
|
|
56
|
+
const ctx_r6 = i0.ɵɵnextContext();
|
|
73
57
|
i0.ɵɵadvance(1);
|
|
74
|
-
i0.ɵɵproperty("@dropdownAnimation",
|
|
58
|
+
i0.ɵɵproperty("@dropdownAnimation", ctx_r6.isShowedHistory ? "visible" : "hidden")("exclude", ".dr-icon-history");
|
|
75
59
|
} }
|
|
76
|
-
const
|
|
77
|
-
const
|
|
78
|
-
const
|
|
79
|
-
const
|
|
60
|
+
const _c2 = function (a0) { return { "message-row_loading": a0 }; };
|
|
61
|
+
const _c3 = function (a0) { return { height: a0 }; };
|
|
62
|
+
const _c4 = function (a0, a1) { return { value: a0, params: a1 }; };
|
|
63
|
+
const _c5 = function (a0, a1, a2) { return { "message-row__input--focused": a0, "message-row__input--filled": a1, "showed-dropdown": a2 }; };
|
|
64
|
+
const _c6 = ["*"];
|
|
80
65
|
export class DrChatFormWithHistoryComponent {
|
|
81
66
|
constructor(cdr, domSanitizer) {
|
|
82
67
|
this.cdr = cdr;
|
|
@@ -84,9 +69,10 @@ export class DrChatFormWithHistoryComponent {
|
|
|
84
69
|
this._textareaInitialHeight = true;
|
|
85
70
|
this.inputFocus = false;
|
|
86
71
|
this.inputHover = false;
|
|
87
|
-
this.droppedFiles = [];
|
|
72
|
+
this.droppedFiles$ = new BehaviorSubject([]);
|
|
88
73
|
this.isShowedHistory = false;
|
|
89
74
|
this.isChatMode = false;
|
|
75
|
+
this.isLoading = false;
|
|
90
76
|
/**
|
|
91
77
|
* Predefined message text
|
|
92
78
|
*
|
|
@@ -122,12 +108,13 @@ export class DrChatFormWithHistoryComponent {
|
|
|
122
108
|
*
|
|
123
109
|
* @type {boolean}
|
|
124
110
|
*/
|
|
125
|
-
this.
|
|
111
|
+
this.showDotFlashing = false;
|
|
126
112
|
/**
|
|
127
113
|
*
|
|
128
|
-
* @type {EventEmitter<{ message: string, files:
|
|
114
|
+
* @type {EventEmitter<{ message: string, files: IFile[] }>}
|
|
129
115
|
*/
|
|
130
116
|
this.send = new EventEmitter();
|
|
117
|
+
this.uploadFiles = new EventEmitter();
|
|
131
118
|
this.abort = new EventEmitter();
|
|
132
119
|
/**
|
|
133
120
|
* Emits when message input value has been changed
|
|
@@ -142,27 +129,18 @@ export class DrChatFormWithHistoryComponent {
|
|
|
142
129
|
event.preventDefault();
|
|
143
130
|
event.stopPropagation();
|
|
144
131
|
this.fileOver = false;
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
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
|
-
}
|
|
132
|
+
const files = event.dataTransfer?.files;
|
|
133
|
+
if (files) {
|
|
134
|
+
this.saveFiles(files);
|
|
159
135
|
}
|
|
160
136
|
}
|
|
161
137
|
}
|
|
162
138
|
removeFile(file) {
|
|
163
|
-
const
|
|
139
|
+
const droppedFiles = this.droppedFiles$.value;
|
|
140
|
+
const index = droppedFiles.indexOf(file);
|
|
164
141
|
if (index >= 0) {
|
|
165
|
-
|
|
142
|
+
droppedFiles.splice(index, 1);
|
|
143
|
+
this.droppedFiles$.next(droppedFiles);
|
|
166
144
|
}
|
|
167
145
|
}
|
|
168
146
|
onDragOver(event) {
|
|
@@ -181,15 +159,16 @@ export class DrChatFormWithHistoryComponent {
|
|
|
181
159
|
}
|
|
182
160
|
sendMessage($event) {
|
|
183
161
|
if (!$event || !$event.shiftKey) {
|
|
184
|
-
$event
|
|
162
|
+
$event?.preventDefault();
|
|
163
|
+
$event?.stopPropagation();
|
|
185
164
|
if (this.waitForReply) {
|
|
186
165
|
return;
|
|
187
166
|
}
|
|
188
|
-
if (this.droppedFiles.length || String(this.message).trim().length) {
|
|
167
|
+
else if (this.droppedFiles$.value.length || String(this.message).trim().length) {
|
|
189
168
|
this._textareaInitialHeight = true;
|
|
190
|
-
this.send.emit({ message: this.message, files: this.droppedFiles });
|
|
169
|
+
this.send.emit({ message: this.message, files: this.droppedFiles$.value });
|
|
191
170
|
this.message = '';
|
|
192
|
-
this.droppedFiles
|
|
171
|
+
this.droppedFiles$.next([]);
|
|
193
172
|
this.cdr.markForCheck();
|
|
194
173
|
}
|
|
195
174
|
}
|
|
@@ -223,52 +202,80 @@ export class DrChatFormWithHistoryComponent {
|
|
|
223
202
|
}
|
|
224
203
|
onFileSelected(event) {
|
|
225
204
|
const input = event.target;
|
|
205
|
+
this.fileOver = false;
|
|
206
|
+
if (input.files.length) {
|
|
207
|
+
this.saveFiles(Array.from(input.files));
|
|
208
|
+
}
|
|
209
|
+
this.fileInput.nativeElement.value = '';
|
|
210
|
+
}
|
|
211
|
+
async saveFiles(files) {
|
|
212
|
+
const uploadedFiles = [];
|
|
213
|
+
for (const file of files) {
|
|
214
|
+
let res = file;
|
|
215
|
+
res.data = (await this.base64Convert(res));
|
|
216
|
+
this.droppedFiles$.next([...this.droppedFiles$.value, res]);
|
|
217
|
+
uploadedFiles.push(res);
|
|
218
|
+
this.cdr.markForCheck();
|
|
219
|
+
this.cdr.detectChanges();
|
|
220
|
+
}
|
|
221
|
+
this.uploadFiles.emit(uploadedFiles.map((item) => ({ data: item.data, name: item.name })));
|
|
222
|
+
}
|
|
223
|
+
base64Convert(file) {
|
|
224
|
+
return new Promise((resolve, reject) => {
|
|
225
|
+
const reader = new FileReader();
|
|
226
|
+
reader.onload = () => resolve(reader.result);
|
|
227
|
+
reader.onerror = (error) => reject(error);
|
|
228
|
+
reader.readAsDataURL(file);
|
|
229
|
+
});
|
|
226
230
|
}
|
|
227
231
|
/** @nocollapse */ static { this.ɵfac = function DrChatFormWithHistoryComponent_Factory(t) { return new (t || DrChatFormWithHistoryComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DomSanitizer)); }; }
|
|
228
232
|
/** @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
233
|
i0.ɵɵviewQuery(_c0, 5);
|
|
234
|
+
i0.ɵɵviewQuery(_c1, 5);
|
|
230
235
|
} if (rf & 2) {
|
|
231
236
|
let _t;
|
|
232
237
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.textAreaElementRef = _t.first);
|
|
238
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.fileInput = _t.first);
|
|
233
239
|
} }, hostVars: 2, hostBindings: function DrChatFormWithHistoryComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
234
240
|
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
241
|
} if (rf & 2) {
|
|
236
242
|
i0.ɵɵclassProp("file-over", ctx.fileOver);
|
|
237
|
-
} }, inputs: { isChatMode: "isChatMode", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply",
|
|
238
|
-
const
|
|
243
|
+
} }, inputs: { isChatMode: "isChatMode", isLoading: "isLoading", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDotFlashing: "showDotFlashing" }, outputs: { send: "send", uploadFiles: "uploadFiles", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c6, decls: 18, vars: 27, consts: [[1, "message-row", 3, "ngClass"], [1, "message-row__input", 3, "ngClass"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent", 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-stop abort-button", 3, "style", "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 4, "ngIf"], [4, "ngIf"], [3, "files", "isRemovable", "maxLengthText", "removeFileEvent"], [1, "dr-icon-send-arrow-up", "send-button", 3, "click"], [1, "dr-icon-stop", "abort-button", 3, "click"], [1, "wait-reply-dot-flashing"], [1, "history-dropdown", 3, "exclude", "clickOutside"]], template: function DrChatFormWithHistoryComponent_Template(rf, ctx) { if (rf & 1) {
|
|
244
|
+
const _r15 = i0.ɵɵgetCurrentView();
|
|
239
245
|
i0.ɵɵprojectionDef();
|
|
240
246
|
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
|
|
241
|
-
i0.ɵɵtemplate(2,
|
|
242
|
-
i0.ɵɵ
|
|
243
|
-
i0.ɵɵ
|
|
244
|
-
i0.ɵɵ
|
|
247
|
+
i0.ɵɵtemplate(2, DrChatFormWithHistoryComponent_dr_chat_dropped_files_2_Template, 2, 5, "dr-chat-dropped-files", 2);
|
|
248
|
+
i0.ɵɵpipe(3, "async");
|
|
249
|
+
i0.ɵɵelementStart(4, "div", 3)(5, "textarea", 4, 5);
|
|
250
|
+
i0.ɵɵlistener("focus", function DrChatFormWithHistoryComponent_Template_textarea_focus_5_listener() { return ctx.inputFocus = true; })("blur", function DrChatFormWithHistoryComponent_Template_textarea_blur_5_listener() { return ctx.inputFocus = false; })("mouseenter", function DrChatFormWithHistoryComponent_Template_textarea_mouseenter_5_listener() { return ctx.inputHover = true; })("mouseleave", function DrChatFormWithHistoryComponent_Template_textarea_mouseleave_5_listener() { return ctx.inputHover = false; })("ngModelChange", function DrChatFormWithHistoryComponent_Template_textarea_ngModelChange_5_listener($event) { return ctx.message = $event; })("ngModelChange", function DrChatFormWithHistoryComponent_Template_textarea_ngModelChange_5_listener($event) { return ctx.onModelChange($event); })("keydown.enter", function DrChatFormWithHistoryComponent_Template_textarea_keydown_enter_5_listener($event) { return ctx.sendMessage($event); });
|
|
251
|
+
i0.ɵɵtext(7, " ");
|
|
245
252
|
i0.ɵɵelementEnd();
|
|
246
|
-
i0.ɵɵelementStart(
|
|
247
|
-
i0.ɵɵtext(
|
|
253
|
+
i0.ɵɵelementStart(8, "div", 6);
|
|
254
|
+
i0.ɵɵtext(9);
|
|
248
255
|
i0.ɵɵelementEnd();
|
|
249
|
-
i0.ɵɵelementStart(
|
|
250
|
-
i0.ɵɵlistener("change", function
|
|
256
|
+
i0.ɵɵelementStart(10, "input", 7, 8);
|
|
257
|
+
i0.ɵɵlistener("change", function DrChatFormWithHistoryComponent_Template_input_change_10_listener($event) { return ctx.onFileSelected($event); });
|
|
251
258
|
i0.ɵɵelementEnd();
|
|
252
|
-
i0.ɵɵelementStart(
|
|
253
|
-
i0.ɵɵlistener("click", function
|
|
259
|
+
i0.ɵɵelementStart(12, "i", 9);
|
|
260
|
+
i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_Template_i_click_12_listener() { return ctx.showHistory(); });
|
|
254
261
|
i0.ɵɵelementEnd();
|
|
255
|
-
i0.ɵɵelementStart(
|
|
256
|
-
i0.ɵɵlistener("click", function
|
|
262
|
+
i0.ɵɵelementStart(13, "i", 10);
|
|
263
|
+
i0.ɵɵlistener("click", function DrChatFormWithHistoryComponent_Template_i_click_13_listener() { i0.ɵɵrestoreView(_r15); const _r2 = i0.ɵɵreference(11); return i0.ɵɵresetView(_r2.click()); });
|
|
257
264
|
i0.ɵɵelementEnd();
|
|
258
|
-
i0.ɵɵtemplate(
|
|
259
|
-
i0.ɵɵtemplate(
|
|
260
|
-
i0.ɵɵtemplate(
|
|
261
|
-
i0.ɵɵtemplate(16, DrChatFormWithHistoryComponent_dr_button_16_Template, 2, 0, "dr-button", 14);
|
|
265
|
+
i0.ɵɵtemplate(14, DrChatFormWithHistoryComponent_i_14_Template, 1, 2, "i", 11);
|
|
266
|
+
i0.ɵɵtemplate(15, DrChatFormWithHistoryComponent_i_15_Template, 1, 2, "i", 12);
|
|
267
|
+
i0.ɵɵtemplate(16, DrChatFormWithHistoryComponent_dr_dot_flashing_16_Template, 1, 0, "dr-dot-flashing", 13);
|
|
262
268
|
i0.ɵɵelementEnd();
|
|
263
|
-
i0.ɵɵtemplate(17, DrChatFormWithHistoryComponent_ng_container_17_Template, 3, 2, "ng-container",
|
|
269
|
+
i0.ɵɵtemplate(17, DrChatFormWithHistoryComponent_ng_container_17_Template, 3, 2, "ng-container", 14);
|
|
264
270
|
i0.ɵɵelementEnd()();
|
|
265
271
|
} if (rf & 2) {
|
|
266
|
-
const _r1 = i0.ɵɵreference(
|
|
272
|
+
const _r1 = i0.ɵɵreference(6);
|
|
273
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(16, _c2, ctx.isLoading));
|
|
267
274
|
i0.ɵɵadvance(1);
|
|
268
|
-
i0.ɵɵproperty("@containerHeightAnimation", i0.ɵɵpureFunction2(
|
|
275
|
+
i0.ɵɵproperty("@containerHeightAnimation", i0.ɵɵpureFunction2(20, _c4, ctx.showHistory ? "expanded" : "collapsed", i0.ɵɵpureFunction1(18, _c3, ctx.getTextAreaHeight(_r1))))("ngClass", i0.ɵɵpureFunction3(23, _c5, ctx.inputFocus, !!(ctx.message == null ? null : ctx.message.length), ctx.isShowedHistory));
|
|
269
276
|
i0.ɵɵadvance(1);
|
|
270
|
-
i0.ɵɵproperty("ngIf",
|
|
271
|
-
i0.ɵɵadvance(
|
|
277
|
+
i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(3, 14, ctx.droppedFiles$).length);
|
|
278
|
+
i0.ɵɵadvance(3);
|
|
272
279
|
i0.ɵɵstyleMap(ctx.getTextAreaHeight(_r1));
|
|
273
280
|
i0.ɵɵpropertyInterpolate("placeholder", ctx.fileOver ? ctx.dropFilePlaceholder : ctx.messagePlaceholder);
|
|
274
281
|
i0.ɵɵproperty("ngModel", ctx.message)("rows", 1);
|
|
@@ -277,14 +284,12 @@ export class DrChatFormWithHistoryComponent {
|
|
|
277
284
|
i0.ɵɵadvance(5);
|
|
278
285
|
i0.ɵɵproperty("ngIf", !ctx.waitForReply);
|
|
279
286
|
i0.ɵɵadvance(1);
|
|
280
|
-
i0.ɵɵproperty("ngIf", ctx.waitForReply && ctx.
|
|
287
|
+
i0.ɵɵproperty("ngIf", ctx.waitForReply && !ctx.showDotFlashing);
|
|
281
288
|
i0.ɵɵadvance(1);
|
|
282
|
-
i0.ɵɵproperty("ngIf", ctx.waitForReply &&
|
|
283
|
-
i0.ɵɵadvance(1);
|
|
284
|
-
i0.ɵɵproperty("ngIf", ctx.waitForReply);
|
|
289
|
+
i0.ɵɵproperty("ngIf", ctx.waitForReply && ctx.showDotFlashing);
|
|
285
290
|
i0.ɵɵadvance(1);
|
|
286
291
|
i0.ɵɵproperty("ngIf", !ctx.isChatMode);
|
|
287
|
-
} }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.
|
|
292
|
+
} }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgIf, i4.ClickOutsideDirective, i5.DrDotFlashingComponent, i6.DrChatDroppedFilesComponent, i3.AsyncPipe], styles: ["[_nghost-%COMP%] {--send-button-offset: 42px;display:flex;flex-direction:column;align-items:center;padding:0 16px}[_nghost-%COMP%] .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}[_nghost-%COMP%] .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}[_nghost-%COMP%] .message-row__input .abort-button, [_nghost-%COMP%] .message-row__input .send-button{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;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}[_nghost-%COMP%] .message-row__input .dr-icon-history, [_nghost-%COMP%] .message-row__input .dr-icon-attachment{display:flex;align-items:center;position:absolute;cursor:pointer;width:32px;height:48px;left:16px;top:-1px}[_nghost-%COMP%] .message-row__input .dr-icon-attachment{left:52px}[_nghost-%COMP%] .message-row__input .send-button{opacity:.5;pointer-events:none}[_nghost-%COMP%] .message-row__input--focused{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{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}[_nghost-%COMP%] .message-row__input--filled .send-button{opacity:1;pointer-events:all}[_nghost-%COMP%] .message-row__input .message-input-tmp{display:none}[_nghost-%COMP%] .message-row__input.showed-dropdown .send-button{opacity:.5}[_nghost-%COMP%] .message-row__input .wait-reply-dot-flashing{display:flex;position:absolute;align-items:center;width:32px;height:48px;right:25px}[_nghost-%COMP%] .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}[_nghost-%COMP%] .message-row__input textarea, [_nghost-%COMP%] .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}[_nghost-%COMP%] .message-row__input textarea:focus, [_nghost-%COMP%] .message-row__input .message-input-tmp:focus{border:none}[_nghost-%COMP%] .message-row__input textarea::placeholder, [_nghost-%COMP%] .message-row__input .message-input-tmp::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}[_nghost-%COMP%] .history-dropdown{width:100%;max-height:220px;overflow-y:auto;padding:12px 16px 0}[_nghost-%COMP%] .showed-dropdown textarea{visibility:hidden;position:absolute}[_nghost-%COMP%] .showed-dropdown .message-input-tmp{display:block;margin-left:inherit;white-space:nowrap;font-family:monospace;overflow:hidden;text-overflow:ellipsis}[_nghost-%COMP%] .showed-dropdown .send-button{top:2.5px!important}[_nghost-%COMP%] dr-chat-dropped-files{margin-right:auto}[_nghost-%COMP%] .message-row_loading .send-button, [_nghost-%COMP%] .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}"], data: { animation: [
|
|
288
293
|
trigger('containerHeightAnimation', [
|
|
289
294
|
state('collapsed', style({ height: '{{height}}' }), { params: { height: '48px' } }),
|
|
290
295
|
state('expanded', style({
|
|
@@ -340,12 +345,17 @@ export class DrChatFormWithHistoryComponent {
|
|
|
340
345
|
style({ display: 'none' }),
|
|
341
346
|
]),
|
|
342
347
|
]),
|
|
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 <
|
|
348
|
+
], template: "<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isLoading }\">\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 <dr-chat-dropped-files\n *ngIf=\"(droppedFiles$ | async).length\"\n [files]=\"droppedFiles$ | async\"\n [isRemovable]=\"true\"\n [maxLengthText]=\"15\"\n (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\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\n <i\n *ngIf=\"waitForReply && !showDotFlashing\"\n [style]=\"getSendButtonPosition(textAreaElement)\"\n class=\"dr-icon-stop abort-button\"\n (click)=\"abortMessage()\"></i>\n <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\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::ng-deep{--send-button-offset: 42px;display:flex;flex-direction:column;align-items:center;padding:0 16px}:host::ng-deep .message-row{display:flex;justify-content:center;width:100%;padding:0 0 21px;max-width:956px}:host::ng-deep .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::ng-deep .message-row__input .abort-button,:host::ng-deep .message-row__input .send-button{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;color:#fff;transition:.15s ease-in-out;background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box}:host::ng-deep .message-row__input .dr-icon-history,:host::ng-deep .message-row__input .dr-icon-attachment{display:flex;align-items:center;position:absolute;cursor:pointer;width:32px;height:48px;left:16px;top:-1px}:host::ng-deep .message-row__input .dr-icon-attachment{left:52px}:host::ng-deep .message-row__input .send-button{opacity:.5;pointer-events:none}:host::ng-deep .message-row__input--focused{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;height:auto!important;background:#fff}:host::ng-deep .message-row__input--filled{box-shadow:8px 8px 16px #6969ff40,-4px -4px 8px #40b6e340,8px 8px 60px #00000040;background:#fff}:host::ng-deep .message-row__input--filled .send-button{opacity:1;pointer-events:all}:host::ng-deep .message-row__input .message-input-tmp{display:none}:host::ng-deep .message-row__input.showed-dropdown .send-button{opacity:.5}:host::ng-deep .message-row__input .wait-reply-dot-flashing{display:flex;position:absolute;align-items:center;width:32px;height:48px;right:25px}:host::ng-deep .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::ng-deep .message-row__input textarea,:host::ng-deep .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::ng-deep .message-row__input textarea:focus,:host::ng-deep .message-row__input .message-input-tmp:focus{border:none}:host::ng-deep .message-row__input textarea::placeholder,:host::ng-deep .message-row__input .message-input-tmp::placeholder{color:#9ea1aa}:host::ng-deep .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host::ng-deep .history-dropdown{width:100%;max-height:220px;overflow-y:auto;padding:12px 16px 0}:host::ng-deep .showed-dropdown textarea{visibility:hidden;position:absolute}:host::ng-deep .showed-dropdown .message-input-tmp{display:block;margin-left:inherit;white-space:nowrap;font-family:monospace;overflow:hidden;text-overflow:ellipsis}:host::ng-deep .showed-dropdown .send-button{top:2.5px!important}:host::ng-deep dr-chat-dropped-files{margin-right:auto}:host::ng-deep .message-row_loading .send-button,:host::ng-deep .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}\n"] }]
|
|
344
349
|
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, { textAreaElementRef: [{
|
|
345
350
|
type: ViewChild,
|
|
346
351
|
args: ['textAreaElement']
|
|
352
|
+
}], fileInput: [{
|
|
353
|
+
type: ViewChild,
|
|
354
|
+
args: ['fileInput']
|
|
347
355
|
}], isChatMode: [{
|
|
348
356
|
type: Input
|
|
357
|
+
}], isLoading: [{
|
|
358
|
+
type: Input
|
|
349
359
|
}], message: [{
|
|
350
360
|
type: Input
|
|
351
361
|
}], messagePlaceholder: [{
|
|
@@ -356,10 +366,12 @@ export class DrChatFormWithHistoryComponent {
|
|
|
356
366
|
type: Input
|
|
357
367
|
}], waitForReply: [{
|
|
358
368
|
type: Input
|
|
359
|
-
}],
|
|
369
|
+
}], showDotFlashing: [{
|
|
360
370
|
type: Input
|
|
361
371
|
}], send: [{
|
|
362
372
|
type: Output
|
|
373
|
+
}], uploadFiles: [{
|
|
374
|
+
type: Output
|
|
363
375
|
}], abort: [{
|
|
364
376
|
type: Output
|
|
365
377
|
}], inputChange: [{
|
|
@@ -377,4 +389,4 @@ export class DrChatFormWithHistoryComponent {
|
|
|
377
389
|
type: HostListener,
|
|
378
390
|
args: ['dragleave', ['$event']]
|
|
379
391
|
}] }); })();
|
|
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"]}
|
|
392
|
+
//# 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 { IFIle } from '../../models/chat';\nimport { trigger, state, style, transition, animate, query, animateChild } from '@angular/animations';\nimport { BehaviorSubject } from 'rxjs';\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    @ViewChild('fileInput') fileInput: ElementRef;\n    _textareaInitialHeight = true;\n    inputFocus = false;\n    inputHover = false;\n\n    droppedFiles$ = new BehaviorSubject<IFIle[]>([]);\n    isShowedHistory = false;\n\n    @Input() isChatMode = false;\n\n    @Input() isLoading = 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() showDotFlashing = false;\n\n    /**\n     *\n     * @type {EventEmitter<{ message: string, files: IFile[] }>}\n     */\n    @Output() send = new EventEmitter<{ message: string; files: IFIle[] }>();\n    @Output() uploadFiles = new EventEmitter<IFIle[]>();\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            const files = event.dataTransfer?.files;\n            if (files) {\n                this.saveFiles(files);\n            }\n        }\n    }\n\n    removeFile(file) {\n        const droppedFiles = this.droppedFiles$.value;\n        const index = droppedFiles.indexOf(file);\n        if (index >= 0) {\n            droppedFiles.splice(index, 1);\n            this.droppedFiles$.next(droppedFiles);\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?.preventDefault();\n            $event?.stopPropagation();\n            if (this.waitForReply) {\n                return;\n            } else if (this.droppedFiles$.value.length || String(this.message).trim().length) {\n                this._textareaInitialHeight = true;\n                this.send.emit({ message: this.message, files: this.droppedFiles$.value });\n                this.message = '';\n                this.droppedFiles$.next([]);\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        this.fileOver = false;\n        if (input.files.length) {\n            this.saveFiles(Array.from(input.files));\n        }\n        this.fileInput.nativeElement.value = '';\n    }\n\n    private async saveFiles(files: Array<File>) {\n        const uploadedFiles = [];\n        for (const file of files) {\n            let res = file as IFIle;\n            res.data = (await this.base64Convert(res)) as string;\n            this.droppedFiles$.next([...this.droppedFiles$.value, res]);\n            uploadedFiles.push(res);\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n        }\n        this.uploadFiles.emit(uploadedFiles.map((item) => ({ data: item.data, name: item.name })));\n    }\n\n    private base64Convert(file: any) {\n        return new Promise((resolve, reject) => {\n            const reader = new FileReader();\n            reader.onload = () => resolve(reader.result as string);\n            reader.onerror = (error) => reject(error);\n            reader.readAsDataURL(file);\n        });\n    }\n}\n","<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isLoading }\">\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        <dr-chat-dropped-files\n            *ngIf=\"(droppedFiles$ | async).length\"\n            [files]=\"droppedFiles$ | async\"\n            [isRemovable]=\"true\"\n            [maxLengthText]=\"15\"\n            (removeFileEvent)=\"removeFile($event)\"></dr-chat-dropped-files>\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\n            <i\n                *ngIf=\"waitForReply && !showDotFlashing\"\n                [style]=\"getSendButtonPosition(textAreaElement)\"\n                class=\"dr-icon-stop abort-button\"\n                (click)=\"abortMessage()\"></i>\n            <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\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"]}
|