@datarailsshared/datarailsshared 1.6.25 → 1.6.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/datarailsshared-datarailsshared-1.6.29.tgz +0 -0
- package/esm2022/lib/dr-chat/chat.component.mjs +4 -4
- package/esm2022/lib/dr-chat/chat.module.mjs +5 -5
- package/esm2022/lib/dr-chat/dr-chat-form-dropdown/dr-chat-form-dropdown.component.mjs +289 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +8 -2
- package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +4 -4
- package/esm2022/lib/models/popover.mjs +1 -1
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +155 -250
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-chat/chat.component.d.ts +1 -1
- package/lib/dr-chat/chat.module.d.ts +2 -2
- package/lib/dr-chat/{dr-chat-form-with-history/chat-form-with-history.component.d.ts → dr-chat-form-dropdown/dr-chat-form-dropdown.component.d.ts} +6 -11
- package/lib/dr-dropdown/dr-dropdown.directive.d.ts +3 -1
- package/lib/dr-dropdown/dr-dropdown.service.d.ts +3 -1
- package/lib/models/popover.d.ts +2 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/datarailsshared-datarailsshared-1.6.25.tgz +0 -0
- package/esm2022/lib/dr-chat/dr-chat-form-with-history/chat-form-with-history.component.mjs +0 -392
|
Binary file
|
|
@@ -44,8 +44,8 @@ function DrChatComponent_dr_chat_suggestions_7_Template(rf, ctx) { if (rf & 1) {
|
|
|
44
44
|
i0.ɵɵclassProp("chat__suggestions--full-height", ctx_r3.fullScreen && !(ctx_r3.messages == null ? null : ctx_r3.messages.length));
|
|
45
45
|
i0.ɵɵproperty("values", ctx_r3.suggestions)("fullScreen", ctx_r3.fullScreen)("waitForReply", ctx_r3.waitForReply)("buttonMode", !!(ctx_r3.messages == null ? null : ctx_r3.messages.length));
|
|
46
46
|
} }
|
|
47
|
-
const _c2 = [[["dr-chat-alert"]], [["dr-chat-form"]], [["dr-
|
|
48
|
-
const _c3 = ["dr-chat-alert", "dr-chat-form", "dr-
|
|
47
|
+
const _c2 = [[["dr-chat-alert"]], [["dr-chat-form"]], [["dr-ai-search-input"]], [["dr-chat-message"]]];
|
|
48
|
+
const _c3 = ["dr-chat-alert", "dr-chat-form", "dr-ai-search-input", "dr-chat-message"];
|
|
49
49
|
export class DrChatComponent {
|
|
50
50
|
set contentUpdateSubject(value) {
|
|
51
51
|
if (value) {
|
|
@@ -166,7 +166,7 @@ export class DrChatComponent {
|
|
|
166
166
|
}
|
|
167
167
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatComponent, [{
|
|
168
168
|
type: Component,
|
|
169
|
-
args: [{ selector: 'dr-chat', providers: [DrChatCustomMessageService], template: "<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-
|
|
169
|
+
args: [{ selector: 'dr-chat', providers: [DrChatCustomMessageService], template: "<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", styles: [":host{height:100%;width:100%;display:flex;flex-direction:column}.chat{position:relative;display:flex;flex-grow:1;flex-direction:column;height:100%;background-color:#fff;color:#4e566c;font-family:Poppins,sans-serif;font-size:14px;font-weight:400;line-height:22px;box-shadow:0 2px 36px #00000026}.chat__sticky-top{display:flex;flex-direction:column;box-shadow:0 1px 3px #0003;z-index:1}.chat__empty-state{display:flex;justify-content:center}.chat__empty-state__text{padding:44px 0;font-family:Poppins,sans-serif;font-size:18px;font-weight:400;line-height:28px;text-align:center;max-width:440px;color:#4646ce}.chat__messages{display:flex;flex-grow:1;overflow-x:hidden;overflow-y:auto;height:100%;width:100%}.chat__messages__container{overflow-y:auto;overflow-x:hidden;display:flex;flex-shrink:0;flex-direction:column;width:100%;padding-bottom:1px}.chat__messages__container--scroll::ng-deep dr-chat-message{padding-right:8px}.chat__suggestions{flex:1}.chat__suggestions ::ng-deep .chat-suggestions__container{padding:0}.chat__suggestions--full-height{flex-grow:1;height:1px;overflow:auto}.chat--in-full-screen .chat__header{padding-left:32px;padding-right:32px}.chat--in-full-screen .chat__empty-state__text{padding:77px 0;font-size:28px;line-height:46px;max-width:570px}.chat--in-full-screen .chat__messages::ng-deep dr-chat-message{justify-content:center}.chat--in-full-screen .chat__messages::ng-deep .message{max-width:912px}.chat--in-full-screen .chat__suggestions::ng-deep .chat-suggestions__items{padding-left:0;padding-right:0}.chat--in-full-screen .chat__suggestions::ng-deep .chat-suggestions__items__item{font-size:16px}\n"] }]
|
|
170
170
|
}], function () { return [{ type: i0.ChangeDetectorRef }]; }, { fullScreen: [{
|
|
171
171
|
type: Input
|
|
172
172
|
}], noMessagesPlaceholder: [{
|
|
@@ -199,4 +199,4 @@ export class DrChatComponent {
|
|
|
199
199
|
type: ViewChild,
|
|
200
200
|
args: [DrChatSuggestionsComponent]
|
|
201
201
|
}] }); })();
|
|
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-chat-form-with-history\"></ng-content>\n    </div>\n</div>\n"]}
|
|
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"]}
|
|
@@ -14,15 +14,15 @@ import { DrChatSuggestionsComponent } from './dr-chat-suggestions/chat-suggestio
|
|
|
14
14
|
import { DrDotFlashingComponent } from './dr-dot-flashing/dr-dot-flashing.component';
|
|
15
15
|
import { DrChatAlertComponent } from './dr-chat-alert/dr-chat-alert.component';
|
|
16
16
|
import { ClickOutsideModule } from '../directives/click-outside/click-outside.module';
|
|
17
|
-
import { DrChatFormWithHistoryComponent } from './dr-chat-form-with-history/chat-form-with-history.component';
|
|
18
17
|
import { DrChatDroppedFilesComponent } from './dr-chat-dropped-files/dr-chat-dropped-files.component';
|
|
19
18
|
import { ShorterNamingPipe } from './dr-chat-dropped-files/pipes/shorter-naming.pipe';
|
|
19
|
+
import { DrChatFormDropdownComponent } from './dr-chat-form-dropdown/dr-chat-form-dropdown.component';
|
|
20
20
|
import * as i0 from "@angular/core";
|
|
21
21
|
const DR_CHAT_COMPONENTS = [
|
|
22
22
|
DrChatComponent,
|
|
23
23
|
DrChatMessageComponent,
|
|
24
24
|
DrChatFormComponent,
|
|
25
|
-
|
|
25
|
+
DrChatFormDropdownComponent,
|
|
26
26
|
DrChatMessageTextComponent,
|
|
27
27
|
DrChatMessageFileComponent,
|
|
28
28
|
DrChatSuggestionsComponent,
|
|
@@ -62,7 +62,7 @@ export class DrChatModule {
|
|
|
62
62
|
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(DrChatModule, { declarations: [DrChatComponent,
|
|
63
63
|
DrChatMessageComponent,
|
|
64
64
|
DrChatFormComponent,
|
|
65
|
-
|
|
65
|
+
DrChatFormDropdownComponent,
|
|
66
66
|
DrChatMessageTextComponent,
|
|
67
67
|
DrChatMessageFileComponent,
|
|
68
68
|
DrChatSuggestionsComponent,
|
|
@@ -77,11 +77,11 @@ export class DrChatModule {
|
|
|
77
77
|
ClickOutsideModule], exports: [DrChatComponent,
|
|
78
78
|
DrChatMessageComponent,
|
|
79
79
|
DrChatFormComponent,
|
|
80
|
-
|
|
80
|
+
DrChatFormDropdownComponent,
|
|
81
81
|
DrChatMessageTextComponent,
|
|
82
82
|
DrChatMessageFileComponent,
|
|
83
83
|
DrChatSuggestionsComponent,
|
|
84
84
|
DrDotFlashingComponent,
|
|
85
85
|
DrChatAlertComponent,
|
|
86
86
|
DrChatDroppedFilesComponent, DrChatCustomMessageDirective] }); })();
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1jaGF0L2NoYXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDaEgsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sd0VBQXdFLENBQUM7QUFDdEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDOUYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDckYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0seURBQXlELENBQUM7O0FBRXRHLE1BQU0sa0JBQWtCLEdBQUc7SUFDdkIsZUFBZTtJQUNmLHNCQUFzQjtJQUN0QixtQkFBbUI7SUFDbkIsMkJBQTJCO0lBQzNCLDBCQUEwQjtJQUMxQiwwQkFBMEI7SUFDMUIsMEJBQTBCO0lBQzFCLHNCQUFzQjtJQUN0QixvQkFBb0I7SUFDcEIsMkJBQTJCO0NBQzlCLENBQUM7QUFFRixNQUFNLGFBQWEsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFFMUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFlMUQsTUFBTSxPQUFPLFlBQVk7Z0dBQVosWUFBWTtrR0FBWixZQUFZO3NHQVhqQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLFlBQVk7WUFDWixjQUFjO1lBQ2QsY0FBYztZQUNkLGVBQWU7WUFDZixrQkFBa0I7O3VGQUtiLFlBQVk7Y0FieEIsUUFBUTtlQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxXQUFXO29CQUNYLG1CQUFtQjtvQkFDbkIsWUFBWTtvQkFDWixjQUFjO29CQUNkLGNBQWM7b0JBQ2QsZUFBZTtvQkFDZixrQkFBa0I7aUJBQ3JCO2dCQUNELFlBQVksRUFBRSxDQUFDLEdBQUcsa0JBQWtCLEVBQUUsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGFBQWEsQ0FBQztnQkFDOUUsT0FBTyxFQUFFLENBQUMsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLGtCQUFrQixDQUFDO2FBQzFEOzt3RkFDWSxZQUFZLG1CQTdCckIsZUFBZTtRQUNmLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsMkJBQTJCO1FBQzNCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLHNCQUFzQjtRQUN0QixvQkFBb0I7UUFDcEIsMkJBQTJCLEVBS0gsNEJBQTRCLEVBRmpDLGlCQUFpQixhQU1oQyxXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWixjQUFjO1FBQ2QsY0FBYztRQUNkLGVBQWU7UUFDZixrQkFBa0IsYUF4QnRCLGVBQWU7UUFDZixzQkFBc0I7UUFDdEIsbUJBQW1CO1FBQ25CLDJCQUEyQjtRQUMzQiwwQkFBMEI7UUFDMUIsMEJBQTBCO1FBQzFCLDBCQUEwQjtRQUMxQixzQkFBc0I7UUFDdEIsb0JBQW9CO1FBQ3BCLDJCQUEyQixFQUtILDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4uL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcbmltcG9ydCB7IERyQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vZHItYXZhdGFyL2RyLWF2YXRhci5tb2R1bGUnO1xuaW1wb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IERyQ2hhdENvbXBvbmVudCB9IGZyb20gJy4vY2hhdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2NoYXQtbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Rm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtL2NoYXQtZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZVRleHRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtdGV4dC9jaGF0LW1lc3NhZ2UtdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0TWVzc2FnZUZpbGVDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtbWVzc2FnZS9kci1jaGF0LW1lc3NhZ2UtZmlsZS9jaGF0LW1lc3NhZ2UtZmlsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0Q3VzdG9tTWVzc2FnZURpcmVjdGl2ZSB9IGZyb20gJy4vZHItY2hhdC1tZXNzYWdlL2RyLWNoYXQtbWVzc2FnZS1jdXN0b20vY2hhdC1jdXN0b20tbWVzc2FnZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJDaGF0U3VnZ2VzdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtc3VnZ2VzdGlvbnMvY2hhdC1zdWdnZXN0aW9ucy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJEb3RGbGFzaGluZ0NvbXBvbmVudCB9IGZyb20gJy4vZHItZG90LWZsYXNoaW5nL2RyLWRvdC1mbGFzaGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJDaGF0QWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2RyLWNoYXQtYWxlcnQvZHItY2hhdC1hbGVydC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2xpY2tPdXRzaWRlTW9kdWxlIH0gZnJvbSAnLi4vZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlL2NsaWNrLW91dHNpZGUubW9kdWxlJztcbmltcG9ydCB7IERyQ2hhdERyb3BwZWRGaWxlc0NvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1kcm9wcGVkLWZpbGVzL2RyLWNoYXQtZHJvcHBlZC1maWxlcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2hvcnRlck5hbWluZ1BpcGUgfSBmcm9tICcuL2RyLWNoYXQtZHJvcHBlZC1maWxlcy9waXBlcy9zaG9ydGVyLW5hbWluZy5waXBlJztcbmltcG9ydCB7IERyQ2hhdEZvcm1Ecm9wZG93bkNvbXBvbmVudCB9IGZyb20gJy4vZHItY2hhdC1mb3JtLWRyb3Bkb3duL2RyLWNoYXQtZm9ybS1kcm9wZG93bi5jb21wb25lbnQnO1xuXG5jb25zdCBEUl9DSEFUX0NPTVBPTkVOVFMgPSBbXG4gICAgRHJDaGF0Q29tcG9uZW50LFxuICAgIERyQ2hhdE1lc3NhZ2VDb21wb25lbnQsXG4gICAgRHJDaGF0Rm9ybUNvbXBvbmVudCxcbiAgICBEckNoYXRGb3JtRHJvcGRvd25Db21wb25lbnQsXG4gICAgRHJDaGF0TWVzc2FnZVRleHRDb21wb25lbnQsXG4gICAgRHJDaGF0TWVzc2FnZUZpbGVDb21wb25lbnQsXG4gICAgRHJDaGF0U3VnZ2VzdGlvbnNDb21wb25lbnQsXG4gICAgRHJEb3RGbGFzaGluZ0NvbXBvbmVudCxcbiAgICBEckNoYXRBbGVydENvbXBvbmVudCxcbiAgICBEckNoYXREcm9wcGVkRmlsZXNDb21wb25lbnQsXG5dO1xuXG5jb25zdCBEUl9DSEFUX1BJUEVTID0gW1Nob3J0ZXJOYW1pbmdQaXBlXTtcblxuY29uc3QgRFJfQ0hBVF9ESVJFQ1RJVkVTID0gW0RyQ2hhdEN1c3RvbU1lc3NhZ2VEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRHJBdmF0YXJNb2R1bGUsXG4gICAgICAgIERySW5wdXRzTW9kdWxlLFxuICAgICAgICBEclRvb2x0aXBNb2R1bGUsXG4gICAgICAgIENsaWNrT3V0c2lkZU1vZHVsZSxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogWy4uLkRSX0NIQVRfQ09NUE9ORU5UUywgLi4uRFJfQ0hBVF9ESVJFQ1RJVkVTLCAuLi5EUl9DSEFUX1BJUEVTXSxcbiAgICBleHBvcnRzOiBbLi4uRFJfQ0hBVF9DT01QT05FTlRTLCAuLi5EUl9DSEFUX0RJUkVDVElWRVNdLFxufSlcbmV4cG9ydCBjbGFzcyBEckNoYXRNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/platform-browser";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "../dr-dot-flashing/dr-dot-flashing.component";
|
|
9
|
+
import * as i5 from "../dr-chat-dropped-files/dr-chat-dropped-files.component";
|
|
10
|
+
const _c0 = ["textAreaElement"];
|
|
11
|
+
const _c1 = ["fileInput"];
|
|
12
|
+
function DrChatFormDropdownComponent_dr_chat_dropped_files_2_Template(rf, ctx) { if (rf & 1) {
|
|
13
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
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)); });
|
|
16
|
+
i0.ɵɵpipe(1, "async");
|
|
17
|
+
i0.ɵɵelementEnd();
|
|
18
|
+
} if (rf & 2) {
|
|
19
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
20
|
+
i0.ɵɵproperty("files", i0.ɵɵpipeBind1(1, 3, ctx_r0.droppedFiles$))("isRemovable", true)("maxLengthText", 15);
|
|
21
|
+
} }
|
|
22
|
+
function DrChatFormDropdownComponent_i_12_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
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)); });
|
|
26
|
+
i0.ɵɵelementEnd();
|
|
27
|
+
} }
|
|
28
|
+
function DrChatFormDropdownComponent_i_13_Template(rf, ctx) { if (rf & 1) {
|
|
29
|
+
const _r11 = i0.ɵɵgetCurrentView();
|
|
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()); });
|
|
32
|
+
i0.ɵɵelementEnd();
|
|
33
|
+
} }
|
|
34
|
+
function DrChatFormDropdownComponent_dr_dot_flashing_14_Template(rf, ctx) { if (rf & 1) {
|
|
35
|
+
i0.ɵɵelement(0, "dr-dot-flashing", 15);
|
|
36
|
+
} }
|
|
37
|
+
const _c2 = function (a0) { return { "message-row_loading": a0 }; };
|
|
38
|
+
const _c3 = function (a0, a1) { return { "message-row__input--focused": a0, "message-row__input--filled": a1 }; };
|
|
39
|
+
const _c4 = ["*"];
|
|
40
|
+
export class DrChatFormDropdownComponent {
|
|
41
|
+
constructor(cdr, domSanitizer) {
|
|
42
|
+
this.cdr = cdr;
|
|
43
|
+
this.domSanitizer = domSanitizer;
|
|
44
|
+
this._textareaInitialHeight = true;
|
|
45
|
+
this.inputFocus = false;
|
|
46
|
+
this.inputHover = false;
|
|
47
|
+
this.droppedFiles$ = new BehaviorSubject([]);
|
|
48
|
+
this.isLoading = false;
|
|
49
|
+
/**
|
|
50
|
+
* Predefined message text
|
|
51
|
+
*
|
|
52
|
+
* @type {string}
|
|
53
|
+
*/
|
|
54
|
+
this.message = '';
|
|
55
|
+
/**
|
|
56
|
+
* Message placeholder text
|
|
57
|
+
*
|
|
58
|
+
* @type {string}
|
|
59
|
+
*/
|
|
60
|
+
this.messagePlaceholder = 'Type a message';
|
|
61
|
+
/**
|
|
62
|
+
* Show send button
|
|
63
|
+
*
|
|
64
|
+
* @type {boolean}
|
|
65
|
+
*/
|
|
66
|
+
this.dropFiles = false;
|
|
67
|
+
/**
|
|
68
|
+
* File drop placeholder text
|
|
69
|
+
*
|
|
70
|
+
* @type {string}
|
|
71
|
+
*/
|
|
72
|
+
this.dropFilePlaceholder = 'Drop file to send';
|
|
73
|
+
/**
|
|
74
|
+
* Parameter to check is send message function available
|
|
75
|
+
*
|
|
76
|
+
* @type {boolean}
|
|
77
|
+
*/
|
|
78
|
+
this.waitForReply = false;
|
|
79
|
+
/**
|
|
80
|
+
* Parameter to check is send message function available
|
|
81
|
+
*
|
|
82
|
+
* @type {boolean}
|
|
83
|
+
*/
|
|
84
|
+
this.showDotFlashing = false;
|
|
85
|
+
/**
|
|
86
|
+
*
|
|
87
|
+
* @type {EventEmitter<{ message: string, files: IFile[] }>}
|
|
88
|
+
*/
|
|
89
|
+
this.send = new EventEmitter();
|
|
90
|
+
this.uploadFiles = new EventEmitter();
|
|
91
|
+
this.abort = new EventEmitter();
|
|
92
|
+
/**
|
|
93
|
+
* Emits when message input value has been changed
|
|
94
|
+
*
|
|
95
|
+
* @type {EventEmitter<string>}
|
|
96
|
+
*/
|
|
97
|
+
this.inputChange = new EventEmitter();
|
|
98
|
+
this.fileOver = false;
|
|
99
|
+
}
|
|
100
|
+
onDrop(event) {
|
|
101
|
+
if (this.dropFiles) {
|
|
102
|
+
event.preventDefault();
|
|
103
|
+
event.stopPropagation();
|
|
104
|
+
this.fileOver = false;
|
|
105
|
+
const files = event.dataTransfer?.files;
|
|
106
|
+
if (files) {
|
|
107
|
+
this.saveFiles(files);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
removeFile(file) {
|
|
112
|
+
const droppedFiles = this.droppedFiles$.value;
|
|
113
|
+
const index = droppedFiles.indexOf(file);
|
|
114
|
+
if (index >= 0) {
|
|
115
|
+
droppedFiles.splice(index, 1);
|
|
116
|
+
this.droppedFiles$.next(droppedFiles);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
onDragOver(event) {
|
|
120
|
+
event.preventDefault();
|
|
121
|
+
event.stopPropagation();
|
|
122
|
+
if (this.dropFiles) {
|
|
123
|
+
this.fileOver = true;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
onDragLeave(event) {
|
|
127
|
+
event.preventDefault();
|
|
128
|
+
event.stopPropagation();
|
|
129
|
+
if (this.dropFiles) {
|
|
130
|
+
this.fileOver = false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
sendMessage($event) {
|
|
134
|
+
if (!$event || !$event.shiftKey) {
|
|
135
|
+
$event?.preventDefault();
|
|
136
|
+
$event?.stopPropagation();
|
|
137
|
+
if (this.waitForReply) {
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
else if (this.droppedFiles$.value.length || String(this.message).trim().length) {
|
|
141
|
+
this._textareaInitialHeight = true;
|
|
142
|
+
this.send.emit({ message: this.message, files: this.droppedFiles$.value });
|
|
143
|
+
this.message = '';
|
|
144
|
+
this.droppedFiles$.next([]);
|
|
145
|
+
this.cdr.markForCheck();
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
abortMessage() {
|
|
150
|
+
this.abort.emit();
|
|
151
|
+
}
|
|
152
|
+
onModelChange(value) {
|
|
153
|
+
this._textareaInitialHeight = false;
|
|
154
|
+
this.inputChange.emit(value);
|
|
155
|
+
}
|
|
156
|
+
getTextAreaHeight(textAreaElement) {
|
|
157
|
+
if (this._textareaInitialHeight) {
|
|
158
|
+
textAreaElement.style.height = '30px';
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
textAreaElement.style.height = 'auto';
|
|
162
|
+
textAreaElement.style.height = textAreaElement.scrollHeight + 'px';
|
|
163
|
+
}
|
|
164
|
+
return `${textAreaElement.style.height}`;
|
|
165
|
+
}
|
|
166
|
+
onFileSelected(event) {
|
|
167
|
+
const input = event.target;
|
|
168
|
+
this.fileOver = false;
|
|
169
|
+
const files = input.files;
|
|
170
|
+
if (files && files.length) {
|
|
171
|
+
this.saveFiles(Array.from(files));
|
|
172
|
+
}
|
|
173
|
+
this.fileInput.nativeElement.value = '';
|
|
174
|
+
}
|
|
175
|
+
async saveFiles(files) {
|
|
176
|
+
const uploadedFiles = [];
|
|
177
|
+
for (const file of files) {
|
|
178
|
+
let res = file;
|
|
179
|
+
res.data = (await this.base64Convert(res));
|
|
180
|
+
this.droppedFiles$.next([...this.droppedFiles$.value, res]);
|
|
181
|
+
uploadedFiles.push(res);
|
|
182
|
+
this.cdr.markForCheck();
|
|
183
|
+
this.cdr.detectChanges();
|
|
184
|
+
}
|
|
185
|
+
this.uploadFiles.emit(uploadedFiles.map((item) => ({ data: item.data, name: item.name })));
|
|
186
|
+
}
|
|
187
|
+
base64Convert(file) {
|
|
188
|
+
return new Promise((resolve, reject) => {
|
|
189
|
+
const reader = new FileReader();
|
|
190
|
+
reader.onload = () => resolve(reader.result);
|
|
191
|
+
reader.onerror = (error) => reject(error);
|
|
192
|
+
reader.readAsDataURL(file);
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
/** @nocollapse */ static { this.ɵfac = function DrChatFormDropdownComponent_Factory(t) { return new (t || DrChatFormDropdownComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DomSanitizer)); }; }
|
|
196
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrChatFormDropdownComponent, selectors: [["dr-chat-form-dropdown"]], viewQuery: function DrChatFormDropdownComponent_Query(rf, ctx) { if (rf & 1) {
|
|
197
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
198
|
+
i0.ɵɵviewQuery(_c1, 5);
|
|
199
|
+
} if (rf & 2) {
|
|
200
|
+
let _t;
|
|
201
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.textAreaElementRef = _t.first);
|
|
202
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.fileInput = _t.first);
|
|
203
|
+
} }, hostVars: 2, hostBindings: function DrChatFormDropdownComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
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
|
+
} if (rf & 2) {
|
|
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) {
|
|
208
|
+
i0.ɵɵprojectionDef();
|
|
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, " ");
|
|
215
|
+
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); });
|
|
220
|
+
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);
|
|
224
|
+
i0.ɵɵelementEnd()()();
|
|
225
|
+
} if (rf & 2) {
|
|
226
|
+
const _r1 = i0.ɵɵreference(6);
|
|
227
|
+
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)));
|
|
231
|
+
i0.ɵɵadvance(1);
|
|
232
|
+
i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(3, 11, ctx.droppedFiles$).length);
|
|
233
|
+
i0.ɵɵadvance(3);
|
|
234
|
+
i0.ɵɵstyleMap(ctx.getTextAreaHeight(_r1));
|
|
235
|
+
i0.ɵɵpropertyInterpolate("placeholder", ctx.fileOver ? ctx.dropFilePlaceholder : ctx.messagePlaceholder);
|
|
236
|
+
i0.ɵɵproperty("ngModel", ctx.message)("rows", 1);
|
|
237
|
+
i0.ɵɵadvance(7);
|
|
238
|
+
i0.ɵɵproperty("ngIf", !ctx.waitForReply);
|
|
239
|
+
i0.ɵɵadvance(1);
|
|
240
|
+
i0.ɵɵproperty("ngIf", ctx.waitForReply && !ctx.showDotFlashing);
|
|
241
|
+
i0.ɵɵadvance(1);
|
|
242
|
+
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
|
+
}
|
|
245
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrChatFormDropdownComponent, [{
|
|
246
|
+
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
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, { textAreaElementRef: [{
|
|
249
|
+
type: ViewChild,
|
|
250
|
+
args: ['textAreaElement']
|
|
251
|
+
}], fileInput: [{
|
|
252
|
+
type: ViewChild,
|
|
253
|
+
args: ['fileInput']
|
|
254
|
+
}], isLoading: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], message: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], messagePlaceholder: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], dropFiles: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], dropFilePlaceholder: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], waitForReply: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], showDotFlashing: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], send: [{
|
|
269
|
+
type: Output
|
|
270
|
+
}], uploadFiles: [{
|
|
271
|
+
type: Output
|
|
272
|
+
}], abort: [{
|
|
273
|
+
type: Output
|
|
274
|
+
}], inputChange: [{
|
|
275
|
+
type: Output
|
|
276
|
+
}], fileOver: [{
|
|
277
|
+
type: HostBinding,
|
|
278
|
+
args: ['class.file-over']
|
|
279
|
+
}], onDrop: [{
|
|
280
|
+
type: HostListener,
|
|
281
|
+
args: ['drop', ['$event']]
|
|
282
|
+
}], onDragOver: [{
|
|
283
|
+
type: HostListener,
|
|
284
|
+
args: ['dragover', ['$event']]
|
|
285
|
+
}], onDragLeave: [{
|
|
286
|
+
type: HostListener,
|
|
287
|
+
args: ['dragleave', ['$event']]
|
|
288
|
+
}] }); })();
|
|
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":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { IFIle } from '../../models/chat';\nimport { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'dr-chat-form-dropdown',\n    templateUrl: './dr-chat-form-dropdown.component.html',\n    styleUrls: ['./dr-chat-form-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrChatFormDropdownComponent {\n    @ViewChild('textAreaElement') textAreaElementRef: ElementRef;\n    @ViewChild('fileInput') fileInput: ElementRef;\n    _textareaInitialHeight = true;\n    inputFocus = false;\n    inputHover = false;\n\n    droppedFiles$ = new BehaviorSubject<IFIle[]>([]);\n\n    @Input() isLoading = false;\n\n    /**\n     * Predefined message text\n     *\n     * @type {string}\n     */\n    @Input() message = '';\n\n    /**\n     * Message placeholder text\n     *\n     * @type {string}\n     */\n    @Input() messagePlaceholder = 'Type a message';\n\n    /**\n     * Show send button\n     *\n     * @type {boolean}\n     */\n    @Input() dropFiles = false;\n\n    /**\n     * File drop placeholder text\n     *\n     * @type {string}\n     */\n    @Input() dropFilePlaceholder = 'Drop file to send';\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() waitForReply = false;\n\n    /**\n     * Parameter to check is send message function available\n     *\n     * @type {boolean}\n     */\n    @Input() showDotFlashing = false;\n\n    /**\n     *\n     * @type {EventEmitter<{ message: string, files: IFile[] }>}\n     */\n    @Output() send = new EventEmitter<{ message: string; files: IFIle[] }>();\n    @Output() uploadFiles = new EventEmitter<IFIle[]>();\n    @Output() abort = new EventEmitter<void>();\n\n    /**\n     * Emits when message input value has been changed\n     *\n     * @type {EventEmitter<string>}\n     */\n\n    @Output() inputChange = new EventEmitter<string>();\n\n    @HostBinding('class.file-over') fileOver = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected domSanitizer: DomSanitizer,\n    ) {}\n\n    @HostListener('drop', ['$event'])\n    onDrop(event: any) {\n        if (this.dropFiles) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.fileOver = false;\n            const files = event.dataTransfer?.files;\n            if (files) {\n                this.saveFiles(files);\n            }\n        }\n    }\n\n    removeFile(file: 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"]}
|
|
@@ -47,6 +47,8 @@ export class DrDropdownDirective {
|
|
|
47
47
|
asChild: !!this.child,
|
|
48
48
|
providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],
|
|
49
49
|
action$: this.drDropdownAction,
|
|
50
|
+
positionOffsetX: this.drDropdownPositionOffsetX,
|
|
51
|
+
positionOffsetY: this.drDropdownPositionOffsetY,
|
|
50
52
|
options: {
|
|
51
53
|
drDropdownInHover: this.drDropdownInHover,
|
|
52
54
|
position: this.drDropdownPosition,
|
|
@@ -70,7 +72,7 @@ export class DrDropdownDirective {
|
|
|
70
72
|
/** @nocollapse */ static { this.ɵfac = function DrDropdownDirective_Factory(t) { return new (t || DrDropdownDirective)(); }; }
|
|
71
73
|
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrDropdownDirective, selectors: [["", "drDropdown", ""]], hostBindings: function DrDropdownDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
72
74
|
i0.ɵɵlistener("mouseenter", function DrDropdownDirective_mouseenter_HostBindingHandler() { return ctx.elementHover(); })("click", function DrDropdownDirective_click_HostBindingHandler() { return ctx.elementClick(); })("mouseleave", function DrDropdownDirective_mouseleave_HostBindingHandler() { return ctx.leaveDropdownTriggerElement(); })("mouseup", function DrDropdownDirective_mouseup_HostBindingHandler() { return ctx.documentClick(); }, false, i0.ɵɵresolveDocument);
|
|
73
|
-
} }, inputs: { drDropdown: "drDropdown", drDropdownPosition: "drDropdownPosition", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover", dataAnalytics: ["data-analytics", "dataAnalytics"] }, outputs: { drDropdownAction: "drDropdownAction", dropdownClosed: "drDropdownClose", dropdownOpened: "drDropdownOpened" }, features: [i0.ɵɵProvidersFeature([
|
|
75
|
+
} }, inputs: { drDropdown: "drDropdown", drDropdownPosition: "drDropdownPosition", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover", dataAnalytics: ["data-analytics", "dataAnalytics"], drDropdownPositionOffsetX: "drDropdownPositionOffsetX", drDropdownPositionOffsetY: "drDropdownPositionOffsetY" }, outputs: { drDropdownAction: "drDropdownAction", dropdownClosed: "drDropdownClose", dropdownOpened: "drDropdownOpened" }, features: [i0.ɵɵProvidersFeature([
|
|
74
76
|
{
|
|
75
77
|
provide: DropdownInstanceService,
|
|
76
78
|
useFactory: ((injector) => {
|
|
@@ -108,6 +110,10 @@ export class DrDropdownDirective {
|
|
|
108
110
|
}], dataAnalytics: [{
|
|
109
111
|
type: Input,
|
|
110
112
|
args: [{ alias: 'data-analytics' }]
|
|
113
|
+
}], drDropdownPositionOffsetX: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], drDropdownPositionOffsetY: [{
|
|
116
|
+
type: Input
|
|
111
117
|
}], drDropdownAction: [{
|
|
112
118
|
type: Output
|
|
113
119
|
}], dropdownClosed: [{
|
|
@@ -139,4 +145,4 @@ export class DrDropdownChildDirective {
|
|
|
139
145
|
selector: '[drDropdownChild]',
|
|
140
146
|
}]
|
|
141
147
|
}], null, null); })();
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, OnDestroy, Output } from '@angular/core';\nimport { ElPosition, IDropdownAction, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrPopoverRef } from '../models/popover';\n\n@Directive({\n    selector: '[drDropdown]',\n    providers: [\n        {\n            provide: DropdownInstanceService,\n            useFactory: (injector: Injector) => {\n                const service = injector.get(DropdownInstanceService, null, { skipSelf: true });\n                return service ?? new DropdownInstanceService(injector);\n            },\n            deps: [Injector],\n        },\n    ],\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    private readonly elementRef = inject(ElementRef<HTMLElement>);\n    private readonly service = inject(DrDropdownService);\n    private readonly child = inject(DrDropdownChildDirective, { optional: true, self: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService);\n\n    @Input({ required: true })\n    drDropdown: IDropdownItem<T>[];\n    @Input()\n    drDropdownPosition: ElPosition = 'left-top';\n    @Input()\n    drDropdownClass: string;\n    @Input()\n    drDropdownInHover: boolean;\n    @Input({ alias: 'data-analytics' })\n    dataAnalytics: string;\n\n    @Input() drDropdownPositionOffsetX: number;\n\n    @Input() drDropdownPositionOffsetY: number;\n\n    @Output()\n    drDropdownAction = new EventEmitter<IDropdownAction<T>>();\n    @Output('drDropdownClose') dropdownClosed = new EventEmitter<void>();\n    @Output('drDropdownOpened') dropdownOpened = new EventEmitter<void>();\n\n    private ref: DrPopoverRef<DrDropdownComponent>;\n\n    private readonly mouseleaveTimeout = 200;\n\n    @HostListener('mouseenter')\n    elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click')\n    elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave')\n    leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(() => {\n                if (this.ref && !this.ref.instance.wasHovered) {\n                    this.close();\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup')\n    documentClick() {\n        this.close();\n    }\n\n    private openDropdown(): void {\n        if (!this.drDropdown?.length) {\n            return;\n        }\n\n        if (this.ref) {\n            this.close();\n            return;\n        }\n\n        this.ref = this.service.open({\n            hostRef: this.elementRef,\n            position: this.drDropdownPosition,\n            asChild: !!this.child,\n            providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],\n            action$: this.drDropdownAction,\n            positionOffsetX: this.drDropdownPositionOffsetX,\n            positionOffsetY: this.drDropdownPositionOffsetY,\n            options: {\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.drDropdownPosition,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n                dataAnalytics: this.dataAnalytics,\n            },\n        });\n        this.dropdownOpened.emit();\n    }\n\n    private close(): void {\n        if (this.ref) {\n            this.ref.close();\n            this.ref = null;\n            this.dropdownClosed.emit();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.close();\n    }\n}\n\n@Directive({\n    selector: '[drDropdownChild]',\n})\nexport class DrDropdownChildDirective {}\n"]}
|