장문번역 기능 추가.
This commit is contained in:
parent
0825f45b17
commit
d08c7058bb
|
@ -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>
|
||||||
|
|
|
@ -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,9 +665,16 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
|
||||||
: ''
|
: ''
|
||||||
};
|
};
|
||||||
|
|
||||||
|
sentMessage = JSON.stringify(previewObject);
|
||||||
|
eventType = EventType.Translation;
|
||||||
|
}
|
||||||
|
|
||||||
if (!!this.translationPreview) {
|
if (!!this.translationPreview) {
|
||||||
// preview
|
// preview
|
||||||
this.translationPreviewInfo = json;
|
this.translationPreviewInfo = {
|
||||||
|
previewInfo: res,
|
||||||
|
translationType: eventType
|
||||||
|
};
|
||||||
} else {
|
} else {
|
||||||
// direct send
|
// direct send
|
||||||
this.store.dispatch(
|
this.store.dispatch(
|
||||||
|
@ -664,8 +682,8 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
|
||||||
senderSeq: this.loginRes.userSeq,
|
senderSeq: this.loginRes.userSeq,
|
||||||
req: {
|
req: {
|
||||||
roomSeq,
|
roomSeq,
|
||||||
eventType: EventType.Translation,
|
eventType,
|
||||||
sentMessage: JSON.stringify(json)
|
sentMessage
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
@ -679,7 +697,6 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
|
||||||
this.isShowStickerSelector = false;
|
this.isShowStickerSelector = false;
|
||||||
this.setStickerHistory(this.selectedSticker);
|
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
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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() {}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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> -->
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user