@datarailsshared/datarailsshared 1.6.27 → 1.6.29

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.
@@ -166,8 +166,9 @@ export class DrChatFormDropdownComponent {
166
166
  onFileSelected(event) {
167
167
  const input = event.target;
168
168
  this.fileOver = false;
169
- if (input.files.length) {
170
- this.saveFiles(Array.from(input.files));
169
+ const files = input.files;
170
+ if (files && files.length) {
171
+ this.saveFiles(Array.from(files));
171
172
  }
172
173
  this.fileInput.nativeElement.value = '';
173
174
  }
@@ -285,4 +286,4 @@ export class DrChatFormDropdownComponent {
285
286
  type: HostListener,
286
287
  args: ['dragleave', ['$event']]
287
288
  }] }); })();
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-chat-form-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.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 { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'dr-chat-form-dropdown',\n    templateUrl: './dr-chat-form-dropdown.component.html',\n    styleUrls: ['./dr-chat-form-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrChatFormDropdownComponent {\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\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<void>();\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 = '30px';\n        } else {\n            textAreaElement.style.height = 'auto';\n            textAreaElement.style.height = textAreaElement.scrollHeight + 'px';\n        }\n\n        return `${textAreaElement.style.height}`;\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        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.trim()?.length,\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        </div>\n        <div class=\"message-row__btns\">\n            <ng-content></ng-content>\n            <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n            <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n            <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n            <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n        </div>\n    </div>\n</div>\n"]}
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-chat-form-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;ICP/B,iDAK2C;IAAvC,mOAAmB,eAAA,yBAAkB,CAAA,IAAC;;IAAC,iBAAwB;;;IAH/D,kEAA+B,qBAAA,qBAAA;;;;IAwB/B,6BAAiG;IAAxE,wKAAS,eAAA,0BAAmB,CAAA,IAAC;IAA2C,iBAAI;;;;IAErG,6BAAuG;IAAzB,oKAAS,eAAA,sBAAc,CAAA,IAAC;IAAC,iBAAI;;;IAC3G,sCAA2G;;;;;ADdvH,MAAM,OAAO,2BAA2B;IAuEpC,YACc,GAAsB,EACtB,YAA0B;QAD1B,QAAG,GAAH,GAAG,CAAmB;QACtB,iBAAY,GAAZ,YAAY,CAAc;QAtExC,2BAAsB,GAAG,IAAI,CAAC;QAC9B,eAAU,GAAG,KAAK,CAAC;QACnB,eAAU,GAAG,KAAK,CAAC;QAEnB,kBAAa,GAAG,IAAI,eAAe,CAAU,EAAE,CAAC,CAAC;QAExC,cAAS,GAAG,KAAK,CAAC;QAE3B;;;;WAIG;QACM,YAAO,GAAG,EAAE,CAAC;QAEtB;;;;WAIG;QACM,uBAAkB,GAAG,gBAAgB,CAAC;QAE/C;;;;WAIG;QACM,cAAS,GAAG,KAAK,CAAC;QAE3B;;;;WAIG;QACM,wBAAmB,GAAG,mBAAmB,CAAC;QAEnD;;;;WAIG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B;;;;WAIG;QACM,oBAAe,GAAG,KAAK,CAAC;QAEjC;;;WAGG;QACO,SAAI,GAAG,IAAI,YAAY,EAAuC,CAAC;QAC/D,gBAAW,GAAG,IAAI,YAAY,EAAW,CAAC;QAC1C,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE3C;;;;WAIG;QAEO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAEnB,aAAQ,GAAG,KAAK,CAAC;IAK9C,CAAC;IAGJ,MAAM,CAAC,KAAU;QACb,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC;YACxC,IAAI,KAAK,EAAE;gBACP,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;aACzB;SACJ;IACL,CAAC;IAED,UAAU,CAAC,IAAW;QAClB,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;QAC9C,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzC,IAAI,KAAK,IAAI,CAAC,EAAE;YACZ,YAAY,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACzC;IACL,CAAC;IAGD,UAAU,CAAC,KAAgB;QACvB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAGD,WAAW,CAAC,KAAgB;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACzB;IACL,CAAC;IAED,WAAW,CAAC,MAA6B;QACrC,IAAI,CAAC,MAAM,IAAI,CAAE,MAAwB,CAAC,QAAQ,EAAE;YAChD,MAAM,EAAE,cAAc,EAAE,CAAC;YACzB,MAAM,EAAE,eAAe,EAAE,CAAC;YAC1B,IAAI,IAAI,CAAC,YAAY,EAAE;gBACnB,OAAO;aACV;iBAAM,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE;gBAC9E,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;gBACnC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC;gBAC3E,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC5B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aAC3B;SACJ;IACL,CAAC;IAED,YAAY;QACR,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,iBAAiB,CAAC,eAAoC;QAClD,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;SACzC;aAAM;YACH,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;YACtC,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,eAAe,CAAC,YAAY,GAAG,IAAI,CAAC;SACtE;QAED,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;IAC7C,CAAC;IAED,cAAc,CAAC,KAAY;QACvB,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B,CAAC;QAC/C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;QAC1B,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE;YACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;IAC5C,CAAC;IAEO,KAAK,CAAC,SAAS,CAAC,KAAkB;QACtC,MAAM,aAAa,GAAG,EAAE,CAAC;QACzB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;YACtB,IAAI,GAAG,GAAG,IAAa,CAAC;YACxB,GAAG,CAAC,IAAI,GAAG,CAAC,MAAM,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAW,CAAC;YACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;YAC5D,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC5B;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAC/F,CAAC;IAEO,aAAa,CAAC,IAAS;QAC3B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACnC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAgB,CAAC,CAAC;YACvD,MAAM,CAAC,OAAO,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC1C,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC;+GAvLQ,2BAA2B;mGAA3B,2BAA2B;;;;;;;;gHAA3B,kBAAc,mGAAd,sBAAkB,qGAAlB,uBAAmB;;;;;YCtBhC,8BAA0E,aAAA;YAOlE,gHAKmE;;YAEnE,8BAA8C,qBAAA;YAGtC,2HAAsB,IAAI,IAAC,4GACN,KAAK,IADC,wHAEA,IAAI,IAFJ,wHAGA,KAAK,IAHL,2IAAA,mHAOV,yBAAqB,IAPX,mHAUV,uBAAmB,IAVT;YAW/B,4BAAA;YAAA,iBAAW,EAAA;YAEf,8BAA+B;YAC3B,kBAAyB;YACzB,oCAAkF;YAApC,gHAAU,0BAAsB,IAAC;YAA/E,iBAAkF;YAClF,0EAAqG;YAErG,2EAA2G;YAC3G,uGAA2G;YAC/G,iBAAM,EAAA,EAAA;;;;YArCW,oEAAgD;YAGjE,eAGE;YAHF,sKAGE;YAEG,eAAoC;YAApC,sEAAoC;YAejC,eAA4C;YAA5C,yCAA4C;YAG5C,wGAAuE;YALvE,qCAAqB,WAAA;YAYrB,eAAmB;YAAnB,wCAAmB;YAEnB,eAAsC;YAAtC,+DAAsC;YACxB,eAAqC;YAArC,8DAAqC;;;uFDdtD,2BAA2B;cANvC,SAAS;2BACI,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM;+FAGjB,kBAAkB;kBAA/C,SAAS;mBAAC,iBAAiB;YACJ,SAAS;kBAAhC,SAAS;mBAAC,WAAW;YAOb,SAAS;kBAAjB,KAAK;YAOG,OAAO;kBAAf,KAAK;YAOG,kBAAkB;kBAA1B,KAAK;YAOG,SAAS;kBAAjB,KAAK;YAOG,mBAAmB;kBAA3B,KAAK;YAOG,YAAY;kBAApB,KAAK;YAOG,eAAe;kBAAvB,KAAK;YAMI,IAAI;kBAAb,MAAM;YACG,WAAW;kBAApB,MAAM;YACG,KAAK;kBAAd,MAAM;YAQG,WAAW;kBAApB,MAAM;YAEyB,QAAQ;kBAAvC,WAAW;mBAAC,iBAAiB;YAQ9B,MAAM;kBADL,YAAY;mBAAC,MAAM,EAAE,CAAC,QAAQ,CAAC;YAwBhC,UAAU;kBADT,YAAY;mBAAC,UAAU,EAAE,CAAC,QAAQ,CAAC;YAUpC,WAAW;kBADV,YAAY;mBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","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 { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'dr-chat-form-dropdown',\n    templateUrl: './dr-chat-form-dropdown.component.html',\n    styleUrls: ['./dr-chat-form-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrChatFormDropdownComponent {\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\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<void>();\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: IFIle) {\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: Event | KeyboardEvent) {\n        if (!$event || !($event as KeyboardEvent).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 = '30px';\n        } else {\n            textAreaElement.style.height = 'auto';\n            textAreaElement.style.height = textAreaElement.scrollHeight + 'px';\n        }\n\n        return `${textAreaElement.style.height}`;\n    }\n\n    onFileSelected(event: Event) {\n        const input = event.target as HTMLInputElement;\n        this.fileOver = false;\n        const files = input.files;\n        if (files && files.length) {\n            this.saveFiles(Array.from(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        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.trim()?.length,\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        </div>\n        <div class=\"message-row__btns\">\n            <ng-content></ng-content>\n            <input #fileInput type=\"file\" hidden multiple (change)=\"onFileSelected($event)\" />\n            <i *ngIf=\"!waitForReply\" (click)=\"sendMessage($event)\" class=\"dr-icon-send-arrow-up send-button\"></i>\n\n            <i *ngIf=\"waitForReply && !showDotFlashing\" class=\"dr-icon-stop abort-button\" (click)=\"abortMessage()\"></i>\n            <dr-dot-flashing *ngIf=\"waitForReply && showDotFlashing\" class=\"wait-reply-dot-flashing\"></dr-dot-flashing>\n        </div>\n    </div>\n</div>\n"]}
@@ -6800,8 +6800,9 @@ class DrChatFormDropdownComponent {
6800
6800
  onFileSelected(event) {
6801
6801
  const input = event.target;
6802
6802
  this.fileOver = false;
6803
- if (input.files.length) {
6804
- this.saveFiles(Array.from(input.files));
6803
+ const files = input.files;
6804
+ if (files && files.length) {
6805
+ this.saveFiles(Array.from(files));
6805
6806
  }
6806
6807
  this.fileInput.nativeElement.value = '';
6807
6808
  }