This commit is contained in:
richard-loafle 2020-01-30 14:13:00 +09:00
commit 20fa760578
13 changed files with 243 additions and 87 deletions

View File

@ -603,7 +603,10 @@ ipcMain.on(
dialog dialog
.showSaveDialog({ defaultPath: args[0] }) .showSaveDialog({ defaultPath: args[0] })
.then(obj => { .then(obj => {
event.returnValue = obj.filePath; event.returnValue = {
canceled: obj.canceled,
filePath: obj.filePath
};
}) })
.catch(obj => { .catch(obj => {
event.returnValue = undefined; event.returnValue = undefined;

View File

@ -4,7 +4,8 @@ import {
APIJsonEncoder, APIJsonEncoder,
APIDecoder, APIDecoder,
APIFormDataEncoder, APIFormDataEncoder,
ParameterUtil ParameterUtil,
MessageStatusCode
} from '@ucap-webmessenger/api'; } from '@ucap-webmessenger/api';
import { DeviceType } from '@ucap-webmessenger/core'; import { DeviceType } from '@ucap-webmessenger/core';
import { MessageType } from '../types/message.type'; import { MessageType } from '../types/message.type';
@ -82,7 +83,7 @@ export const encodeSend: APIFormDataEncoder<SendRequest> = (
export const decodeSend: APIDecoder<SendResponse> = (res: any) => { export const decodeSend: APIDecoder<SendResponse> = (res: any) => {
return { return {
responseCode: res.responseCode, responseCode: res.responseCode as MessageStatusCode,
responseMsg: res.responseMsg responseMsg: res.responseMsg
} as SendResponse; } as SendResponse;
}; };

View File

@ -168,7 +168,7 @@ export class MessageApiService {
'POST', 'POST',
this.urls.sendNewMessage, this.urls.sendNewMessage,
encodeSend(req), encodeSend(req),
{ reportProgress: true, responseType: 'text' as 'json' } { reportProgress: true }
); );
const progress = req.fileUploadItem.uploadStart(); const progress = req.fileUploadItem.uploadStart();
@ -196,7 +196,7 @@ export class MessageApiService {
'POST', 'POST',
this.urls.editReservationMessageEx, this.urls.editReservationMessageEx,
encodeEditReservation(req), encodeEditReservation(req),
{ reportProgress: true, responseType: 'text' as 'json' } { reportProgress: true }
); );
const progress = req.fileUploadItem.uploadStart(); const progress = req.fileUploadItem.uploadStart();

View File

@ -1,57 +1,20 @@
import { UserSelectDialogType } from '../../../types/userselect.dialog.type';
import { import {
Component, Component,
OnInit, OnInit,
Output,
EventEmitter,
ViewChildren,
QueryList,
ElementRef,
OnDestroy, OnDestroy,
ViewChild
} from '@angular/core'; } from '@angular/core';
import { NGXLogger } from 'ngx-logger'; import { NGXLogger } from 'ngx-logger';
import { ucapAnimations, DialogService } from '@ucap-webmessenger/ui'; import { ucapAnimations } from '@ucap-webmessenger/ui';
import { import { Subscription, Observable, } from 'rxjs';
CreateChatDialogComponent,
CreateChatDialogData,
CreateChatDialogResult
} from '@app/layouts/messenger/dialogs/chat/create-chat.dialog.component';
import { Subscription, Observable, merge } from 'rxjs';
import { Store, select } from '@ngrx/store'; import { Store, select } from '@ngrx/store';
import * as AppStore from '@app/store'; import * as AppStore from '@app/store';
import * as ChatStore from '@app/store/messenger/chat';
import * as MessageStore from '@app/store/messenger/message'; import * as MessageStore from '@app/store/messenger/message';
import * as SyncStore from '@app/store/messenger/sync';
import * as SettingsStore from '@app/store/messenger/settings'; import * as SettingsStore from '@app/store/messenger/settings';
import { UserInfo } from '@ucap-webmessenger/protocol-sync';
import {
UserInfoSS,
UserInfoF,
UserInfoDN
} from '@ucap-webmessenger/protocol-query';
import { MatTabChangeEvent } from '@angular/material'; import { MatTabChangeEvent } from '@angular/material';
import { LoginResponse } from '@ucap-webmessenger/protocol-authentication';
import { OpenProfileOptions } from '@ucap-webmessenger/protocol-buddy';
import { SessionStorageService } from '@ucap-webmessenger/web-storage';
import { VersionInfo2Response } from '@ucap-webmessenger/api-public';
import { MessageType } from '@ucap-webmessenger/api-message';
import { tap } from 'rxjs/operators';
import { import {
MessageWriteDialogComponent,
MessageWriteDialogResult,
MessageWriteDialogData
} from '../dialogs/message/message-write.dialog.component';
import {
EnvironmentsInfo,
KEY_ENVIRONMENTS_INFO,
KEY_VER_INFO,
MainMenu MainMenu
} from '@app/types'; } from '@app/types';
import { MessageBoxComponent } from './left-sidenav/message.component';
import { environment } from '../../../../environments/environment';
import { TranslateService } from '@ngx-translate/core';
@Component({ @Component({
selector: 'app-layout-messenger-left-nav', selector: 'app-layout-messenger-left-nav',

View File

@ -918,15 +918,19 @@ export class MessagesComponent implements OnInit, OnDestroy, AfterViewInit {
this.nativeService this.nativeService
.selectSaveFilePath(value.fileInfo.fileName) .selectSaveFilePath(value.fileInfo.fileName)
.then(result => { .then(result => {
if (!!result && result.length > 0) { if (!!result && result.filePath.length > 0) {
this.saveFile(value, result); this.saveFile(value, result.filePath);
} else { } else {
this.snackBarService.open( if (!!result && result.canceled) {
this.translateService.instant( // ignore..
'common.file.errors.failToSpecifyPath' } else {
), this.snackBarService.open(
this.translateService.instant('common.file.errors.label') this.translateService.instant(
); 'common.file.errors.failToSpecifyPath'
),
this.translateService.instant('common.file.errors.label')
);
}
} }
}) })
.catch(reason => { .catch(reason => {

View File

@ -1,7 +1,13 @@
import { Component, OnInit, Inject, ViewChild } from '@angular/core'; import { Component, OnInit, Inject, ViewChild } from '@angular/core';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material'; import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
import { DialogService, SnackBarService } from '@ucap-webmessenger/ui'; import {
DialogService,
SnackBarService,
AlertDialogComponent,
AlertDialogResult,
AlertDialogData
} from '@ucap-webmessenger/ui';
import { import {
DetailResponse, DetailResponse,
@ -32,13 +38,14 @@ import {
EnvironmentsInfo, EnvironmentsInfo,
KEY_VER_INFO KEY_VER_INFO
} from '@app/types'; } from '@app/types';
import { take } from 'rxjs/operators'; import { take, tap } from 'rxjs/operators';
import { UserInfoSS } from '@ucap-webmessenger/protocol-query'; import { UserInfoSS } from '@ucap-webmessenger/protocol-query';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import { VersionInfo2Response } from '@ucap-webmessenger/api-public'; import { VersionInfo2Response } from '@ucap-webmessenger/api-public';
import { SessionStorageService } from '@ucap-webmessenger/web-storage'; import { SessionStorageService } from '@ucap-webmessenger/web-storage';
import { environment } from '../../../../../environments/environment'; import { environment } from '../../../../../environments/environment';
import { EmployeeType } from '@ucap-webmessenger/protocol-room'; import { EmployeeType } from '@ucap-webmessenger/protocol-room';
import { MessageStatusCode } from '@ucap-webmessenger/api';
export interface MessageWriteDialogData { export interface MessageWriteDialogData {
loginRes: LoginResponse; loginRes: LoginResponse;
@ -155,23 +162,93 @@ export class MessageWriteDialogComponent implements OnInit {
.pipe(take(1)) .pipe(take(1))
.subscribe( .subscribe(
res => { res => {
let msg = ''; if (!!res && res.responseCode === MessageStatusCode.Success) {
if (!!message.reservationTime) { let msg = '';
msg = this.translateService.instant( if (!!message.reservationTime) {
'message.results.successForReservation' msg = this.translateService.instant(
); 'message.results.successForReservation'
);
} else {
msg = this.translateService.instant(
'message.results.successForSending'
);
}
this.snackBarService.open(msg, '', {
duration: 3000,
verticalPosition: 'bottom'
});
this.dialogRef.close({ sendFlag: true, sendType: message.type });
} else { } else {
msg = this.translateService.instant( let alertType = 'S';
'message.results.successForSending' let errorMsg =
); this.translateService.instant('message.errors.failToSending') +
`(${res.responseCode})`;
switch (res.responseCode) {
case MessageStatusCode.Fail_Msg_Reservation_Time_Null:
errorMsg = this.translateService.instant(
'message.errors.failToReservationTimeEmpty'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Title_length:
errorMsg = this.translateService.instant(
'message.errors.failToTitleLength'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Reservation_Time_Less:
case MessageStatusCode.Fail_Msg_Edit_Reservation_Time_Less:
errorMsg = this.translateService.instant(
'message.errors.failToReservationTimeLess'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Edit_Cancel_Reservation_Sended:
errorMsg = this.translateService.instant(
'message.errors.failToReservationSended'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_File_Size:
errorMsg = this.translateService.instant(
'message.errors.failToFileSize'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_File_Ext:
errorMsg = this.translateService.instant(
'message.errors.failToFileExt'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Cancelled_Msg:
errorMsg = this.translateService.instant(
'message.errors.failToCancelled'
);
alertType = 'A';
break;
}
if (alertType === 'S') {
this.snackBarService.open(errorMsg, '', {
duration: 3000,
verticalPosition: 'bottom'
});
} else {
this.dialogService.open<
AlertDialogComponent,
AlertDialogData,
AlertDialogResult
>(AlertDialogComponent, {
data: {
title: this.translateService.instant('message.errors.label'),
message: errorMsg
}
});
}
} }
this.snackBarService.open(msg, '', {
duration: 3000,
verticalPosition: 'bottom'
});
this.dialogRef.close({ sendFlag: true, sendType: message.type });
}, },
error => { error => {
this.snackBarService.open( this.snackBarService.open(
@ -199,18 +276,88 @@ export class MessageWriteDialogComponent implements OnInit {
.pipe(take(1)) .pipe(take(1))
.subscribe( .subscribe(
res => { res => {
this.snackBarService.open( if (!!res && res.responseCode === MessageStatusCode.Success) {
this.translateService.instant( this.snackBarService.open(
'message.results.successForModifying' this.translateService.instant(
), 'message.results.successForModifying'
'', ),
{ '',
duration: 3000, {
verticalPosition: 'bottom' duration: 3000,
} verticalPosition: 'bottom'
); }
);
this.dialogRef.close({ sendFlag: true, sendType: message.type }); this.dialogRef.close({ sendFlag: true, sendType: message.type });
} else {
let alertType = 'S';
let errorMsg =
this.translateService.instant('message.errors.failToSending') +
`(${res.responseCode})`;
switch (res.responseCode) {
case MessageStatusCode.Fail_Msg_Reservation_Time_Null:
errorMsg = this.translateService.instant(
'message.errors.failToReservationTimeEmpty'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Title_length:
errorMsg = this.translateService.instant(
'message.errors.failToTitleLength'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Reservation_Time_Less:
case MessageStatusCode.Fail_Msg_Edit_Reservation_Time_Less:
errorMsg = this.translateService.instant(
'message.errors.failToReservationTimeLess'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Msg_Edit_Cancel_Reservation_Sended:
errorMsg = this.translateService.instant(
'message.errors.failToReservationSended'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_File_Size:
errorMsg = this.translateService.instant(
'message.errors.failToFileSize'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_File_Ext:
errorMsg = this.translateService.instant(
'message.errors.failToFileExt'
);
alertType = 'A';
break;
case MessageStatusCode.Fail_Cancelled_Msg:
errorMsg = this.translateService.instant(
'message.errors.failToCancelled'
);
alertType = 'A';
break;
}
if (alertType === 'S') {
this.snackBarService.open(errorMsg, '', {
duration: 3000,
verticalPosition: 'bottom'
});
} else {
this.dialogService.open<
AlertDialogComponent,
AlertDialogData,
AlertDialogResult
>(AlertDialogComponent, {
data: {
title: this.translateService.instant('message.errors.label'),
message: errorMsg
}
});
}
}
}, },
error => { error => {
this.snackBarService.open( this.snackBarService.open(

View File

@ -149,7 +149,10 @@
</svg> </svg>
</button> </button>
</div> </div>
<span *ngIf="(!!weblink && weblink.length > 0) || (updateInfo$ | async)" class="stroke-bar"></span> <span
*ngIf="(!!weblink && weblink.length > 0) || (updateInfo$ | async)"
class="stroke-bar"
></span>
<ucap-profile-my-profile-widget <ucap-profile-my-profile-widget
[profileImageRoot]="sessionVerinfo.profileRoot" [profileImageRoot]="sessionVerinfo.profileRoot"
[profileImageFile]="getMyProfileImageWidget()" [profileImageFile]="getMyProfileImageWidget()"

View File

@ -327,6 +327,13 @@
"label": "Message error", "label": "Message error",
"failToSending": "The message failed to send.", "failToSending": "The message failed to send.",
"failToModify": "The message failed to modify.", "failToModify": "The message failed to modify.",
"failToReservationTimeEmpty": "No reservation time is specified.",
"failToTitleLength": "Title is too long",
"failToReservationTimeLess": "Reservation time can not be sent within 10 minutes.",
"failToReservationSended": "You can't edit a message that has already been sent.",
"failToFileSize": "The file you are uploading is larger than the limit.",
"failToFileExt": "The file you uploaded contains restricted files.",
"failToCancelled": "This message has been canceled.",
"minTimeReservation": "It can be set only 30 minutes after the current time.", "minTimeReservation": "It can be set only 30 minutes after the current time.",
"cancelledError": "The message failed to cancel.", "cancelledError": "The message failed to cancel.",
"cancelledMessage": "This message has been cancelled." "cancelledMessage": "This message has been cancelled."

View File

@ -327,6 +327,13 @@
"label": "쪽지 에러", "label": "쪽지 에러",
"failToSending": "쪽지를 전송에 실패 하였습니다.", "failToSending": "쪽지를 전송에 실패 하였습니다.",
"failToModify": "쪽지 수정에 실패 하였습니다.", "failToModify": "쪽지 수정에 실패 하였습니다.",
"failToReservationTimeEmpty": "예약시간이 지정되어 있지 않습니다.",
"failToTitleLength": "제목이 너무 길게 입력되었습니다.",
"failToReservationTimeLess": "예약시간이 현재시간 기준 10분 이내에는 보낼수 없습니다.",
"failToReservationSended": "이미 발송된 메시지는 수정할 수 없습니다.",
"failToFileSize": "업로드 하는 파일의 용량이 제한크기보다 큽니다.",
"failToFileExt": "업로드 하는 파일에 제한된 파일이 포함되었습니다.",
"failToCancelled": "발송 취소된 메시지 입니다.",
"minTimeReservation": "현재 시각으로부터 30분 이후로만 설정 가능합니다.", "minTimeReservation": "현재 시각으로부터 30분 이후로만 설정 가능합니다.",
"cancelledError": "발송 취소에 실패 하였습니다.", "cancelledError": "발송 취소에 실패 하였습니다.",
"cancelledMessage": "발송 취소된 쪽지 입니다." "cancelledMessage": "발송 취소된 쪽지 입니다."

View File

@ -187,9 +187,18 @@ export class BrowserNativeService extends NativeService {
}); });
} }
selectSaveFilePath(defaultPath?: string): Promise<string> { selectSaveFilePath(defaultPath?: string): Promise<{
return new Promise<string>((resolve, reject) => { canceled: boolean,
resolve(''); filePath: string
}> {
return new Promise<{
canceled: boolean,
filePath: string
}>((resolve, reject) => {
resolve({
canceled: false,
filePath: ''
});
}); });
} }

View File

@ -309,8 +309,14 @@ export class ElectronNativeService implements NativeService {
}); });
} }
selectSaveFilePath(defaultPath?: string): Promise<string> { selectSaveFilePath(defaultPath?: string): Promise<{
return new Promise<string>((resolve, reject) => { canceled: boolean,
filePath: string
}> {
return new Promise<{
canceled: boolean,
filePath: string
}>((resolve, reject) => {
try { try {
resolve( resolve(
this.ipcRenderer.sendSync(FileChannel.SelectSaveFilePath, defaultPath) this.ipcRenderer.sendSync(FileChannel.SelectSaveFilePath, defaultPath)

View File

@ -59,7 +59,10 @@ export abstract class NativeService {
abstract openTargetItem(filePath?: string): Promise<boolean>; abstract openTargetItem(filePath?: string): Promise<boolean>;
abstract getPath(name: NativePathName): Promise<string>; abstract getPath(name: NativePathName): Promise<string>;
abstract selectDirectory(): Promise<string>; abstract selectDirectory(): Promise<string>;
abstract selectSaveFilePath(defaultPath?: string): Promise<string>; abstract selectSaveFilePath(defaultPath?: string): Promise<{
canceled: boolean,
filePath: string
}>;
abstract executeProcess(executableName: string): Promise<number>; abstract executeProcess(executableName: string): Promise<number>;

View File

@ -58,9 +58,12 @@
<mat-form-field class="message-title"> <mat-form-field class="message-title">
<input <input
matInput matInput
#inputTitle
formControlName="title" formControlName="title"
placeholder="{{ 'message.fieldTitle' | translate }}" placeholder="{{ 'message.fieldTitle' | translate }}"
maxlength="100"
/> />
<mat-hint align="end">{{ inputTitle.value?.length || 0 }}/100</mat-hint>
</mat-form-field> </mat-form-field>
<div class="message-content"> <div class="message-content">