@datarailsshared/datarailsshared 1.6.37 → 1.6.41

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.
@@ -79,6 +79,7 @@ export class DrChatComponent {
79
79
  * @type {boolean}
80
80
  */
81
81
  this.waitForReply = false;
82
+ this.scrollDelay = 250;
82
83
  this.suggestionSelect = new EventEmitter();
83
84
  }
84
85
  ngAfterViewInit() {
@@ -105,7 +106,7 @@ export class DrChatComponent {
105
106
  this.messagesContainer.nativeElement.scrollTo(scrollToOptions);
106
107
  this.cdr.markForCheck();
107
108
  }
108
- });
109
+ }, this.scrollDelay);
109
110
  }
110
111
  ngOnDestroy() {
111
112
  this.destroy$.next();
@@ -138,7 +139,7 @@ export class DrChatComponent {
138
139
  let _t;
139
140
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.messagesContainer = _t.first);
140
141
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx._chatSuggestions = _t.first);
141
- } }, inputs: { fullScreen: "fullScreen", noMessagesPlaceholder: "noMessagesPlaceholder", contentUpdateSubject: "contentUpdateSubject", scrollBottom: "scrollBottom", suggestions: "suggestions", reopen: "reopen", waitForReply: "waitForReply" }, outputs: { suggestionSelect: "suggestionSelect" }, features: [i0.ɵɵProvidersFeature([DrChatCustomMessageService])], ngContentSelectors: _c3, decls: 11, vars: 6, consts: [[1, "chat"], [1, "chat__sticky-top"], [3, "ngTemplateOutlet", 4, "ngIf"], [1, "chat__alert"], ["class", "chat__empty-state", 4, "ngIf"], ["class", "chat__messages", 4, "ngIf"], ["class", "chat__suggestions", 3, "values", "fullScreen", "waitForReply", "chat__suggestions--full-height", "buttonMode", "suggestionSelect", 4, "ngIf"], [1, "form"], [3, "ngTemplateOutlet"], [1, "chat__empty-state"], [1, "chat__empty-state__text"], [1, "chat__messages"], [1, "chat__messages__container"], ["messagesContainer", ""], [1, "chat__suggestions", 3, "values", "fullScreen", "waitForReply", "buttonMode", "suggestionSelect"]], template: function DrChatComponent_Template(rf, ctx) { if (rf & 1) {
142
+ } }, inputs: { fullScreen: "fullScreen", noMessagesPlaceholder: "noMessagesPlaceholder", contentUpdateSubject: "contentUpdateSubject", scrollBottom: "scrollBottom", suggestions: "suggestions", reopen: "reopen", waitForReply: "waitForReply", scrollDelay: "scrollDelay" }, outputs: { suggestionSelect: "suggestionSelect" }, features: [i0.ɵɵProvidersFeature([DrChatCustomMessageService])], ngContentSelectors: _c3, decls: 11, vars: 6, consts: [[1, "chat"], [1, "chat__sticky-top"], [3, "ngTemplateOutlet", 4, "ngIf"], [1, "chat__alert"], ["class", "chat__empty-state", 4, "ngIf"], ["class", "chat__messages", 4, "ngIf"], ["class", "chat__suggestions", 3, "values", "fullScreen", "waitForReply", "chat__suggestions--full-height", "buttonMode", "suggestionSelect", 4, "ngIf"], [1, "form"], [3, "ngTemplateOutlet"], [1, "chat__empty-state"], [1, "chat__empty-state__text"], [1, "chat__messages"], [1, "chat__messages__container"], ["messagesContainer", ""], [1, "chat__suggestions", 3, "values", "fullScreen", "waitForReply", "buttonMode", "suggestionSelect"]], template: function DrChatComponent_Template(rf, ctx) { if (rf & 1) {
142
143
  i0.ɵɵprojectionDef(_c2);
143
144
  i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
144
145
  i0.ɵɵtemplate(2, DrChatComponent_ng_container_2_Template, 1, 1, "ng-container", 2);
@@ -181,6 +182,8 @@ export class DrChatComponent {
181
182
  type: Input
182
183
  }], waitForReply: [{
183
184
  type: Input
185
+ }], scrollDelay: [{
186
+ type: Input
184
187
  }], messagesContainer: [{
185
188
  type: ViewChild,
186
189
  args: ['messagesContainer']
@@ -199,4 +202,4 @@ export class DrChatComponent {
199
202
  type: ViewChild,
200
203
  args: [DrChatSuggestionsComponent]
201
204
  }] }); })();
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-chat/chat.component.ts","../../../../../projects/datarailsshared/src/lib/dr-chat/chat.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    ViewChild,\n    ElementRef,\n    ContentChildren,\n    QueryList,\n    AfterViewInit,\n    ContentChild,\n    ChangeDetectorRef,\n    Output,\n    EventEmitter,\n    OnDestroy,\n    TemplateRef,\n} from '@angular/core';\n\nimport { DrChatFormComponent } from './dr-chat-form/chat-form.component';\nimport { DrChatMessageComponent } from './dr-chat-message/chat-message.component';\nimport { DrChatCustomMessageService } from './dr-chat-message/dr-chat-message-custom/chat-custom-message.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrChatSuggestionsComponent } from './dr-chat-suggestions/chat-suggestions.component';\n\n@Component({\n    selector: 'dr-chat',\n    styleUrls: ['./chat.component.scss'],\n    templateUrl: 'chat.component.html',\n    providers: [DrChatCustomMessageService],\n})\nexport class DrChatComponent implements AfterViewInit, OnDestroy {\n    private destroy$ = new Subject<void>();\n\n    @Input() fullScreen: boolean;\n    @Input() noMessagesPlaceholder = 'No messages yet.';\n\n    @Input() set contentUpdateSubject(value: Subject<any>) {\n        if (value) {\n            value.pipe(takeUntil(this.destroy$)).subscribe(() => {\n                this.updateView();\n            });\n        }\n    }\n\n    /**\n     * Scroll chat to the bottom of the list when a new message arrives\n     */\n    @Input()\n    get scrollBottom(): boolean {\n        return this._scrollBottom;\n    }\n\n    set scrollBottom(value: boolean) {\n        this._scrollBottom = !!value;\n    }\n\n    protected _scrollBottom = true;\n\n    @Input() suggestions: string[] = [];\n    @Input() reopen: boolean;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n\n    @ViewChild('messagesContainer') messagesContainer: ElementRef;\n    @ContentChildren(DrChatMessageComponent) messages: QueryList<DrChatMessageComponent>;\n    @ContentChild(DrChatFormComponent) chatForm: DrChatFormComponent;\n    @ContentChild('drChatHeader') chatHeader: TemplateRef<unknown>;\n    @Output() suggestionSelect: EventEmitter<string> = new EventEmitter<string>();\n    @ViewChild(DrChatSuggestionsComponent) _chatSuggestions: DrChatSuggestionsComponent;\n\n    public get messagesContainerWithScroll(): boolean {\n        return (\n            this.messagesContainer &&\n            this.messagesContainer.nativeElement.scrollHeight > this.messagesContainer.nativeElement.offsetHeight\n        );\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit() {\n        this.messages.changes.subscribe((messages) => {\n            this.messages = messages;\n            this.updateView();\n        });\n\n        this.updateView();\n    }\n\n    updateView() {\n        if (this.scrollBottom) {\n            this.scrollListBottom();\n        }\n    }\n\n    scrollListBottom() {\n        setTimeout(() => {\n            if (this.messagesContainer) {\n                const scrollToOptions: any = {\n                    top: this.messagesContainer.nativeElement.scrollHeight,\n                };\n\n                if (!this.reopen) {\n                    scrollToOptions.behavior = 'smooth';\n                }\n\n                this.messagesContainer.nativeElement.scrollTo(scrollToOptions);\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    clearHiddenSuggestions() {\n        if (this._chatSuggestions) {\n            this._chatSuggestions.clearHidden();\n        }\n    }\n\n    hideSuggestions(): void {\n        if (this._chatSuggestions?.isSuggestedMenuOpen) {\n            this._chatSuggestions.toggleSuggestedMenu();\n        }\n    }\n}\n","<div class=\"chat\" [class.chat--in-full-screen]=\"fullScreen\">\n    <div class=\"chat__sticky-top\">\n        <ng-container *ngIf=\"chatHeader\" [ngTemplateOutlet]=\"chatHeader\"></ng-container>\n\n        <div class=\"chat__alert\">\n            <ng-content select=\"dr-chat-alert\"></ng-content>\n        </div>\n    </div>\n\n    <div *ngIf=\"!messages?.length\" class=\"chat__empty-state\">\n        <span class=\"chat__empty-state__text\">{{ noMessagesPlaceholder }}</span>\n    </div>\n\n    <div *ngIf=\"messages?.length\" class=\"chat__messages\">\n        <div\n            #messagesContainer\n            class=\"chat__messages__container\"\n            [class.chat__messages__container--scroll]=\"messagesContainerWithScroll\">\n            <ng-content select=\"dr-chat-message\"></ng-content>\n        </div>\n    </div>\n\n    <dr-chat-suggestions\n        *ngIf=\"suggestions?.length\"\n        [values]=\"suggestions\"\n        [fullScreen]=\"fullScreen\"\n        [waitForReply]=\"waitForReply\"\n        class=\"chat__suggestions\"\n        [class.chat__suggestions--full-height]=\"fullScreen && !messages?.length\"\n        [buttonMode]=\"!!messages?.length\"\n        (suggestionSelect)=\"suggestionSelect.emit($event)\">\n    </dr-chat-suggestions>\n\n    <div class=\"form\">\n        <ng-content select=\"dr-chat-form\"></ng-content>\n        <ng-content select=\"dr-ai-search-input\"></ng-content>\n    </div>\n</div>\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-chat/chat.component.ts","../../../../../projects/datarailsshared/src/lib/dr-chat/chat.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    ViewChild,\n    ElementRef,\n    ContentChildren,\n    QueryList,\n    AfterViewInit,\n    ContentChild,\n    ChangeDetectorRef,\n    Output,\n    EventEmitter,\n    OnDestroy,\n    TemplateRef,\n} from '@angular/core';\n\nimport { DrChatFormComponent } from './dr-chat-form/chat-form.component';\nimport { DrChatMessageComponent } from './dr-chat-message/chat-message.component';\nimport { DrChatCustomMessageService } from './dr-chat-message/dr-chat-message-custom/chat-custom-message.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DrChatSuggestionsComponent } from './dr-chat-suggestions/chat-suggestions.component';\n\n@Component({\n    selector: 'dr-chat',\n    styleUrls: ['./chat.component.scss'],\n    templateUrl: 'chat.component.html',\n    providers: [DrChatCustomMessageService],\n})\nexport class DrChatComponent implements AfterViewInit, OnDestroy {\n    private destroy$ = new Subject<void>();\n\n    @Input() fullScreen: boolean;\n    @Input() noMessagesPlaceholder = 'No messages yet.';\n\n    @Input() set contentUpdateSubject(value: Subject<any>) {\n        if (value) {\n            value.pipe(takeUntil(this.destroy$)).subscribe(() => {\n                this.updateView();\n            });\n        }\n    }\n\n    /**\n     * Scroll chat to the bottom of the list when a new message arrives\n     */\n    @Input()\n    get scrollBottom(): boolean {\n        return this._scrollBottom;\n    }\n\n    set scrollBottom(value: boolean) {\n        this._scrollBottom = !!value;\n    }\n\n    protected _scrollBottom = true;\n\n    @Input() suggestions: string[] = [];\n    @Input() reopen: boolean;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n    @Input() scrollDelay = 250;\n\n    @ViewChild('messagesContainer') messagesContainer: ElementRef;\n    @ContentChildren(DrChatMessageComponent) messages: QueryList<DrChatMessageComponent>;\n    @ContentChild(DrChatFormComponent) chatForm: DrChatFormComponent;\n    @ContentChild('drChatHeader') chatHeader: TemplateRef<unknown>;\n    @Output() suggestionSelect: EventEmitter<string> = new EventEmitter<string>();\n    @ViewChild(DrChatSuggestionsComponent) _chatSuggestions: DrChatSuggestionsComponent;\n\n    public get messagesContainerWithScroll(): boolean {\n        return (\n            this.messagesContainer &&\n            this.messagesContainer.nativeElement.scrollHeight > this.messagesContainer.nativeElement.offsetHeight\n        );\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit() {\n        this.messages.changes.subscribe((messages) => {\n            this.messages = messages;\n            this.updateView();\n        });\n\n        this.updateView();\n    }\n\n    updateView() {\n        if (this.scrollBottom) {\n            this.scrollListBottom();\n        }\n    }\n\n    scrollListBottom() {\n        setTimeout(() => {\n            if (this.messagesContainer) {\n                const scrollToOptions: any = {\n                    top: this.messagesContainer.nativeElement.scrollHeight,\n                };\n\n                if (!this.reopen) {\n                    scrollToOptions.behavior = 'smooth';\n                }\n\n                this.messagesContainer.nativeElement.scrollTo(scrollToOptions);\n                this.cdr.markForCheck();\n            }\n        }, this.scrollDelay);\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    clearHiddenSuggestions() {\n        if (this._chatSuggestions) {\n            this._chatSuggestions.clearHidden();\n        }\n    }\n\n    hideSuggestions(): void {\n        if (this._chatSuggestions?.isSuggestedMenuOpen) {\n            this._chatSuggestions.toggleSuggestedMenu();\n        }\n    }\n}\n","<div class=\"chat\" [class.chat--in-full-screen]=\"fullScreen\">\n    <div class=\"chat__sticky-top\">\n        <ng-container *ngIf=\"chatHeader\" [ngTemplateOutlet]=\"chatHeader\"></ng-container>\n\n        <div class=\"chat__alert\">\n            <ng-content select=\"dr-chat-alert\"></ng-content>\n        </div>\n    </div>\n\n    <div *ngIf=\"!messages?.length\" class=\"chat__empty-state\">\n        <span class=\"chat__empty-state__text\">{{ noMessagesPlaceholder }}</span>\n    </div>\n\n    <div *ngIf=\"messages?.length\" class=\"chat__messages\">\n        <div\n            #messagesContainer\n            class=\"chat__messages__container\"\n            [class.chat__messages__container--scroll]=\"messagesContainerWithScroll\">\n            <ng-content select=\"dr-chat-message\"></ng-content>\n        </div>\n    </div>\n\n    <dr-chat-suggestions\n        *ngIf=\"suggestions?.length\"\n        [values]=\"suggestions\"\n        [fullScreen]=\"fullScreen\"\n        [waitForReply]=\"waitForReply\"\n        class=\"chat__suggestions\"\n        [class.chat__suggestions--full-height]=\"fullScreen && !messages?.length\"\n        [buttonMode]=\"!!messages?.length\"\n        (suggestionSelect)=\"suggestionSelect.emit($event)\">\n    </dr-chat-suggestions>\n\n    <div class=\"form\">\n        <ng-content select=\"dr-chat-form\"></ng-content>\n        <ng-content select=\"dr-ai-search-input\"></ng-content>\n    </div>\n</div>\n"]}
@@ -17,6 +17,7 @@ import { ClickOutsideModule } from '../directives/click-outside/click-outside.mo
17
17
  import { DrChatDroppedFilesComponent } from './dr-chat-dropped-files/dr-chat-dropped-files.component';
18
18
  import { ShorterNamingPipe } from './dr-chat-dropped-files/pipes/shorter-naming.pipe';
19
19
  import { DrChatFormDropdownComponent } from './dr-chat-form-dropdown/dr-chat-form-dropdown.component';
20
+ import { FileClassNamePipe } from './dr-chat-dropped-files/pipes/file-class-name.pipe';
20
21
  import * as i0 from "@angular/core";
21
22
  const DR_CHAT_COMPONENTS = [
22
23
  DrChatComponent,
@@ -30,7 +31,7 @@ const DR_CHAT_COMPONENTS = [
30
31
  DrChatAlertComponent,
31
32
  DrChatDroppedFilesComponent,
32
33
  ];
33
- const DR_CHAT_PIPES = [ShorterNamingPipe];
34
+ const DR_CHAT_PIPES = [ShorterNamingPipe, FileClassNamePipe];
34
35
  const DR_CHAT_DIRECTIVES = [DrChatCustomMessageDirective];
35
36
  export class DrChatModule {
36
37
  /** @nocollapse */ static { this.ɵfac = function DrChatModule_Factory(t) { return new (t || DrChatModule)(); }; }
@@ -68,7 +69,7 @@ export class DrChatModule {
68
69
  DrChatSuggestionsComponent,
69
70
  DrDotFlashingComponent,
70
71
  DrChatAlertComponent,
71
- DrChatDroppedFilesComponent, DrChatCustomMessageDirective, ShorterNamingPipe], imports: [FormsModule,
72
+ DrChatDroppedFilesComponent, DrChatCustomMessageDirective, ShorterNamingPipe, FileClassNamePipe], imports: [FormsModule,
72
73
  ReactiveFormsModule,
73
74
  CommonModule,
74
75
  DrAvatarModule,
@@ -84,4 +85,4 @@ export class DrChatModule {
84
85
  DrDotFlashingComponent,
85
86
  DrChatAlertComponent,
86
87
  DrChatDroppedFilesComponent, DrChatCustomMessageDirective] }); })();
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2NoYXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sd0VBQXdFLENBQUM7QUFDdEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDOUYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDckYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7O0FBRXRHLE1BQU0sa0JBQWtCLEdBQUc7SUFDdkIsZUFBZTtJQUNmLHNCQUFzQjtJQUN0QixtQkFBbUI7SUFDbkIsMkJBQTJCO0lBQzNCLDBCQUEwQjtJQUMxQiwwQkFBMEI7SUFDMUIsMEJBQTBCO0lBQzFCLHNCQUFzQjtJQUN0QixvQkFBb0I7SUFDcEIsMkJBQTJCO0NBQzlCLENBQUM7QUFFRixNQUFNLGFBQWEsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFFMUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFlMUQsTUFBTSxPQUFPLFlBQVk7Z0dBQVosWUFBWTtrR0FBWixZQUFZO3NHQVhqQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLFlBQVk7WUFDWixjQUFjO1lBQ2QsY0FBYztZQUNkLGVBQWU7WUFDZixrQkFBa0I7O3VGQUtiLFlBQVk7Y0FieEIsUUFBUTtlQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxXQUFXO29CQUNYLG1CQUFtQjtvQkFDbkIsWUFBWTtvQkFDWixjQUFjO29CQUNkLGNBQWM7b0JBQ2QsZUFBZTtvQkFDZixrQkFBa0I7aUJBQ3JCO2dCQUNELFlBQVksRUFBRSxDQUFDLEdBQUcsa0JBQWtCLEVBQUUsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGFBQWEsQ0FBQztnQkFDOUUsT0FBTyxFQUFFLENBQUMsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGtCQUFrQixDQUFDO2FBQzFEOzt3RkFDWSxZQUFZLG1CQTdCckIsZUFBZTtRQUNmLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsMkJBQTJCO1FBQzNCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLHNCQUFzQjtRQUN0QixvQkFBb0I7UUFDcEIsMkJBQTJCLEVBS0gsNEJBQTRCLEVBRmpDLGlCQUFpQixhQU1oQyxXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWixjQUFjO1FBQ2QsY0FBYztRQUNkLGVBQWU7UUFDZixrQkFBa0IsYUF4QnRCLGVBQWU7UUFDZixzQkFBc0I7UUFDdEIsbUJBQW1CO1FBQ25CLDJCQUEyQjtRQUMzQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLDBCQUEwQjtRQUMxQixzQkFBc0I7UUFDdEIsb0JBQW9CO1FBQ3BCLDJCQUEyQixFQUtILDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4uL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcbmltcG9ydCB7IERyQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vZHItYXZhdGFyL2RyLWF2YXRhci5tb2R1bGUnO1xuaW1wb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IERyQ2hhdENvbXBvbmVudCB9IGZyb20gJy4vY2hhdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2NoYXQtbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Rm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtL2NoYXQtZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZVRleHRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtdGV4dC9jaGF0LW1lc3NhZ2UtdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUZpbGVDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtZmlsZS9jaGF0LW1lc3NhZ2UtZmlsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Q3VzdG9tTWVzc2FnZURpcmVjdGl2ZSB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2RyLWNoYXQtbWVzc2FnZS1jdXN0b20vY2hhdC1jdXN0b20tbWVzc2FnZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJDaGF0U3VnZ2VzdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtc3VnZ2VzdGlvbnMvY2hhdC1zdWdnZXN0aW9ucy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJEb3RGbGFzaGluZ0NvbXBvbmVudCB9IGZyb20gJy4vZHItZG90LWZsYXNoaW5nL2RyLWRvdC1mbGFzaGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0QWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtYWxlcnQvZHItY2hhdC1hbGVydC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2xpY2tPdXRzaWRlTW9kdWxlIH0gZnJvbSAnLi4vZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlL2NsaWNrLW91dHNpZGUubW9kdWxlJztcbmltcG9ydCB7IERyQ2hhdERyb3BwZWRGaWxlc0NvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1kcm9wcGVkLWZpbGVzL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2hvcnRlck5hbWluZ1BpcGUgfSBmcm9tICcuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy9waXBlcy9zaG9ydGVyLW5hbWluZy5waXBlJztcbmltcG9ydCB7IERyQ2hhdEZvcm1Ecm9wZG93bkNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtLWRyb3Bkb3duL2RyLWNoYXQtZm9ybS1kcm9wZG93bi5jb21wb25lbnQnO1xuXG5jb25zdCBEUl9DSEFUX0NPTVBPTkVOVFMgPSBbXG4gICAgRHJDaGF0Q29tcG9uZW50LFxuICAgIERyQ2hhdE1lc3NhZ2VDb21wb25lbnQsXG4gICAgRHJDaGF0Rm9ybUNvbXBvbmVudCxcbiAgICBEckNoYXRGb3JtRHJvcGRvd25Db21wb25lbnQsXG4gICAgRHJDaGF0TWVzc2FnZVRleHRDb21wb25lbnQsXG4gICAgRHJDaGF0TWVzc2FnZUZpbGVDb21wb25lbnQsXG4gICAgRHJDaGF0U3VnZ2VzdGlvbnNDb21wb25lbnQsXG4gICAgRHJEb3RGbGFzaGluZ0NvbXBvbmVudCxcbiAgICBEckNoYXRBbGVydENvbXBvbmVudCxcbiAgICBEckNoYXREcm9wcGVkRmlsZXNDb21wb25lbnQsXG5dO1xuXG5jb25zdCBEUl9DSEFUX1BJUEVTID0gW1Nob3J0ZXJOYW1pbmdQaXBlXTtcblxuY29uc3QgRFJfQ0hBVF9ESVJFQ1RJVkVTID0gW0RyQ2hhdEN1c3RvbU1lc3NhZ2VEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRHJBdmF0YXJNb2R1bGUsXG4gICAgICAgIERySW5wdXRzTW9kdWxlLFxuICAgICAgICBEclRvb2x0aXBNb2R1bGUsXG4gICAgICAgIENsaWNrT3V0c2lkZU1vZHVsZSxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogWy4uLkRSX0NIQVRfQ09NUE9ORU5UUywgLi4uRFJfQ0hBVF9ESVJFQ1RJVkVTLCAuLi5EUl9DSEFUX1BJUEVTXSxcbiAgICBleHBvcnRzOiBbLi4uRFJfQ0hBVF9DT01QT05FTlRTLCAuLi5EUl9DSEFUX0RJUkVDVElWRVNdLFxufSlcbmV4cG9ydCBjbGFzcyBEckNoYXRNb2R1bGUge31cbiJdfQ==
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2NoYXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sd0VBQXdFLENBQUM7QUFDdEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDOUYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDckYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7O0FBRXZGLE1BQU0sa0JBQWtCLEdBQUc7SUFDdkIsZUFBZTtJQUNmLHNCQUFzQjtJQUN0QixtQkFBbUI7SUFDbkIsMkJBQTJCO0lBQzNCLDBCQUEwQjtJQUMxQiwwQkFBMEI7SUFDMUIsMEJBQTBCO0lBQzFCLHNCQUFzQjtJQUN0QixvQkFBb0I7SUFDcEIsMkJBQTJCO0NBQzlCLENBQUM7QUFFRixNQUFNLGFBQWEsR0FBRyxDQUFDLGlCQUFpQixFQUFFLGlCQUFpQixDQUFDLENBQUM7QUFFN0QsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFlMUQsTUFBTSxPQUFPLFlBQVk7Z0dBQVosWUFBWTtrR0FBWixZQUFZO3NHQVhqQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLFlBQVk7WUFDWixjQUFjO1lBQ2QsY0FBYztZQUNkLGVBQWU7WUFDZixrQkFBa0I7O3VGQUtiLFlBQVk7Y0FieEIsUUFBUTtlQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxXQUFXO29CQUNYLG1CQUFtQjtvQkFDbkIsWUFBWTtvQkFDWixjQUFjO29CQUNkLGNBQWM7b0JBQ2QsZUFBZTtvQkFDZixrQkFBa0I7aUJBQ3JCO2dCQUNELFlBQVksRUFBRSxDQUFDLEdBQUcsa0JBQWtCLEVBQUUsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGFBQWEsQ0FBQztnQkFDOUUsT0FBTyxFQUFFLENBQUMsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGtCQUFrQixDQUFDO2FBQzFEOzt3RkFDWSxZQUFZLG1CQTdCckIsZUFBZTtRQUNmLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsMkJBQTJCO1FBQzNCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLHNCQUFzQjtRQUN0QixvQkFBb0I7UUFDcEIsMkJBQTJCLEVBS0gsNEJBQTRCLEVBRmpDLGlCQUFpQixFQUFFLGlCQUFpQixhQU1uRCxXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWixjQUFjO1FBQ2QsY0FBYztRQUNkLGVBQWU7UUFDZixrQkFBa0IsYUF4QnRCLGVBQWU7UUFDZixzQkFBc0I7UUFDdEIsbUJBQW1CO1FBQ25CLDJCQUEyQjtRQUMzQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLDBCQUEwQjtRQUMxQixzQkFBc0I7UUFDdEIsb0JBQW9CO1FBQ3BCLDJCQUEyQixFQUtILDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4uL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcbmltcG9ydCB7IERyQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vZHItYXZhdGFyL2RyLWF2YXRhci5tb2R1bGUnO1xuaW1wb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IERyQ2hhdENvbXBvbmVudCB9IGZyb20gJy4vY2hhdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2NoYXQtbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Rm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtL2NoYXQtZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZVRleHRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtdGV4dC9jaGF0LW1lc3NhZ2UtdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUZpbGVDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtZmlsZS9jaGF0LW1lc3NhZ2UtZmlsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Q3VzdG9tTWVzc2FnZURpcmVjdGl2ZSB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2RyLWNoYXQtbWVzc2FnZS1jdXN0b20vY2hhdC1jdXN0b20tbWVzc2FnZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJDaGF0U3VnZ2VzdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtc3VnZ2VzdGlvbnMvY2hhdC1zdWdnZXN0aW9ucy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJEb3RGbGFzaGluZ0NvbXBvbmVudCB9IGZyb20gJy4vZHItZG90LWZsYXNoaW5nL2RyLWRvdC1mbGFzaGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0QWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtYWxlcnQvZHItY2hhdC1hbGVydC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2xpY2tPdXRzaWRlTW9kdWxlIH0gZnJvbSAnLi4vZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlL2NsaWNrLW91dHNpZGUubW9kdWxlJztcbmltcG9ydCB7IERyQ2hhdERyb3BwZWRGaWxlc0NvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1kcm9wcGVkLWZpbGVzL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2hvcnRlck5hbWluZ1BpcGUgfSBmcm9tICcuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy9waXBlcy9zaG9ydGVyLW5hbWluZy5waXBlJztcbmltcG9ydCB7IERyQ2hhdEZvcm1Ecm9wZG93bkNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtLWRyb3Bkb3duL2RyLWNoYXQtZm9ybS1kcm9wZG93bi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmlsZUNsYXNzTmFtZVBpcGUgfSBmcm9tICcuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy9waXBlcy9maWxlLWNsYXNzLW5hbWUucGlwZSc7XG5cbmNvbnN0IERSX0NIQVRfQ09NUE9ORU5UUyA9IFtcbiAgICBEckNoYXRDb21wb25lbnQsXG4gICAgRHJDaGF0TWVzc2FnZUNvbXBvbmVudCxcbiAgICBEckNoYXRGb3JtQ29tcG9uZW50LFxuICAgIERyQ2hhdEZvcm1Ecm9wZG93bkNvbXBvbmVudCxcbiAgICBEckNoYXRNZXNzYWdlVGV4dENvbXBvbmVudCxcbiAgICBEckNoYXRNZXNzYWdlRmlsZUNvbXBvbmVudCxcbiAgICBEckNoYXRTdWdnZXN0aW9uc0NvbXBvbmVudCxcbiAgICBEckRvdEZsYXNoaW5nQ29tcG9uZW50LFxuICAgIERyQ2hhdEFsZXJ0Q29tcG9uZW50LFxuICAgIERyQ2hhdERyb3BwZWRGaWxlc0NvbXBvbmVudCxcbl07XG5cbmNvbnN0IERSX0NIQVRfUElQRVMgPSBbU2hvcnRlck5hbWluZ1BpcGUsIEZpbGVDbGFzc05hbWVQaXBlXTtcblxuY29uc3QgRFJfQ0hBVF9ESVJFQ1RJVkVTID0gW0RyQ2hhdEN1c3RvbU1lc3NhZ2VEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRHJBdmF0YXJNb2R1bGUsXG4gICAgICAgIERySW5wdXRzTW9kdWxlLFxuICAgICAgICBEclRvb2x0aXBNb2R1bGUsXG4gICAgICAgIENsaWNrT3V0c2lkZU1vZHVsZSxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogWy4uLkRSX0NIQVRfQ09NUE9ORU5UUywgLi4uRFJfQ0hBVF9ESVJFQ1RJVkVTLCAuLi5EUl9DSEFUX1BJUEVTXSxcbiAgICBleHBvcnRzOiBbLi4uRFJfQ0hBVF9DT01QT05FTlRTLCAuLi5EUl9DSEFUX0RJUkVDVElWRVNdLFxufSlcbmV4cG9ydCBjbGFzcyBEckNoYXRNb2R1bGUge31cbiJdfQ==
@@ -2,26 +2,30 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  import * as i2 from "./pipes/shorter-naming.pipe";
5
- function DrChatDroppedFilesComponent_div_1_i_5_Template(rf, ctx) { if (rf & 1) {
5
+ import * as i3 from "./pipes/file-class-name.pipe";
6
+ function DrChatDroppedFilesComponent_div_1_i_6_Template(rf, ctx) { if (rf & 1) {
6
7
  const _r5 = i0.ɵɵgetCurrentView();
7
- i0.ɵɵelementStart(0, "i", 6);
8
- i0.ɵɵlistener("click", function DrChatDroppedFilesComponent_div_1_i_5_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r5); const file_r1 = i0.ɵɵnextContext().$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeFile(file_r1, $event)); });
8
+ i0.ɵɵelementStart(0, "i", 5);
9
+ i0.ɵɵlistener("click", function DrChatDroppedFilesComponent_div_1_i_6_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r5); const file_r1 = i0.ɵɵnextContext().$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeFile(file_r1, $event)); });
9
10
  i0.ɵɵelementEnd();
10
11
  } }
11
12
  function DrChatDroppedFilesComponent_div_1_Template(rf, ctx) { if (rf & 1) {
12
13
  i0.ɵɵelementStart(0, "div", 2);
13
- i0.ɵɵelement(1, "i", 3);
14
- i0.ɵɵelementStart(2, "div", 4);
15
- i0.ɵɵtext(3);
16
- i0.ɵɵpipe(4, "shorterNaming");
14
+ i0.ɵɵelement(1, "i");
15
+ i0.ɵɵpipe(2, "fileClassName");
16
+ i0.ɵɵelementStart(3, "div", 3);
17
+ i0.ɵɵtext(4);
18
+ i0.ɵɵpipe(5, "shorterNaming");
17
19
  i0.ɵɵelementEnd();
18
- i0.ɵɵtemplate(5, DrChatDroppedFilesComponent_div_1_i_5_Template, 1, 0, "i", 5);
20
+ i0.ɵɵtemplate(6, DrChatDroppedFilesComponent_div_1_i_6_Template, 1, 0, "i", 4);
19
21
  i0.ɵɵelementEnd();
20
22
  } if (rf & 2) {
21
23
  const file_r1 = ctx.$implicit;
22
24
  const ctx_r0 = i0.ɵɵnextContext();
25
+ i0.ɵɵadvance(1);
26
+ i0.ɵɵclassMapInterpolate1("dr-icon-", i0.ɵɵpipeBind1(2, 5, file_r1.name), "");
23
27
  i0.ɵɵadvance(3);
24
- i0.ɵɵtextInterpolate(i0.ɵɵpipeBind2(4, 2, file_r1.name, ctx_r0.maxLengthText));
28
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind2(5, 7, file_r1.name, ctx_r0.maxLengthText));
25
29
  i0.ɵɵadvance(2);
26
30
  i0.ɵɵproperty("ngIf", ctx_r0.isRemovable);
27
31
  } }
@@ -37,18 +41,18 @@ export class DrChatDroppedFilesComponent {
37
41
  this.removeFileEvent.emit(file);
38
42
  }
39
43
  /** @nocollapse */ static { this.ɵfac = function DrChatDroppedFilesComponent_Factory(t) { return new (t || DrChatDroppedFilesComponent)(); }; }
40
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrChatDroppedFilesComponent, selectors: [["dr-chat-dropped-files"]], inputs: { files: "files", isRemovable: "isRemovable", maxLengthText: "maxLengthText" }, outputs: { removeFileEvent: "removeFileEvent" }, decls: 2, vars: 1, consts: [[1, "dropped-files"], ["class", "dropped-files__item", 4, "ngFor", "ngForOf"], [1, "dropped-files__item"], [1, "dr-icon-file"], [1, "dropped-files__item-name"], ["class", "dr-icon-noty-error dropped-files__item-remove", 3, "click", 4, "ngIf"], [1, "dr-icon-noty-error", "dropped-files__item-remove", 3, "click"]], template: function DrChatDroppedFilesComponent_Template(rf, ctx) { if (rf & 1) {
44
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrChatDroppedFilesComponent, selectors: [["dr-chat-dropped-files"]], inputs: { files: "files", isRemovable: "isRemovable", maxLengthText: "maxLengthText" }, outputs: { removeFileEvent: "removeFileEvent" }, decls: 2, vars: 1, consts: [[1, "dropped-files"], ["class", "dropped-files__item", 4, "ngFor", "ngForOf"], [1, "dropped-files__item"], [1, "dropped-files__item-name"], ["class", "dr-icon-noty-error dropped-files__item-remove", 3, "click", 4, "ngIf"], [1, "dr-icon-noty-error", "dropped-files__item-remove", 3, "click"]], template: function DrChatDroppedFilesComponent_Template(rf, ctx) { if (rf & 1) {
41
45
  i0.ɵɵelementStart(0, "div", 0);
42
- i0.ɵɵtemplate(1, DrChatDroppedFilesComponent_div_1_Template, 6, 5, "div", 1);
46
+ i0.ɵɵtemplate(1, DrChatDroppedFilesComponent_div_1_Template, 7, 10, "div", 1);
43
47
  i0.ɵɵelementEnd();
44
48
  } if (rf & 2) {
45
49
  i0.ɵɵadvance(1);
46
50
  i0.ɵɵproperty("ngForOf", ctx.files);
47
- } }, dependencies: [i1.NgForOf, i1.NgIf, i2.ShorterNamingPipe], styles: [".dropped-files[_ngcontent-%COMP%]{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}.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;background-color:#f6f7f8;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}.dropped-files__item-name[_ngcontent-%COMP%]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;color:#6d6e6f}.dropped-files__item-remove[_ngcontent-%COMP%]{cursor:pointer;color:#6d6e6f}"], changeDetection: 0 }); }
51
+ } }, dependencies: [i1.NgForOf, i1.NgIf, i2.ShorterNamingPipe, i3.FileClassNamePipe], styles: [".dropped-files[_ngcontent-%COMP%]{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}.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;background-color:#f6f7f8;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}.dropped-files__item-name[_ngcontent-%COMP%]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;color:#6d6e6f}.dropped-files__item-remove[_ngcontent-%COMP%]{cursor:pointer;color:#6d6e6f}"], changeDetection: 0 }); }
48
52
  }
49
53
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatDroppedFilesComponent, [{
50
54
  type: Component,
51
- args: [{ selector: 'dr-chat-dropped-files', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dropped-files\">\n <div class=\"dropped-files__item\" *ngFor=\"let file of files\">\n <i class=\"dr-icon-file\"></i>\n <div class=\"dropped-files__item-name\">{{ file.name | shorterNaming: maxLengthText }}</div>\n <i *ngIf=\"isRemovable\" class=\"dr-icon-noty-error dropped-files__item-remove\" (click)=\"removeFile(file, $event)\"></i>\n </div>\n</div>\n", styles: [".dropped-files{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}.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;background-color:#f6f7f8;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}.dropped-files__item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;color:#6d6e6f}.dropped-files__item-remove{cursor:pointer;color:#6d6e6f}\n"] }]
55
+ args: [{ selector: 'dr-chat-dropped-files', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dropped-files\">\n <div class=\"dropped-files__item\" *ngFor=\"let file of files\">\n <i class=\"dr-icon-{{ file.name | fileClassName }}\"></i>\n <div class=\"dropped-files__item-name\">{{ file.name | shorterNaming: maxLengthText }}</div>\n <i *ngIf=\"isRemovable\" class=\"dr-icon-noty-error dropped-files__item-remove\" (click)=\"removeFile(file, $event)\"></i>\n </div>\n</div>\n", styles: [".dropped-files{display:flex;flex-direction:row;margin-bottom:.5rem;flex-wrap:wrap;gap:8px;padding-left:16px}.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;background-color:#f6f7f8;border:1px solid rgb(223,224,227);box-sizing:border-box;border-radius:8px}.dropped-files__item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Poppins,sans-serif;font-size:12px;line-height:20px;font-weight:500;font-weight:400;color:#6d6e6f}.dropped-files__item-remove{cursor:pointer;color:#6d6e6f}\n"] }]
52
56
  }], null, { files: [{
53
57
  type: Input
54
58
  }], isRemovable: [{
@@ -58,4 +62,4 @@ export class DrChatDroppedFilesComponent {
58
62
  }], removeFileEvent: [{
59
63
  type: Output
60
64
  }] }); })();
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItY2hhdC1kcm9wcGVkLWZpbGVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWNoYXQvZHItY2hhdC1kcm9wcGVkLWZpbGVzL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2RyLWNoYXQtZHJvcHBlZC1maWxlcy9kci1jaGF0LWRyb3BwZWQtZmlsZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0lDSXhGLDRCQUFnSDtJQUFuQywyTkFBUyxlQUFBLGtDQUF3QixDQUFBLElBQUM7SUFBQyxpQkFBSTs7O0lBSHhILDhCQUE0RDtJQUN4RCx1QkFBNEI7SUFDNUIsOEJBQXNDO0lBQUEsWUFBOEM7O0lBQUEsaUJBQU07SUFDMUYsOEVBQW9IO0lBQ3hILGlCQUFNOzs7O0lBRm9DLGVBQThDO0lBQTlDLDhFQUE4QztJQUNoRixlQUFpQjtJQUFqQix5Q0FBaUI7O0FESzdCLE1BQU0sT0FBTywyQkFBMkI7SUFOeEM7UUFRYSxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixrQkFBYSxHQUFHLEVBQUUsQ0FBQztRQUNsQixvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7S0FPekQ7SUFMRyxVQUFVLENBQUMsSUFBVyxFQUFFLEtBQVk7UUFDaEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQyxDQUFDOytHQVZRLDJCQUEyQjttR0FBM0IsMkJBQTJCO1lDVHhDLDhCQUEyQjtZQUN2Qiw0RUFJTTtZQUNWLGlCQUFNOztZQUxnRCxlQUFRO1lBQVIsbUNBQVE7Ozt1RkRRakQsMkJBQTJCO2NBTnZDLFNBQVM7MkJBQ0ksdUJBQXVCLG1CQUdoQix1QkFBdUIsQ0FBQyxNQUFNO2dCQUd0QyxLQUFLO2tCQUFiLEtBQUs7WUFDRyxXQUFXO2tCQUFuQixLQUFLO1lBQ0csYUFBYTtrQkFBckIsS0FBSztZQUNJLGVBQWU7a0JBQXhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElGSWxlIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2NoYXQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLWNoYXQtZHJvcHBlZC1maWxlcycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZHItY2hhdC1kcm9wcGVkLWZpbGVzLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIERyQ2hhdERyb3BwZWRGaWxlc0NvbXBvbmVudCB7XG4gICAgQElucHV0KCkgZmlsZXM6IEFycmF5PElGSWxlPjtcbiAgICBASW5wdXQoKSBpc1JlbW92YWJsZSA9IGZhbHNlO1xuICAgIEBJbnB1dCgpIG1heExlbmd0aFRleHQgPSAxODtcbiAgICBAT3V0cHV0KCkgcmVtb3ZlRmlsZUV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxJRklsZT4oKTtcblxuICAgIHJlbW92ZUZpbGUoZmlsZTogSUZJbGUsIGV2ZW50OiBFdmVudCkge1xuICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgdGhpcy5yZW1vdmVGaWxlRXZlbnQuZW1pdChmaWxlKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZHJvcHBlZC1maWxlc1wiPlxuICAgIDxkaXYgY2xhc3M9XCJkcm9wcGVkLWZpbGVzX19pdGVtXCIgKm5nRm9yPVwibGV0IGZpbGUgb2YgZmlsZXNcIj5cbiAgICAgICAgPGkgY2xhc3M9XCJkci1pY29uLWZpbGVcIj48L2k+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJkcm9wcGVkLWZpbGVzX19pdGVtLW5hbWVcIj57eyBmaWxlLm5hbWUgfCBzaG9ydGVyTmFtaW5nOiBtYXhMZW5ndGhUZXh0IH19PC9kaXY+XG4gICAgICAgIDxpICpuZ0lmPVwiaXNSZW1vdmFibGVcIiBjbGFzcz1cImRyLWljb24tbm90eS1lcnJvciBkcm9wcGVkLWZpbGVzX19pdGVtLXJlbW92ZVwiIChjbGljayk9XCJyZW1vdmVGaWxlKGZpbGUsICRldmVudClcIj48L2k+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItY2hhdC1kcm9wcGVkLWZpbGVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWNoYXQvZHItY2hhdC1kcm9wcGVkLWZpbGVzL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2RyLWNoYXQtZHJvcHBlZC1maWxlcy9kci1jaGF0LWRyb3BwZWQtZmlsZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7OztJQ0l4Riw0QkFBZ0g7SUFBbkMsMk5BQVMsZUFBQSxrQ0FBd0IsQ0FBQSxJQUFDO0lBQUMsaUJBQUk7OztJQUh4SCw4QkFBNEQ7SUFDeEQsb0JBQXVEOztJQUN2RCw4QkFBc0M7SUFBQSxZQUE4Qzs7SUFBQSxpQkFBTTtJQUMxRiw4RUFBb0g7SUFDeEgsaUJBQU07Ozs7SUFIQyxlQUErQztJQUEvQyw2RUFBK0M7SUFDWixlQUE4QztJQUE5Qyw4RUFBOEM7SUFDaEYsZUFBaUI7SUFBakIseUNBQWlCOztBREs3QixNQUFNLE9BQU8sMkJBQTJCO0lBTnhDO1FBUWEsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsa0JBQWEsR0FBRyxFQUFFLENBQUM7UUFDbEIsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO0tBT3pEO0lBTEcsVUFBVSxDQUFDLElBQVcsRUFBRSxLQUFZO1FBQ2hDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEMsQ0FBQzsrR0FWUSwyQkFBMkI7bUdBQTNCLDJCQUEyQjtZQ1R4Qyw4QkFBMkI7WUFDdkIsNkVBSU07WUFDVixpQkFBTTs7WUFMZ0QsZUFBUTtZQUFSLG1DQUFROzs7dUZEUWpELDJCQUEyQjtjQU52QyxTQUFTOzJCQUNJLHVCQUF1QixtQkFHaEIsdUJBQXVCLENBQUMsTUFBTTtnQkFHdEMsS0FBSztrQkFBYixLQUFLO1lBQ0csV0FBVztrQkFBbkIsS0FBSztZQUNHLGFBQWE7a0JBQXJCLEtBQUs7WUFDSSxlQUFlO2tCQUF4QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJRklsZSB9IGZyb20gJy4uLy4uL21vZGVscy9jaGF0JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkci1jaGF0LWRyb3BwZWQtZmlsZXMnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9kci1jaGF0LWRyb3BwZWQtZmlsZXMuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEckNoYXREcm9wcGVkRmlsZXNDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIGZpbGVzOiBBcnJheTxJRklsZT47XG4gICAgQElucHV0KCkgaXNSZW1vdmFibGUgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBtYXhMZW5ndGhUZXh0ID0gMTg7XG4gICAgQE91dHB1dCgpIHJlbW92ZUZpbGVFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8SUZJbGU+KCk7XG5cbiAgICByZW1vdmVGaWxlKGZpbGU6IElGSWxlLCBldmVudDogRXZlbnQpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMucmVtb3ZlRmlsZUV2ZW50LmVtaXQoZmlsZSk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImRyb3BwZWQtZmlsZXNcIj5cbiAgICA8ZGl2IGNsYXNzPVwiZHJvcHBlZC1maWxlc19faXRlbVwiICpuZ0Zvcj1cImxldCBmaWxlIG9mIGZpbGVzXCI+XG4gICAgICAgIDxpIGNsYXNzPVwiZHItaWNvbi17eyBmaWxlLm5hbWUgfCBmaWxlQ2xhc3NOYW1lIH19XCI+PC9pPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZHJvcHBlZC1maWxlc19faXRlbS1uYW1lXCI+e3sgZmlsZS5uYW1lIHwgc2hvcnRlck5hbWluZzogbWF4TGVuZ3RoVGV4dCB9fTwvZGl2PlxuICAgICAgICA8aSAqbmdJZj1cImlzUmVtb3ZhYmxlXCIgY2xhc3M9XCJkci1pY29uLW5vdHktZXJyb3IgZHJvcHBlZC1maWxlc19faXRlbS1yZW1vdmVcIiAoY2xpY2spPVwicmVtb3ZlRmlsZShmaWxlLCAkZXZlbnQpXCI+PC9pPlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,26 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class FileClassNamePipe {
4
+ transform(filename) {
5
+ if (!filename)
6
+ return 'file';
7
+ const extension = filename.split('.').pop()?.toLowerCase();
8
+ switch (extension) {
9
+ case 'csv':
10
+ case 'xls':
11
+ case 'xlsx':
12
+ return 'filter-logo_excel-svg';
13
+ default:
14
+ return 'file';
15
+ }
16
+ }
17
+ /** @nocollapse */ static { this.ɵfac = function FileClassNamePipe_Factory(t) { return new (t || FileClassNamePipe)(); }; }
18
+ /** @nocollapse */ static { this.ɵpipe = /** @pureOrBreakMyCode */ i0.ɵɵdefinePipe({ name: "fileClassName", type: FileClassNamePipe, pure: true }); }
19
+ }
20
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FileClassNamePipe, [{
21
+ type: Pipe,
22
+ args: [{
23
+ name: 'fileClassName',
24
+ }]
25
+ }], null, null); })();
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jbGFzcy1uYW1lLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2RyLWNoYXQtZHJvcHBlZC1maWxlcy9waXBlcy9maWxlLWNsYXNzLW5hbWUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLGlCQUFpQjtJQUMxQixTQUFTLENBQUMsUUFBZ0I7UUFDdEIsSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPLE1BQU0sQ0FBQztRQUM3QixNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLFdBQVcsRUFBRSxDQUFDO1FBQzNELFFBQVEsU0FBUyxFQUFFO1lBQ2YsS0FBSyxLQUFLLENBQUM7WUFDWCxLQUFLLEtBQUssQ0FBQztZQUNYLEtBQUssTUFBTTtnQkFDUCxPQUFPLHVCQUF1QixDQUFDO1lBQ25DO2dCQUNJLE9BQU8sTUFBTSxDQUFDO1NBQ3JCO0lBQ0wsQ0FBQztxR0FaUSxpQkFBaUI7c0hBQWpCLGlCQUFpQjs7dUZBQWpCLGlCQUFpQjtjQUg3QixJQUFJO2VBQUM7Z0JBQ0YsSUFBSSxFQUFFLGVBQWU7YUFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBQaXBlKHtcbiAgICBuYW1lOiAnZmlsZUNsYXNzTmFtZScsXG59KVxuZXhwb3J0IGNsYXNzIEZpbGVDbGFzc05hbWVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgdHJhbnNmb3JtKGZpbGVuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgICAgICBpZiAoIWZpbGVuYW1lKSByZXR1cm4gJ2ZpbGUnO1xuICAgICAgICBjb25zdCBleHRlbnNpb24gPSBmaWxlbmFtZS5zcGxpdCgnLicpLnBvcCgpPy50b0xvd2VyQ2FzZSgpO1xuICAgICAgICBzd2l0Y2ggKGV4dGVuc2lvbikge1xuICAgICAgICAgICAgY2FzZSAnY3N2JzpcbiAgICAgICAgICAgIGNhc2UgJ3hscyc6XG4gICAgICAgICAgICBjYXNlICd4bHN4JzpcbiAgICAgICAgICAgICAgICByZXR1cm4gJ2ZpbHRlci1sb2dvX2V4Y2VsLXN2Zyc7XG4gICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgIHJldHVybiAnZmlsZSc7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
@@ -9,29 +9,29 @@ import * as i4 from "../dr-dot-flashing/dr-dot-flashing.component";
9
9
  import * as i5 from "../dr-chat-dropped-files/dr-chat-dropped-files.component";
10
10
  const _c0 = ["textAreaElement"];
11
11
  const _c1 = ["fileInput"];
12
- function DrChatFormDropdownComponent_dr_chat_dropped_files_2_Template(rf, ctx) { if (rf & 1) {
12
+ function DrChatFormDropdownComponent_dr_chat_dropped_files_3_Template(rf, ctx) { if (rf & 1) {
13
13
  const _r7 = i0.ɵɵgetCurrentView();
14
14
  i0.ɵɵelementStart(0, "dr-chat-dropped-files", 12);
15
- i0.ɵɵlistener("removeFileEvent", function DrChatFormDropdownComponent_dr_chat_dropped_files_2_Template_dr_chat_dropped_files_removeFileEvent_0_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.removeFile($event)); });
15
+ i0.ɵɵlistener("removeFileEvent", function DrChatFormDropdownComponent_dr_chat_dropped_files_3_Template_dr_chat_dropped_files_removeFileEvent_0_listener($event) { i0.ɵɵrestoreView(_r7); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.removeFile($event)); });
16
16
  i0.ɵɵpipe(1, "async");
17
17
  i0.ɵɵelementEnd();
18
18
  } if (rf & 2) {
19
19
  const ctx_r0 = i0.ɵɵnextContext();
20
20
  i0.ɵɵproperty("files", i0.ɵɵpipeBind1(1, 3, ctx_r0.droppedFiles$))("isRemovable", true)("maxLengthText", 15);
21
21
  } }
22
- function DrChatFormDropdownComponent_i_12_Template(rf, ctx) { if (rf & 1) {
22
+ function DrChatFormDropdownComponent_i_13_Template(rf, ctx) { if (rf & 1) {
23
23
  const _r9 = i0.ɵɵgetCurrentView();
24
24
  i0.ɵɵelementStart(0, "i", 13);
25
- i0.ɵɵlistener("click", function DrChatFormDropdownComponent_i_12_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r9); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.sendMessage($event)); });
25
+ i0.ɵɵlistener("click", function DrChatFormDropdownComponent_i_13_Template_i_click_0_listener($event) { i0.ɵɵrestoreView(_r9); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.sendMessage($event)); });
26
26
  i0.ɵɵelementEnd();
27
27
  } }
28
- function DrChatFormDropdownComponent_i_13_Template(rf, ctx) { if (rf & 1) {
28
+ function DrChatFormDropdownComponent_i_14_Template(rf, ctx) { if (rf & 1) {
29
29
  const _r11 = i0.ɵɵgetCurrentView();
30
30
  i0.ɵɵelementStart(0, "i", 14);
31
- i0.ɵɵlistener("click", function DrChatFormDropdownComponent_i_13_Template_i_click_0_listener() { i0.ɵɵrestoreView(_r11); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.abortMessage()); });
31
+ i0.ɵɵlistener("click", function DrChatFormDropdownComponent_i_14_Template_i_click_0_listener() { i0.ɵɵrestoreView(_r11); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.abortMessage()); });
32
32
  i0.ɵɵelementEnd();
33
33
  } }
34
- function DrChatFormDropdownComponent_dr_dot_flashing_14_Template(rf, ctx) { if (rf & 1) {
34
+ function DrChatFormDropdownComponent_dr_dot_flashing_15_Template(rf, ctx) { if (rf & 1) {
35
35
  i0.ɵɵelement(0, "dr-dot-flashing", 15);
36
36
  } }
37
37
  const _c2 = function (a0) { return { "message-row_loading": a0 }; };
@@ -45,7 +45,7 @@ export class DrChatFormDropdownComponent {
45
45
  this.inputFocus = false;
46
46
  this.inputHover = false;
47
47
  this.droppedFiles$ = new BehaviorSubject([]);
48
- this.isLoading = false;
48
+ this.isUploadingFiles = false;
49
49
  /**
50
50
  * Predefined message text
51
51
  *
@@ -134,7 +134,7 @@ export class DrChatFormDropdownComponent {
134
134
  if (!$event || !$event.shiftKey) {
135
135
  $event?.preventDefault();
136
136
  $event?.stopPropagation();
137
- if (this.waitForReply) {
137
+ if (this.waitForReply || this.isUploadingFiles) {
138
138
  return;
139
139
  }
140
140
  else if (this.droppedFiles$.value.length || String(this.message).trim().length) {
@@ -204,32 +204,33 @@ export class DrChatFormDropdownComponent {
204
204
  i0.ɵɵlistener("drop", function DrChatFormDropdownComponent_drop_HostBindingHandler($event) { return ctx.onDrop($event); })("dragover", function DrChatFormDropdownComponent_dragover_HostBindingHandler($event) { return ctx.onDragOver($event); })("dragleave", function DrChatFormDropdownComponent_dragleave_HostBindingHandler($event) { return ctx.onDragLeave($event); });
205
205
  } if (rf & 2) {
206
206
  i0.ɵɵclassProp("file-over", ctx.fileOver);
207
- } }, inputs: { isLoading: "isLoading", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDotFlashing: "showDotFlashing" }, outputs: { send: "send", uploadFiles: "uploadFiles", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c4, decls: 15, vars: 18, 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-row__btns"], ["type", "file", "hidden", "", "multiple", "", 3, "change"], ["fileInput", ""], ["class", "dr-icon-send-arrow-up send-button", 3, "click", 4, "ngIf"], ["class", "dr-icon-stop abort-button", 3, "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 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"]], template: function DrChatFormDropdownComponent_Template(rf, ctx) { if (rf & 1) {
207
+ } }, inputs: { isUploadingFiles: "isUploadingFiles", message: "message", messagePlaceholder: "messagePlaceholder", dropFiles: "dropFiles", dropFilePlaceholder: "dropFilePlaceholder", waitForReply: "waitForReply", showDotFlashing: "showDotFlashing" }, outputs: { send: "send", uploadFiles: "uploadFiles", abort: "abort", inputChange: "inputChange" }, ngContentSelectors: _c4, decls: 16, vars: 20, 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-row__btns"], ["type", "file", "hidden", "", "multiple", "", 3, "change"], ["fileInput", ""], ["class", "dr-icon-send-arrow-up send-button", 3, "click", 4, "ngIf"], ["class", "dr-icon-stop abort-button", 3, "click", 4, "ngIf"], ["class", "wait-reply-dot-flashing", 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"]], template: function DrChatFormDropdownComponent_Template(rf, ctx) { if (rf & 1) {
208
208
  i0.ɵɵprojectionDef();
209
209
  i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
210
- i0.ɵɵtemplate(2, DrChatFormDropdownComponent_dr_chat_dropped_files_2_Template, 2, 5, "dr-chat-dropped-files", 2);
211
- i0.ɵɵpipe(3, "async");
212
- i0.ɵɵelementStart(4, "div", 3)(5, "textarea", 4, 5);
213
- i0.ɵɵlistener("focus", function DrChatFormDropdownComponent_Template_textarea_focus_5_listener() { return ctx.inputFocus = true; })("blur", function DrChatFormDropdownComponent_Template_textarea_blur_5_listener() { return ctx.inputFocus = false; })("mouseenter", function DrChatFormDropdownComponent_Template_textarea_mouseenter_5_listener() { return ctx.inputHover = true; })("mouseleave", function DrChatFormDropdownComponent_Template_textarea_mouseleave_5_listener() { return ctx.inputHover = false; })("ngModelChange", function DrChatFormDropdownComponent_Template_textarea_ngModelChange_5_listener($event) { return ctx.message = $event; })("ngModelChange", function DrChatFormDropdownComponent_Template_textarea_ngModelChange_5_listener($event) { return ctx.onModelChange($event); })("keydown.enter", function DrChatFormDropdownComponent_Template_textarea_keydown_enter_5_listener($event) { return ctx.sendMessage($event); });
214
- i0.ɵɵtext(7, " ");
210
+ i0.ɵɵpipe(2, "async");
211
+ i0.ɵɵtemplate(3, DrChatFormDropdownComponent_dr_chat_dropped_files_3_Template, 2, 5, "dr-chat-dropped-files", 2);
212
+ i0.ɵɵpipe(4, "async");
213
+ i0.ɵɵelementStart(5, "div", 3)(6, "textarea", 4, 5);
214
+ i0.ɵɵlistener("focus", function DrChatFormDropdownComponent_Template_textarea_focus_6_listener() { return ctx.inputFocus = true; })("blur", function DrChatFormDropdownComponent_Template_textarea_blur_6_listener() { return ctx.inputFocus = false; })("mouseenter", function DrChatFormDropdownComponent_Template_textarea_mouseenter_6_listener() { return ctx.inputHover = true; })("mouseleave", function DrChatFormDropdownComponent_Template_textarea_mouseleave_6_listener() { return ctx.inputHover = false; })("ngModelChange", function DrChatFormDropdownComponent_Template_textarea_ngModelChange_6_listener($event) { return ctx.message = $event; })("ngModelChange", function DrChatFormDropdownComponent_Template_textarea_ngModelChange_6_listener($event) { return ctx.onModelChange($event); })("keydown.enter", function DrChatFormDropdownComponent_Template_textarea_keydown_enter_6_listener($event) { return ctx.sendMessage($event); });
215
+ i0.ɵɵtext(8, " ");
215
216
  i0.ɵɵelementEnd()();
216
- i0.ɵɵelementStart(8, "div", 6);
217
- i0.ɵɵprojection(9);
218
- i0.ɵɵelementStart(10, "input", 7, 8);
219
- i0.ɵɵlistener("change", function DrChatFormDropdownComponent_Template_input_change_10_listener($event) { return ctx.onFileSelected($event); });
217
+ i0.ɵɵelementStart(9, "div", 6);
218
+ i0.ɵɵprojection(10);
219
+ i0.ɵɵelementStart(11, "input", 7, 8);
220
+ i0.ɵɵlistener("change", function DrChatFormDropdownComponent_Template_input_change_11_listener($event) { return ctx.onFileSelected($event); });
220
221
  i0.ɵɵelementEnd();
221
- i0.ɵɵtemplate(12, DrChatFormDropdownComponent_i_12_Template, 1, 0, "i", 9);
222
- i0.ɵɵtemplate(13, DrChatFormDropdownComponent_i_13_Template, 1, 0, "i", 10);
223
- i0.ɵɵtemplate(14, DrChatFormDropdownComponent_dr_dot_flashing_14_Template, 1, 0, "dr-dot-flashing", 11);
222
+ i0.ɵɵtemplate(13, DrChatFormDropdownComponent_i_13_Template, 1, 0, "i", 9);
223
+ i0.ɵɵtemplate(14, DrChatFormDropdownComponent_i_14_Template, 1, 0, "i", 10);
224
+ i0.ɵɵtemplate(15, DrChatFormDropdownComponent_dr_dot_flashing_15_Template, 1, 0, "dr-dot-flashing", 11);
224
225
  i0.ɵɵelementEnd()()();
225
226
  } if (rf & 2) {
226
- const _r1 = i0.ɵɵreference(6);
227
+ const _r1 = i0.ɵɵreference(7);
227
228
  let tmp_1_0;
228
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(13, _c2, ctx.isLoading));
229
- i0.ɵɵadvance(1);
230
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(15, _c3, ctx.inputFocus, !!(ctx.message == null ? null : (tmp_1_0 = ctx.message.trim()) == null ? null : tmp_1_0.length)));
229
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c2, ctx.isUploadingFiles));
231
230
  i0.ɵɵadvance(1);
232
- i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(3, 11, ctx.droppedFiles$).length);
231
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(17, _c3, ctx.inputFocus, !!(ctx.message == null ? null : (tmp_1_0 = ctx.message.trim()) == null ? null : tmp_1_0.length) || !!i0.ɵɵpipeBind1(2, 11, ctx.droppedFiles$).length));
232
+ i0.ɵɵadvance(2);
233
+ i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(4, 13, ctx.droppedFiles$).length);
233
234
  i0.ɵɵadvance(3);
234
235
  i0.ɵɵstyleMap(ctx.getTextAreaHeight(_r1));
235
236
  i0.ɵɵpropertyInterpolate("placeholder", ctx.fileOver ? ctx.dropFilePlaceholder : ctx.messagePlaceholder);
@@ -240,18 +241,18 @@ export class DrChatFormDropdownComponent {
240
241
  i0.ɵɵproperty("ngIf", ctx.waitForReply && !ctx.showDotFlashing);
241
242
  i0.ɵɵadvance(1);
242
243
  i0.ɵɵproperty("ngIf", ctx.waitForReply && ctx.showDotFlashing);
243
- } }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgIf, i4.DrDotFlashingComponent, i5.DrChatDroppedFilesComponent, i3.AsyncPipe], styles: ["[_nghost-%COMP%] {--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}[_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;padding:14px 8px 8px 15px;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;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 .send-button{background:var(--disabled-bg);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{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}[_nghost-%COMP%] .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:48px;right:25px}[_nghost-%COMP%] .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}[_nghost-%COMP%] .message-row__input textarea{font-size:14px;color:#333;width:100%;outline:none;min-height:30px;line-height:19px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px}[_nghost-%COMP%] .message-row__input textarea:focus{border:none}[_nghost-%COMP%] .message-row__input textarea::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}[_nghost-%COMP%] .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}[_nghost-%COMP%] dr-chat-dropped-files{margin-right:auto}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files{padding:0}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files__item{margin:0}[_nghost-%COMP%] .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}"], changeDetection: 0 }); }
244
+ } }, dependencies: [i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.NgClass, i3.NgIf, i4.DrDotFlashingComponent, i5.DrChatDroppedFilesComponent, i3.AsyncPipe], styles: ["[_nghost-%COMP%] {--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}[_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;padding:14px 8px 8px 15px;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;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 .send-button, [_nghost-%COMP%] .message-row__input .abort-button{background:var(--disabled-bg);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{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}[_nghost-%COMP%] .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}[_nghost-%COMP%] .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}[_nghost-%COMP%] .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}[_nghost-%COMP%] .message-row__input textarea:focus{border:none}[_nghost-%COMP%] .message-row__input textarea::placeholder{color:#9ea1aa}[_nghost-%COMP%] .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}[_nghost-%COMP%] .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}[_nghost-%COMP%] dr-chat-dropped-files{margin-right:auto}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files{padding:0}[_nghost-%COMP%] dr-chat-dropped-files .dropped-files__item{margin:0}[_nghost-%COMP%] .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}[_nghost-%COMP%] .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}"], changeDetection: 0 }); }
244
245
  }
245
246
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatFormDropdownComponent, [{
246
247
  type: Component,
247
- args: [{ selector: 'dr-chat-form-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<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", styles: [":host::ng-deep{--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}: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;padding:14px 8px 8px 15px;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;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 .send-button{background:var(--disabled-bg);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{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}:host::ng-deep .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:48px;right:25px}:host::ng-deep .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}:host::ng-deep .message-row__input textarea{font-size:14px;color:#333;width:100%;outline:none;min-height:30px;line-height:19px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px}:host::ng-deep .message-row__input textarea:focus{border:none}:host::ng-deep .message-row__input textarea::placeholder{color:#9ea1aa}:host::ng-deep .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}:host::ng-deep .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host::ng-deep dr-chat-dropped-files{margin-right:auto}:host::ng-deep dr-chat-dropped-files .dropped-files{padding:0}:host::ng-deep dr-chat-dropped-files .dropped-files__item{margin:0}:host::ng-deep .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}\n"] }]
248
+ args: [{ selector: 'dr-chat-form-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"message-row\" [ngClass]=\"{ 'message-row_loading': isUploadingFiles }\">\n <div\n class=\"message-row__input\"\n [ngClass]=\"{\n 'message-row__input--focused': inputFocus,\n 'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).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", styles: [":host::ng-deep{--disabled-bg: linear-gradient(270.95deg, rgba(130, 210, 240, .2) 10.98%, rgba(146, 146, 255, .2) 93.38%);display:flex;flex-direction:column;align-items:center;padding:0}: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;padding:14px 8px 8px 15px;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;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 .send-button,:host::ng-deep .message-row__input .abort-button{background:var(--disabled-bg);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{background:linear-gradient(266deg,#6969ff 25.2%,#4eb7df 90.24%) border-box;pointer-events:all}:host::ng-deep .message-row__input .wait-reply-dot-flashing{display:flex;align-items:center;width:32px;height:32px}:host::ng-deep .message-row__input:before{content:\"\";position:absolute;inset:-3px;background:linear-gradient(266.3deg,#6969ff 25.2%,#4eb7df 90.24%);border-radius:25px;z-index:-1}:host::ng-deep .message-row__input textarea{color:#333;width:100%;outline:none;min-height:30px;flex-grow:1;resize:none;padding:4px 48px 4px 4px;margin:auto;border:none;border-radius:22.5px;font-family:Poppins,sans-serif;font-size:14px;line-height:22px}:host::ng-deep .message-row__input textarea:focus{border:none}:host::ng-deep .message-row__input textarea::placeholder{color:#9ea1aa}:host::ng-deep .message-row__btns{display:flex;justify-content:space-between;width:100%;align-items:center}:host::ng-deep .message-row__input-textarea-wrap{display:flex;width:100%;position:relative}:host::ng-deep dr-chat-dropped-files{margin-right:auto}:host::ng-deep dr-chat-dropped-files .dropped-files{padding:0}:host::ng-deep dr-chat-dropped-files .dropped-files__item{margin:0}:host::ng-deep .message-row_loading .send-button{background:var(--disabled-bg);pointer-events:none}:host::ng-deep .message-row_loading .dropped-files__item{opacity:.5;pointer-events:none}\n"] }]
248
249
  }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, { textAreaElementRef: [{
249
250
  type: ViewChild,
250
251
  args: ['textAreaElement']
251
252
  }], fileInput: [{
252
253
  type: ViewChild,
253
254
  args: ['fileInput']
254
- }], isLoading: [{
255
+ }], isUploadingFiles: [{
255
256
  type: Input
256
257
  }], message: [{
257
258
  type: Input
@@ -286,4 +287,4 @@ export class DrChatFormDropdownComponent {
286
287
  type: HostListener,
287
288
  args: ['dragleave', ['$event']]
288
289
  }] }); })();
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"]}
290
+ //# 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() isUploadingFiles = 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 || this.isUploadingFiles) {\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': isUploadingFiles }\">\n    <div\n        class=\"message-row__input\"\n        [ngClass]=\"{\n            'message-row__input--focused': inputFocus,\n            'message-row__input--filled': !!message?.trim()?.length || !!(droppedFiles$ | async).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"]}