UNPKG

ngx-tencent-im

Version:
226 lines 41.2 kB
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core'; import { MESSAGE_STATUS } from '../../shared.data'; import { pushCurrentMessageListAction, showAction } from '../../store/actions'; import { currentConversationSelector } from '../../store/selectors'; import { emojiMap, emojiName, emojiUrl } from '../../util/emoji-map'; import * as i0 from "@angular/core"; import * as i1 from "@ngrx/store"; import * as i2 from "../../tim-helper.service"; import * as i3 from "../../re-edit-message.service"; import * as i4 from "ng-zorro-antd/button"; import * as i5 from "@angular/common"; import * as i6 from "ng-zorro-antd/core/transition-patch"; import * as i7 from "ng-zorro-antd/icon"; import * as i8 from "ng-zorro-antd/popover"; import * as i9 from "@angular/forms"; import * as i10 from "ng-zorro-antd/core/wave"; import * as i11 from "ng-zorro-antd/tooltip"; export class MessageSendBoxComponent { constructor(store, cd, timHelperService, reEditMessage) { this.store = store; this.cd = cd; this.timHelperService = timHelperService; this.reEditMessage = reEditMessage; this.visible = false; this.emojiName = emojiName; this.emojiUrl = emojiUrl; this.emojiMap = emojiMap; this.focus = false; // 消息内容 this.messageContent = ''; } ngOnInit() { this.store.select(currentConversationSelector).subscribe(currentConversation => { this.currentConversation = currentConversation; if (!currentConversation || !currentConversation.conversationID) { this.toAccount = ''; } else { switch (currentConversation.type) { case 'C2C': this.toAccount = currentConversation.conversationID.replace('C2C', ''); break; case 'GROUP': this.toAccount = currentConversation.conversationID.replace('GROUP', ''); break; default: this.toAccount = currentConversation.conversationID; } } if (!currentConversation || !currentConversation.type) { this.currentConversationType = ''; } else { this.currentConversationType = currentConversation.type; } }); this.textInput.nativeElement.addEventListener('paste', this.handlePaste.bind(this)); this.reEditMessage.reEditMessage.subscribe((payload) => { this.messageContent = payload; this.cd.markForCheck(); }); } onfocus(event) { console.log('onfocus'); this.focus = true; console.log(this.currentConversation); this.timHelperService.checkoutConversation(this.currentConversation.conversationID); } onblur(event) { console.log('onblur'); this.focus = false; } handleEnter(event) { this.sendTextMessage(); } handleLine(event) { event.preventDefault(); if (event.ctrlKey && event.key === 'Enter') { this.messageContent += '\n'; } } handleUp(event) { console.log('handleUp::', event); } handleDown(event) { console.log('handleDown::', event); } keyDown(event) { if (!event.ctrlKey && event.key === 'Enter') { event.preventDefault(); this.handleEnter(event); } if (event.key === 'ArrowUp') { event.stopPropagation(); this.handleUp(event); } if (event.key === 'ArrowDown') { event.stopPropagation(); this.handleDown(event); } } handlePaste(e) { const clipboardData = e.clipboardData; let file; if (clipboardData && clipboardData.files && clipboardData.files.length > 0) { file = clipboardData.files[0]; } if (typeof file === 'undefined') { return; } // 1. 创建消息实例,接口返回的实例可以上屏 const message = this.timHelperService.tim.createImageMessage({ to: this.toAccount, conversationType: this.currentConversationType, payload: { file, }, onProgress: (percent) => { message.progress = percent; // 手动给message 实例加个响应式属性: progress }, }); // 2. 发送消息 const promise = this.timHelperService.tim.sendMessage(message).then(res => { this.store.dispatch(pushCurrentMessageListAction({ message })); }); promise.catch((error) => { console.error('[sendMessage error]::', error); }); } sendImage(event) { console.log('sendImage'); const message = this.timHelperService.tim.createImageMessage({ to: this.toAccount, conversationType: this.currentConversationType, payload: { file: this.imagePicker.nativeElement // 或者用event.target }, onProgress: (percent) => { // 手动给message 实例加个响应式属性: progress message.progress = percent; console.log('percent:', percent); } }); this.timHelperService.tim .sendMessage(message) .then(({ data }) => { console.log('发送成功', data); this.store.dispatch(pushCurrentMessageListAction({ message: Object.assign({}, data.message) })); this.imagePicker.nativeElement.value = null; }) .catch(imError => { console.error('imError::', imError); }); } sendFile(event) { const message = this.timHelperService.tim.createFileMessage({ to: this.toAccount, conversationType: this.currentConversationType, payload: { file: document.getElementById('filePicker'), // 或者用event.target }, onProgress: (percent) => { message.progress = percent; console.log('上传进度', percent); }, }); this.timHelperService.tim .sendMessage(message) .then(({ data }) => { this.store.dispatch(pushCurrentMessageListAction({ message: Object.assign({}, data.message) })); this.filePicker.nativeElement.value = null; }) .catch((imError) => { console.error('imError::', imError); }); } chooseEmoji(item) { console.log(item); this.messageContent += item; } sendTextMessage() { if (this.messageContent === '' || this.messageContent.trim().length === 0) { this.messageContent = ''; this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.warning, message: '不能发送空消息哦!' })); return; } const message = this.timHelperService.tim.createTextMessage({ to: this.toAccount, conversationType: this.currentConversationType, payload: { text: this.messageContent } }); this.store.dispatch(pushCurrentMessageListAction({ message })); this.timHelperService.eventBus$.next('scroll-bottom'); this.timHelperService.tim.sendMessage(message).catch(error => { console.error('[sendMessage error]::', error); }); this.messageContent = ''; } handleSendImageClick(input, event) { event.stopPropagation(); input.click(); } handleSendFileClick(input) { input.click(); } ngOnDestroy() { this.textInput.nativeElement.addEventListener('paste', this.handlePaste.bind(this)); } } MessageSendBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: MessageSendBoxComponent, deps: [{ token: i1.Store }, { token: i0.ChangeDetectorRef }, { token: i2.TimHelperService }, { token: i3.ReEditMessageService }], target: i0.ɵɵFactoryTarget.Component }); MessageSendBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: MessageSendBoxComponent, selector: "app-message-send-box", viewQueries: [{ propertyName: "imagePicker", first: true, predicate: ["imagePicker"], descendants: true }, { propertyName: "filePicker", first: true, predicate: ["filePicker"], descendants: true }, { propertyName: "textInput", first: true, predicate: ["textInput"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"message-send-box-wrapper\" [ngClass]=\"{'white-background': focus}\"\r\n (focus)=\"onfocus($event)\">\r\n <div class=\"send-header-bar\">\r\n\r\n <input type=\"file\" #imagePicker accept=\".jpg, .jpeg, .png, .gif\" (change)=\"sendImage($event)\"\r\n (click)=\"$event.stopPropagation()\" style=\"display:none\" />\r\n\r\n <input type=\"file\" #filePicker (change)=\"sendFile($event)\" (click)=\"$event.stopPropagation()\"\r\n style=\"display:none\" />\r\n\r\n <i nz-icon nzType=\"meh\" nzTheme=\"outline\" title=\"\u53D1\u8868\u60C5\" nz-popover nzPopoverTitle=\"Title\"\r\n [(nzPopoverVisible)]=\"visible\" nzPopoverTrigger=\"click\" [nzPopoverContent]=\"contentTemplate\"\r\n [nzPopoverTitle]=\"'\u8868\u60C5'\"></i>\r\n\r\n <i nz-icon nzType=\"picture\" nzTheme=\"outline\" title=\"\u53D1\u56FE\u7247\"\r\n (click)=\"handleSendImageClick(imagePicker,$event)\"></i>\r\n\r\n <i nz-icon nzType=\"folder\" nzTheme=\"outline\" title=\"\u53D1\u6587\u4EF6\"\r\n (click)=\"handleSendFileClick(filePicker)\"></i>\r\n\r\n </div>\r\n <div class=\"bottom\">\r\n <textarea rows=\"4\" resize=\"false\" class=\"text-input\" #textInput [(ngModel)]=\"messageContent\"\r\n (focus)=\"onfocus($event)\" (blur)=\"onblur($event)\" (keydown)=\"keyDown($event)\"\r\n (keyup)=\"handleLine($event)\">\r\n </textarea>\r\n <div class=\"btn-send\" (click)=\"sendTextMessage()\">\r\n <button nzTooltipTitle=\"\u6309Enter\u53D1\u9001\u6D88\u606F\uFF0CCtrl+Enter\u6362\u884C\" nzTooltipPlacement=\"left\" nz-button\r\n nz-tooltip class=\"tim-icon-send\">\u53D1\u9001</button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #contentTemplate>\r\n <div class=\"emojis\" [ngStyle]=\"{'width': '400px'}\">\r\n <div *ngFor=\"let item of emojiName\" class=\"emoji\" (click)=\"chooseEmoji(item)\">\r\n <img [src]=\"emojiUrl + emojiMap[item]\" style=\"width:30px;height:30px\" />\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".message-send-box-wrapper{box-sizing:border-box;overflow:hidden;padding:3px 20px 20px}.emojis{height:160px;box-sizing:border-box;display:flex;flex-direction:row;flex-wrap:wrap;overflow-y:scroll}.emoji{height:40px;width:40px;box-sizing:border-box}.send-header-bar{box-sizing:border-box;padding:3px 0 0}.send-header-bar i{cursor:pointer;font-size:24px;color:gray;margin:0 12px 0 0}.send-header-bar i:hover{color:#000}textarea{resize:none}.text-input{font-size:16px;width:100%;box-sizing:box-sizing;border:none;outline:none;background-color:transparent}.block{padding:10px 0;display:flex;align-items:center}.bottom{padding-top:10px;position:relative}.bottom .btn-send{cursor:pointer;position:absolute;color:#2d8cf0;font-size:30px;right:0;bottom:-5px;padding:6px 6px 4px 4px;border-radius:50%}.white-background{background-color:#fff}\n"], components: [{ type: i4.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { type: i7.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { type: i8.NzPopoverDirective, selector: "[nz-popover]", inputs: ["nzPopoverArrowPointAtCenter", "nzPopoverTitle", "nzPopoverContent", "nz-popover", "nzPopoverTrigger", "nzPopoverPlacement", "nzPopoverOrigin", "nzPopoverVisible", "nzPopoverMouseEnterDelay", "nzPopoverMouseLeaveDelay", "nzPopoverOverlayClassName", "nzPopoverOverlayStyle", "nzPopoverBackdrop"], outputs: ["nzPopoverVisibleChange"], exportAs: ["nzPopover"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }, { type: i11.NzTooltipDirective, selector: "[nz-tooltip]", inputs: ["nzTooltipTitle", "nzTooltipTitleContext", "nz-tooltip", "nzTooltipTrigger", "nzTooltipPlacement", "nzTooltipOrigin", "nzTooltipVisible", "nzTooltipMouseEnterDelay", "nzTooltipMouseLeaveDelay", "nzTooltipOverlayClassName", "nzTooltipOverlayStyle", "nzTooltipArrowPointAtCenter", "nzTooltipColor"], outputs: ["nzTooltipVisibleChange"], exportAs: ["nzTooltip"] }, { type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: MessageSendBoxComponent, decorators: [{ type: Component, args: [{ selector: 'app-message-send-box', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"message-send-box-wrapper\" [ngClass]=\"{'white-background': focus}\"\r\n (focus)=\"onfocus($event)\">\r\n <div class=\"send-header-bar\">\r\n\r\n <input type=\"file\" #imagePicker accept=\".jpg, .jpeg, .png, .gif\" (change)=\"sendImage($event)\"\r\n (click)=\"$event.stopPropagation()\" style=\"display:none\" />\r\n\r\n <input type=\"file\" #filePicker (change)=\"sendFile($event)\" (click)=\"$event.stopPropagation()\"\r\n style=\"display:none\" />\r\n\r\n <i nz-icon nzType=\"meh\" nzTheme=\"outline\" title=\"\u53D1\u8868\u60C5\" nz-popover nzPopoverTitle=\"Title\"\r\n [(nzPopoverVisible)]=\"visible\" nzPopoverTrigger=\"click\" [nzPopoverContent]=\"contentTemplate\"\r\n [nzPopoverTitle]=\"'\u8868\u60C5'\"></i>\r\n\r\n <i nz-icon nzType=\"picture\" nzTheme=\"outline\" title=\"\u53D1\u56FE\u7247\"\r\n (click)=\"handleSendImageClick(imagePicker,$event)\"></i>\r\n\r\n <i nz-icon nzType=\"folder\" nzTheme=\"outline\" title=\"\u53D1\u6587\u4EF6\"\r\n (click)=\"handleSendFileClick(filePicker)\"></i>\r\n\r\n </div>\r\n <div class=\"bottom\">\r\n <textarea rows=\"4\" resize=\"false\" class=\"text-input\" #textInput [(ngModel)]=\"messageContent\"\r\n (focus)=\"onfocus($event)\" (blur)=\"onblur($event)\" (keydown)=\"keyDown($event)\"\r\n (keyup)=\"handleLine($event)\">\r\n </textarea>\r\n <div class=\"btn-send\" (click)=\"sendTextMessage()\">\r\n <button nzTooltipTitle=\"\u6309Enter\u53D1\u9001\u6D88\u606F\uFF0CCtrl+Enter\u6362\u884C\" nzTooltipPlacement=\"left\" nz-button\r\n nz-tooltip class=\"tim-icon-send\">\u53D1\u9001</button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #contentTemplate>\r\n <div class=\"emojis\" [ngStyle]=\"{'width': '400px'}\">\r\n <div *ngFor=\"let item of emojiName\" class=\"emoji\" (click)=\"chooseEmoji(item)\">\r\n <img [src]=\"emojiUrl + emojiMap[item]\" style=\"width:30px;height:30px\" />\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".message-send-box-wrapper{box-sizing:border-box;overflow:hidden;padding:3px 20px 20px}.emojis{height:160px;box-sizing:border-box;display:flex;flex-direction:row;flex-wrap:wrap;overflow-y:scroll}.emoji{height:40px;width:40px;box-sizing:border-box}.send-header-bar{box-sizing:border-box;padding:3px 0 0}.send-header-bar i{cursor:pointer;font-size:24px;color:gray;margin:0 12px 0 0}.send-header-bar i:hover{color:#000}textarea{resize:none}.text-input{font-size:16px;width:100%;box-sizing:box-sizing;border:none;outline:none;background-color:transparent}.block{padding:10px 0;display:flex;align-items:center}.bottom{padding-top:10px;position:relative}.bottom .btn-send{cursor:pointer;position:absolute;color:#2d8cf0;font-size:30px;right:0;bottom:-5px;padding:6px 6px 4px 4px;border-radius:50%}.white-background{background-color:#fff}\n"] }] }], ctorParameters: function () { return [{ type: i1.Store }, { type: i0.ChangeDetectorRef }, { type: i2.TimHelperService }, { type: i3.ReEditMessageService }]; }, propDecorators: { imagePicker: [{ type: ViewChild, args: ['imagePicker', { static: false }] }], filePicker: [{ type: ViewChild, args: ['filePicker', { static: false }] }], textInput: [{ type: ViewChild, args: ['textInput', { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-send-box.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-tencent-im/src/message/message-send-box/message-send-box.component.ts","../../../../../projects/ngx-tencent-im/src/message/message-send-box/message-send-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { Store } from '@ngrx/store';\r\nimport { ReEditMessageService } from '../../re-edit-message.service';\r\nimport { MESSAGE_STATUS } from '../../shared.data';\r\nimport { pushCurrentMessageListAction, showAction } from '../../store/actions';\r\nimport { currentConversationSelector } from '../../store/selectors';\r\n\r\nimport { TimHelperService } from '../../tim-helper.service';\r\nimport { emojiMap, emojiName, emojiUrl } from '../../util/emoji-map';\r\n\r\n@Component({\r\n  selector: 'app-message-send-box',\r\n  templateUrl: './message-send-box.component.html',\r\n  styleUrls: ['./message-send-box.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class MessageSendBoxComponent implements OnInit, OnDestroy {\r\n  active: boolean;\r\n  visible = false;\r\n  emojiName = emojiName;\r\n  emojiUrl = emojiUrl;\r\n  emojiMap = emojiMap;\r\n  focus = false;\r\n  // 消息内容\r\n  messageContent = '';\r\n\r\n  toAccount: any;\r\n  currentConversationType: any;\r\n  currentConversation: any;\r\n\r\n  @ViewChild('imagePicker', { static: false }) imagePicker: ElementRef;\r\n  @ViewChild('filePicker', { static: false }) filePicker: ElementRef;\r\n  @ViewChild('textInput', { static: true }) textInput: ElementRef;\r\n  constructor(\r\n    private store: Store,\r\n    private cd: ChangeDetectorRef,\r\n    private timHelperService: TimHelperService,\r\n    private reEditMessage: ReEditMessageService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.store.select(currentConversationSelector).subscribe(currentConversation => {\r\n      this.currentConversation = currentConversation;\r\n      if (!currentConversation || !currentConversation.conversationID) {\r\n        this.toAccount = '';\r\n      } else {\r\n        switch (currentConversation.type) {\r\n          case 'C2C':\r\n            this.toAccount = currentConversation.conversationID.replace('C2C', '');\r\n            break;\r\n          case 'GROUP':\r\n            this.toAccount = currentConversation.conversationID.replace('GROUP', '');\r\n            break;\r\n          default:\r\n            this.toAccount = currentConversation.conversationID;\r\n        }\r\n      }\r\n\r\n      if (!currentConversation || !currentConversation.type) {\r\n        this.currentConversationType = '';\r\n      } else {\r\n        this.currentConversationType = currentConversation.type;\r\n      }\r\n    });\r\n    this.textInput.nativeElement.addEventListener('paste', this.handlePaste.bind(this));\r\n\r\n    this.reEditMessage.reEditMessage.subscribe((payload) => {\r\n      this.messageContent = payload;\r\n      this.cd.markForCheck();\r\n    });\r\n  }\r\n\r\n  onfocus(event: Event) {\r\n    console.log('onfocus');\r\n    this.focus = true;\r\n    console.log(this.currentConversation);\r\n    this.timHelperService.checkoutConversation(this.currentConversation.conversationID);\r\n  }\r\n\r\n  onblur(event: Event) {\r\n    console.log('onblur');\r\n    this.focus = false;\r\n  }\r\n\r\n  handleEnter(event: KeyboardEvent) {\r\n    this.sendTextMessage();\r\n  }\r\n  handleLine(event: KeyboardEvent) {\r\n    event.preventDefault();\r\n    if (event.ctrlKey && event.key === 'Enter') {\r\n      this.messageContent += '\\n';\r\n    }\r\n  }\r\n  handleUp(event: KeyboardEvent) {\r\n    console.log('handleUp::', event);\r\n  }\r\n\r\n  handleDown(event: KeyboardEvent) {\r\n    console.log('handleDown::', event);\r\n  }\r\n\r\n  keyDown(event: KeyboardEvent) {\r\n    if (!event.ctrlKey && event.key === 'Enter') {\r\n      event.preventDefault();\r\n      this.handleEnter(event);\r\n    }\r\n    if (event.key === 'ArrowUp') {\r\n      event.stopPropagation();\r\n      this.handleUp(event);\r\n    }\r\n    if (event.key === 'ArrowDown') {\r\n      event.stopPropagation();\r\n      this.handleDown(event);\r\n    }\r\n  }\r\n\r\n  handlePaste(e: any) {\r\n    const clipboardData = e.clipboardData;\r\n    let file: any;\r\n    if (clipboardData && clipboardData.files && clipboardData.files.length > 0) {\r\n      file = clipboardData.files[0];\r\n    }\r\n\r\n    if (typeof file === 'undefined') {\r\n      return;\r\n    }\r\n    // 1. 创建消息实例，接口返回的实例可以上屏\r\n    const message = this.timHelperService.tim.createImageMessage({\r\n      to: this.toAccount,\r\n      conversationType: this.currentConversationType,\r\n      payload: {\r\n        file,\r\n      },\r\n      onProgress: (percent) => {\r\n        message.progress = percent; // 手动给message 实例加个响应式属性: progress\r\n      },\r\n    });\r\n\r\n    // 2. 发送消息\r\n    const promise = this.timHelperService.tim.sendMessage(message).then(res => {\r\n      this.store.dispatch(pushCurrentMessageListAction({ message }));\r\n    });\r\n    promise.catch((error) => {\r\n      console.error('[sendMessage error]::', error);\r\n    });\r\n  }\r\n\r\n  sendImage(event: any) {\r\n    console.log('sendImage');\r\n    const message = this.timHelperService.tim.createImageMessage({\r\n      to: this.toAccount,\r\n      conversationType: this.currentConversationType,\r\n      payload: {\r\n        file: this.imagePicker.nativeElement // 或者用event.target\r\n      },\r\n      onProgress: (percent) => {\r\n        // 手动给message 实例加个响应式属性: progress\r\n        message.progress = percent;\r\n        console.log('percent:', percent);\r\n      }\r\n    });\r\n\r\n    this.timHelperService.tim\r\n      .sendMessage(message)\r\n      .then(({ data }) => {\r\n        console.log('发送成功', data);\r\n        this.store.dispatch(pushCurrentMessageListAction({ message: Object.assign({}, data.message) }));\r\n        this.imagePicker.nativeElement.value = null;\r\n      })\r\n      .catch(imError => {\r\n        console.error('imError::', imError);\r\n      });\r\n  }\r\n\r\n  sendFile(event: any) {\r\n    const message = this.timHelperService.tim.createFileMessage({\r\n      to: this.toAccount,\r\n      conversationType: this.currentConversationType,\r\n      payload: {\r\n        file: document.getElementById('filePicker'), // 或者用event.target\r\n      },\r\n      onProgress: (percent) => {\r\n        message.progress = percent;\r\n        console.log('上传进度', percent);\r\n      },\r\n    });\r\n\r\n    this.timHelperService.tim\r\n      .sendMessage(message)\r\n      .then(({ data }) => {\r\n        this.store.dispatch(pushCurrentMessageListAction({ message: Object.assign({}, data.message) }));\r\n\r\n        this.filePicker.nativeElement.value = null;\r\n      })\r\n      .catch((imError) => {\r\n        console.error('imError::', imError);\r\n\r\n      });\r\n  }\r\n\r\n  chooseEmoji(item: string) {\r\n    console.log(item);\r\n    this.messageContent += item;\r\n  }\r\n\r\n  sendTextMessage() {\r\n    if (\r\n      this.messageContent === '' ||\r\n      this.messageContent.trim().length === 0\r\n    ) {\r\n      this.messageContent = '';\r\n      this.store.dispatch(showAction({ msgType: MESSAGE_STATUS.warning, message: '不能发送空消息哦！' }));\r\n      return;\r\n    }\r\n    const message = this.timHelperService.tim.createTextMessage({\r\n      to: this.toAccount,\r\n      conversationType: this.currentConversationType,\r\n      payload: { text: this.messageContent }\r\n    });\r\n    this.store.dispatch(pushCurrentMessageListAction({ message }));\r\n    this.timHelperService.eventBus$.next('scroll-bottom');\r\n    this.timHelperService.tim.sendMessage(message).catch(error => {\r\n      console.error('[sendMessage error]::', error);\r\n    });\r\n\r\n    this.messageContent = '';\r\n\r\n  }\r\n\r\n  handleSendImageClick(input: HTMLInputElement, event: Event) {\r\n    event.stopPropagation();\r\n\r\n    input.click();\r\n  }\r\n\r\n  handleSendFileClick(input: HTMLInputElement) {\r\n    input.click();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.textInput.nativeElement.addEventListener('paste', this.handlePaste.bind(this));\r\n  }\r\n\r\n}\r\n","<div class=\"message-send-box-wrapper\" [ngClass]=\"{'white-background': focus}\"\r\n  (focus)=\"onfocus($event)\">\r\n  <div class=\"send-header-bar\">\r\n\r\n    <input type=\"file\" #imagePicker accept=\".jpg, .jpeg, .png, .gif\" (change)=\"sendImage($event)\"\r\n      (click)=\"$event.stopPropagation()\" style=\"display:none\" />\r\n\r\n    <input type=\"file\" #filePicker (change)=\"sendFile($event)\" (click)=\"$event.stopPropagation()\"\r\n      style=\"display:none\" />\r\n\r\n    <i nz-icon nzType=\"meh\" nzTheme=\"outline\" title=\"发表情\" nz-popover nzPopoverTitle=\"Title\"\r\n      [(nzPopoverVisible)]=\"visible\" nzPopoverTrigger=\"click\" [nzPopoverContent]=\"contentTemplate\"\r\n      [nzPopoverTitle]=\"'表情'\"></i>\r\n\r\n    <i nz-icon nzType=\"picture\" nzTheme=\"outline\" title=\"发图片\"\r\n      (click)=\"handleSendImageClick(imagePicker,$event)\"></i>\r\n\r\n    <i nz-icon nzType=\"folder\" nzTheme=\"outline\" title=\"发文件\"\r\n      (click)=\"handleSendFileClick(filePicker)\"></i>\r\n\r\n  </div>\r\n  <div class=\"bottom\">\r\n    <textarea rows=\"4\" resize=\"false\" class=\"text-input\" #textInput [(ngModel)]=\"messageContent\"\r\n      (focus)=\"onfocus($event)\" (blur)=\"onblur($event)\" (keydown)=\"keyDown($event)\"\r\n      (keyup)=\"handleLine($event)\">\r\n    </textarea>\r\n    <div class=\"btn-send\" (click)=\"sendTextMessage()\">\r\n      <button nzTooltipTitle=\"按Enter发送消息，Ctrl+Enter换行\" nzTooltipPlacement=\"left\" nz-button\r\n        nz-tooltip class=\"tim-icon-send\">发送</button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #contentTemplate>\r\n  <div class=\"emojis\" [ngStyle]=\"{'width': '400px'}\">\r\n    <div *ngFor=\"let item of emojiName\" class=\"emoji\" (click)=\"chooseEmoji(item)\">\r\n      <img [src]=\"emojiUrl + emojiMap[item]\" style=\"width:30px;height:30px\" />\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}