장문번역 기능 추가.

This commit is contained in:
leejinho 2019-12-31 16:10:24 +09:00
parent 0825f45b17
commit d08c7058bb
7 changed files with 141 additions and 115 deletions

View File

@ -101,10 +101,16 @@
(click)="onClickReceiveAlarm()" (click)="onClickReceiveAlarm()"
aria-label="Toggle Receive Alarm" aria-label="Toggle Receive Alarm"
> >
<mat-icon class="amber-fg" *ngIf="roomInfo.receiveAlarm" <mat-icon
class="amber-fg"
*ngIf="roomInfo.receiveAlarm"
matTooltip="알림 켜짐"
>notifications_active</mat-icon >notifications_active</mat-icon
> >
<mat-icon class="secondary-text" *ngIf="!roomInfo.receiveAlarm" <mat-icon
class="secondary-text"
*ngIf="!roomInfo.receiveAlarm"
matTooltip="알림 꺼짐"
>notifications_off</mat-icon >notifications_off</mat-icon
> >
</button> </button>

View File

@ -36,7 +36,8 @@ import {
FileEventJson, FileEventJson,
StickerEventJson, StickerEventJson,
MassTextEventJson, MassTextEventJson,
TranslationEventJson TranslationEventJson,
MassTranslationEventJson
} from '@ucap-webmessenger/protocol-event'; } from '@ucap-webmessenger/protocol-event';
import * as AppStore from '@app/store'; import * as AppStore from '@app/store';
@ -75,7 +76,8 @@ import {
FileTalkSaveRequest, FileTalkSaveRequest,
FileTalkSaveResponse, FileTalkSaveResponse,
TranslationReqRequest, TranslationReqRequest,
TranslationSaveRequest TranslationSaveRequest,
TranslationSaveResponse
} from '@ucap-webmessenger/api-common'; } from '@ucap-webmessenger/api-common';
import { import {
CreateChatDialogComponent, CreateChatDialogComponent,
@ -174,7 +176,10 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
translationSimpleview = false; translationSimpleview = false;
translationPreview = false; translationPreview = false;
destLocale = 'en'; // default English :: en destLocale = 'en'; // default English :: en
translationPreviewInfo: TranslationEventJson | null; translationPreviewInfo: {
previewInfo: TranslationSaveResponse | null;
translationType: EventType.Translation | EventType.MassTranslation;
};
/** About ReadHere */ /** About ReadHere */
firstcheckReadHere = true; firstcheckReadHere = true;
@ -620,8 +625,6 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
if (!!this.isShowTranslation && this.destLocale.trim().length > 0) { if (!!this.isShowTranslation && this.destLocale.trim().length > 0) {
/** CASE : Translation */ /** CASE : Translation */
console.log('번역들어간다.');
const destLocale = this.destLocale; const destLocale = this.destLocale;
const original = message; const original = message;
const roomSeq = this.roomInfo.roomSeq; const roomSeq = this.roomInfo.roomSeq;
@ -638,13 +641,21 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
.pipe( .pipe(
take(1), take(1),
map(res => { map(res => {
console.log(res);
if (res.statusCode === StatusCode.Success) { if (res.statusCode === StatusCode.Success) {
let sentMessage = '';
let eventType = EventType.Translation;
let previewObject:
| TranslationEventJson
| MassTranslationEventJson;
if (res.translationSeq > 0) { if (res.translationSeq > 0) {
// Mass Text Translation // Mass Text Translation
previewObject = res;
sentMessage = res.returnJson;
eventType = EventType.MassTranslation;
} else { } else {
// Normal Text Translation // Normal Text Translation
const json: TranslationEventJson = { previewObject = {
locale: destLocale, locale: destLocale,
original, original,
translation: res.translation, translation: res.translation,
@ -654,32 +665,38 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
: '' : ''
}; };
if (!!this.translationPreview) { sentMessage = JSON.stringify(previewObject);
// preview eventType = EventType.Translation;
this.translationPreviewInfo = json; }
} else {
// direct send
this.store.dispatch(
EventStore.send({
senderSeq: this.loginRes.userSeq,
req: {
roomSeq,
eventType: EventType.Translation,
sentMessage: JSON.stringify(json)
}
})
);
if (!!this.translationPreviewInfo) { if (!!this.translationPreview) {
this.translationPreviewInfo = null; // preview
} this.translationPreviewInfo = {
} previewInfo: res,
translationType: eventType
};
} else {
// direct send
this.store.dispatch(
EventStore.send({
senderSeq: this.loginRes.userSeq,
req: {
roomSeq,
eventType,
sentMessage
}
})
);
if (!!this.selectedSticker) { if (!!this.translationPreviewInfo) {
this.isShowStickerSelector = false; this.translationPreviewInfo = null;
this.setStickerHistory(this.selectedSticker);
} }
} }
if (!!this.selectedSticker) {
this.isShowStickerSelector = false;
this.setStickerHistory(this.selectedSticker);
}
} else { } else {
this.logger.error(res); this.logger.error(res);
} }
@ -1470,14 +1487,32 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
onCancelTranslation() { onCancelTranslation() {
this.translationPreviewInfo = null; this.translationPreviewInfo = null;
} }
onSendTranslationMessage(translationInfo: TranslationEventJson) { onSendTranslationMessage(params: {
previewInfo: TranslationSaveResponse | null;
translationType: EventType.Translation | EventType.MassTranslation;
}) {
let sentMessage = '';
if (params.translationType === EventType.MassTranslation) {
// Mass Text Translation
sentMessage = params.previewInfo.returnJson;
} else {
// Normal Text Translation
sentMessage = JSON.stringify({
locale: params.previewInfo.destLocale,
original: params.previewInfo.original,
translation: params.previewInfo.translation,
stickername: '',
stickerfile: !!this.selectedSticker ? this.selectedSticker.index : ''
});
}
this.store.dispatch( this.store.dispatch(
EventStore.send({ EventStore.send({
senderSeq: this.loginRes.userSeq, senderSeq: this.loginRes.userSeq,
req: { req: {
roomSeq: this.roomInfo.roomSeq, roomSeq: this.roomInfo.roomSeq,
eventType: EventType.Translation, eventType: params.translationType,
sentMessage: JSON.stringify(translationInfo) sentMessage
} }
}) })
); );

View File

@ -1,23 +1,26 @@
<div class="translation-main"> <div class="translation-main">
<div class="original"> <div
{{ message.sentMessageJson.translation }} *ngIf="!translationSimpleview || (!!translationSimpleview && !!isMe)"
</div> class="original"
<div class="translation"> [innerHTML]="message.sentMessageJson.original | linky"
<span class="language">Kor</span> ></div>
녕하세요 장문장문 롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 <div
롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 *ngIf="!translationSimpleview || (!!translationSimpleview && !isMe)"
장문장문 롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 class="translation"
롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 >
장문장문 롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 <span class="language">{{ message.sentMessageJson.destLocale }}</span>
롱텍스트안녕하세요 장문장문 롱텍스트안녕하세요 장문장문 롱텍스트 <span [innerHTML]="message.sentMessageJson.translation | linky"> </span>
</div> </div>
<div class="btn-box"> <div class="btn-box">
<ul> <ul>
<li> <li>
<button mat-button>Save</button> <button mat-button>전체보기</button>
</li> </li>
<li> <li>
<button mat-button><span class="language">Kor</span>번역보기</button> <button mat-button>
<span class="language">{{ message.sentMessageJson.destLocale }}</span
>번역보기
</button>
</li> </li>
</ul> </ul>
</div> </div>

View File

@ -1,5 +1,9 @@
import { Component, OnInit, Input } from '@angular/core'; import { Component, OnInit, Input } from '@angular/core';
import { TranslationEventJson, Info } from '@ucap-webmessenger/protocol-event'; import {
TranslationEventJson,
Info,
MassTranslationEventJson
} from '@ucap-webmessenger/protocol-event';
@Component({ @Component({
selector: 'ucap-chat-message-box-mass-translation', selector: 'ucap-chat-message-box-mass-translation',
@ -8,7 +12,13 @@ import { TranslationEventJson, Info } from '@ucap-webmessenger/protocol-event';
}) })
export class MassTranslationComponent implements OnInit { export class MassTranslationComponent implements OnInit {
@Input() @Input()
message: Info<TranslationEventJson>; message: Info<MassTranslationEventJson>;
@Input()
translationSimpleview: boolean;
@Input()
isMe: boolean;
constructor() {} constructor() {}

View File

@ -131,14 +131,14 @@
*ngIf="getUserProfile(message.senderSeq) != ''" *ngIf="getUserProfile(message.senderSeq) != ''"
class="profile-img thumbnail-mask" class="profile-img thumbnail-mask"
> >
<img <img
class="avatar" class="avatar"
ucapImage ucapImage
[base]="profileImageRoot" [base]="profileImageRoot"
[path]="getUserProfile(message.senderSeq)" [path]="getUserProfile(message.senderSeq)"
[default]="'assets/images/img_nophoto_50.png'" [default]="'assets/images/img_nophoto_50.png'"
(click)="onClickOpenProfile($event, getUerInfo(message.senderSeq))" (click)="onClickOpenProfile($event, getUerInfo(message.senderSeq))"
/> />
<!-- <ucap-ui-imaage <!-- <ucap-ui-imaage
[style]="'width: 50px; height: 50px;'" [style]="'width: 50px; height: 50px;'"
[imageClass]="'avatar'" [imageClass]="'avatar'"
@ -203,6 +203,14 @@
[isMe]="message.senderSeq === loginRes.userSeq" [isMe]="message.senderSeq === loginRes.userSeq"
class="information-msg" class="information-msg"
></ucap-chat-message-box-translation> ></ucap-chat-message-box-translation>
<ucap-chat-message-box-mass-translation
*ngSwitchCase="EventType.MassTranslation"
[message]="message"
[translationSimpleview]="translationSimpleview"
[isMe]="message.senderSeq === loginRes.userSeq"
class="information-msg"
>
</ucap-chat-message-box-mass-translation>
<ucap-chat-message-box-allim <ucap-chat-message-box-allim
*ngSwitchCase="EventType.AllimTms" *ngSwitchCase="EventType.AllimTms"
@ -218,8 +226,7 @@
</ucap-chat-message-box-allim> </ucap-chat-message-box-allim>
<div *ngSwitchDefault> <div *ngSwitchDefault>
<!-- mass-translation <!--
<ucap-chat-message-box-mass-translation></ucap-chat-message-box-mass-translation>
notice notice
<ucap-chat-message-box-notice></ucap-chat-message-box-notice> <ucap-chat-message-box-notice></ucap-chat-message-box-notice>
video-conference video-conference

View File

@ -2,12 +2,13 @@
*ngIf=" *ngIf="
isShowTranslationPreview && isShowTranslationPreview &&
!!translationPreviewInfo && !!translationPreviewInfo &&
!!translationPreviewInfo.translation !!translationPreviewInfo.previewInfo &&
!!translationPreviewInfo.previewInfo.translation
" "
class="translation-preview" class="translation-preview"
> >
<span class="translation-section"> <span class="translation-section">
{{ translationPreviewInfo.translation }} {{ translationPreviewInfo.previewInfo.translation }}
</span> </span>
<button <button
@ -56,53 +57,3 @@
> >
</form> </form>
</div> </div>
<!-- <div *ngIf="currentSticker" class="selected-sticker">
<img [src]="getStickerContentsImage(currentSticker)" />
<span class="btn-close">
<button
mat-button
matSuffix
mat-icon-button
aria-label="Close"
(click)="onClickClose()"
>
<mat-icon>close</mat-icon>
</button>
</span>
</div>
<div class="sticker-selector">
<mat-tab-group
mat-stretch-tabs
animationDuration="0ms"
(selectedIndexChange)="onSelectedIndexChange($event)"
>
<mat-tab
*ngFor="let stickerInfo of stickerInfoList; let idx = index"
[aria-label]="stickerInfo.title"
>
<ng-template mat-tab-label>
<img
#stickerTitle
[matTooltip]="stickerInfo.title"
matTooltipPosition="after"
[src]="getStickerTitleImage(stickerInfo, false, idx)"
(mouseover)="
stickerTitle.src = getStickerTitleImage(stickerInfo, true, idx)
"
(mouseout)="
stickerTitle.src = getStickerTitleImage(stickerInfo, false, idx)
"
/>
</ng-template>
<div fxFlex fxLayout="row" fxLayoutGap="20px" class="sticker-item-box">
<div
*ngFor="let sticker of getStickerInfos(stickerInfo)"
(click)="onClickSelectSticker(sticker)"
class="sticker-item"
>
<img [src]="getStickerContentsImage(sticker)" />
</div>
</div>
</mat-tab>
</mat-tab-group>
</div> -->

View File

@ -7,7 +7,12 @@ import {
} from '@ucap-webmessenger/core'; } from '@ucap-webmessenger/core';
import { FormGroup, FormBuilder } from '@angular/forms'; import { FormGroup, FormBuilder } from '@angular/forms';
import { MatSlideToggleChange, MatSelectChange } from '@angular/material'; import { MatSlideToggleChange, MatSelectChange } from '@angular/material';
import { TranslationEventJson } from '@ucap-webmessenger/protocol-event'; import {
TranslationEventJson,
MassTranslationEventJson,
EventType
} from '@ucap-webmessenger/protocol-event';
import { TranslationSaveResponse } from '@ucap-webmessenger/api-common';
@Component({ @Component({
selector: 'ucap-translation-section', selector: 'ucap-translation-section',
@ -22,7 +27,10 @@ export class TranslationSectionComponent implements OnInit {
@Input() @Input()
preView: boolean; preView: boolean;
@Input() @Input()
translationPreviewInfo: TranslationEventJson | null; translationPreviewInfo: {
previewInfo: TranslationSaveResponse | null;
translationType: EventType.Translation | EventType.MassTranslation;
};
@Output() @Output()
changeTranslationSimpleview = new EventEmitter<boolean>(); changeTranslationSimpleview = new EventEmitter<boolean>();
@ -33,7 +41,10 @@ export class TranslationSectionComponent implements OnInit {
@Output() @Output()
cancelTranslation = new EventEmitter<void>(); cancelTranslation = new EventEmitter<void>();
@Output() @Output()
sendTranslationMessage = new EventEmitter<TranslationEventJson>(); sendTranslationMessage = new EventEmitter<{
previewInfo: TranslationSaveResponse | null;
translationType: EventType.Translation | EventType.MassTranslation;
}>();
isShowTranslationSimpleview = false; isShowTranslationSimpleview = false;
isShowTranslationPreview = false; isShowTranslationPreview = false;
@ -171,7 +182,10 @@ export class TranslationSectionComponent implements OnInit {
this.changeTranslationPreview.emit(event.checked); this.changeTranslationPreview.emit(event.checked);
} }
onClickSendTranslationMessage(translationInfo: TranslationEventJson) { onClickSendTranslationMessage(translationInfo: {
previewInfo: TranslationSaveResponse | null;
translationType: EventType.Translation | EventType.MassTranslation;
}) {
this.sendTranslationMessage.emit(translationInfo); this.sendTranslationMessage.emit(translationInfo);
} }