Merge branch 'master' of http://10.81.13.221:6990/Web/next-ucap-messenger
This commit is contained in:
commit
582b76024b
|
@ -49,7 +49,6 @@ export class LeftSideComponent implements OnInit {
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!!result && !!result.choice && result.choice) {
|
if (!!result && !!result.choice && result.choice) {
|
||||||
this.logger.debug(result.selectedUserList);
|
|
||||||
if (!!result.selectedUserList && result.selectedUserList.length > 0) {
|
if (!!result.selectedUserList && result.selectedUserList.length > 0) {
|
||||||
const userSeqs: number[] = [];
|
const userSeqs: number[] = [];
|
||||||
result.selectedUserList.map(user => userSeqs.push(user.seq));
|
result.selectedUserList.map(user => userSeqs.push(user.seq));
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
|
import { UserSelectDialogType } from './../../../../types/userselect.dialog.type';
|
||||||
|
import {
|
||||||
|
CreateChatDialogComponent,
|
||||||
|
CreateChatDialogData,
|
||||||
|
CreateChatDialogResult
|
||||||
|
} from './../../dialogs/chat/create-chat.dialog.component';
|
||||||
import { Component, OnInit, ViewChild, OnDestroy } from '@angular/core';
|
import { Component, OnInit, ViewChild, OnDestroy } from '@angular/core';
|
||||||
|
|
||||||
import { Observable, combineLatest, Subscription } from 'rxjs';
|
import { Observable, combineLatest, Subscription } from 'rxjs';
|
||||||
|
@ -155,16 +161,29 @@ export class GroupComponent implements OnInit, OnDestroy {
|
||||||
case 'GROUP_NEW':
|
case 'GROUP_NEW':
|
||||||
{
|
{
|
||||||
const result = await this.dialogService.open<
|
const result = await this.dialogService.open<
|
||||||
CreateGroupDialogComponent,
|
CreateChatDialogComponent,
|
||||||
CreateGroupDialogData,
|
CreateChatDialogData,
|
||||||
CreateGroupDialogResult
|
CreateChatDialogResult
|
||||||
>(CreateGroupDialogComponent, {
|
>(CreateChatDialogComponent, {
|
||||||
width: '220px',
|
width: '600px',
|
||||||
|
height: '500px',
|
||||||
data: {
|
data: {
|
||||||
title: 'Logout',
|
type: UserSelectDialogType.NewGroup,
|
||||||
message: 'Logout ?'
|
title: 'New Group'
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (!!result && !!result.choice && result.choice) {
|
||||||
|
this.logger.debug(result);
|
||||||
|
if (
|
||||||
|
!!result.selectedUserList &&
|
||||||
|
result.selectedUserList.length > 0
|
||||||
|
) {
|
||||||
|
// const userSeqs: number[] = [];
|
||||||
|
// result.selectedUserList.map(user => userSeqs.push(user.seq));
|
||||||
|
// this.store.dispatch(ChatStore.openRoom({ userSeqList: userSeqs }));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'GROUP_EXPAND_MORE':
|
case 'GROUP_EXPAND_MORE':
|
||||||
|
|
|
@ -2,7 +2,22 @@
|
||||||
<mat-card-header cdkDrag cdkDragRootElement=".cdk-overlay-pane" cdkDragHandle>
|
<mat-card-header cdkDrag cdkDragRootElement=".cdk-overlay-pane" cdkDragHandle>
|
||||||
<mat-card-title>{{ data.title }}</mat-card-title>
|
<mat-card-title>{{ data.title }}</mat-card-title>
|
||||||
</mat-card-header>
|
</mat-card-header>
|
||||||
<mat-card-content
|
<mat-card-content>
|
||||||
|
<div *ngIf="data.type === UserSelectDialogType.NewGroup">
|
||||||
|
<form name="inputForm" [formGroup]="inputForm" novalidate>
|
||||||
|
<mat-form-field hintLabel="특수문자는 '-,_'만 사용할 수 있습니다.">
|
||||||
|
<input
|
||||||
|
matInput
|
||||||
|
#input
|
||||||
|
maxlength="20"
|
||||||
|
placeholder="그룹이름"
|
||||||
|
formControlName="groupName"
|
||||||
|
/>
|
||||||
|
<mat-hint align="end">{{ input.value?.length || 0 }}/20</mat-hint>
|
||||||
|
</mat-form-field>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
fxLayout
|
fxLayout
|
||||||
fxLayout.xs="column"
|
fxLayout.xs="column"
|
||||||
fxLayoutAlign="center"
|
fxLayoutAlign="center"
|
||||||
|
@ -82,6 +97,7 @@
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
</mat-card-content>
|
</mat-card-content>
|
||||||
<mat-card-actions class="button-farm flex-row">
|
<mat-card-actions class="button-farm flex-row">
|
||||||
<button
|
<button
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { UserSelectDialogType } from './../../../../types/userselect.dialog.type';
|
import { UserSelectDialogType } from './../../../../types/userselect.dialog.type';
|
||||||
import { Component, OnInit, OnDestroy, Inject } from '@angular/core';
|
import { Component, OnInit, OnDestroy, Inject } from '@angular/core';
|
||||||
|
import { FormGroup, FormBuilder, Validators } from '@angular/forms';
|
||||||
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
|
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
|
||||||
import { NGXLogger } from 'ngx-logger';
|
import { NGXLogger } from 'ngx-logger';
|
||||||
import { Observable, combineLatest, Subscription } from 'rxjs';
|
import { Observable, combineLatest, Subscription } from 'rxjs';
|
||||||
|
@ -41,6 +42,7 @@ export interface CreateChatDialogData {
|
||||||
export interface CreateChatDialogResult {
|
export interface CreateChatDialogResult {
|
||||||
choice: boolean;
|
choice: boolean;
|
||||||
selectedUserList?: (UserInfo | UserInfoSS | UserInfoF | UserInfoDN)[];
|
selectedUserList?: (UserInfo | UserInfoSS | UserInfoF | UserInfoDN)[];
|
||||||
|
groupName?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -57,6 +59,7 @@ export class CreateChatDialogComponent implements OnInit, OnDestroy {
|
||||||
@Inject(MAT_DIALOG_DATA) public data: CreateChatDialogData,
|
@Inject(MAT_DIALOG_DATA) public data: CreateChatDialogData,
|
||||||
private store: Store<any>,
|
private store: Store<any>,
|
||||||
private sessionStorageService: SessionStorageService,
|
private sessionStorageService: SessionStorageService,
|
||||||
|
private formBuilder: FormBuilder,
|
||||||
private logger: NGXLogger
|
private logger: NGXLogger
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
|
@ -83,6 +86,8 @@ export class CreateChatDialogComponent implements OnInit, OnDestroy {
|
||||||
// 수집 데이터
|
// 수집 데이터
|
||||||
selectedUserList: (UserInfo | UserInfoSS | UserInfoF | UserInfoDN)[] = [];
|
selectedUserList: (UserInfo | UserInfoSS | UserInfoF | UserInfoDN)[] = [];
|
||||||
|
|
||||||
|
inputForm: FormGroup;
|
||||||
|
|
||||||
ngOnInit() {
|
ngOnInit() {
|
||||||
const loginInfo = this.sessionStorageService.get<LoginInfo>(KEY_LOGIN_INFO);
|
const loginInfo = this.sessionStorageService.get<LoginInfo>(KEY_LOGIN_INFO);
|
||||||
this.companyCode = loginInfo.companyCode;
|
this.companyCode = loginInfo.companyCode;
|
||||||
|
@ -155,6 +160,10 @@ export class CreateChatDialogComponent implements OnInit, OnDestroy {
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
.subscribe();
|
.subscribe();
|
||||||
|
|
||||||
|
this.inputForm = this.formBuilder.group({
|
||||||
|
groupName: ['', [Validators.required]]
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnDestroy(): void {
|
ngOnDestroy(): void {
|
||||||
|
@ -267,7 +276,11 @@ export class CreateChatDialogComponent implements OnInit, OnDestroy {
|
||||||
onClickChoice(choice: boolean): void {
|
onClickChoice(choice: boolean): void {
|
||||||
this.dialogRef.close({
|
this.dialogRef.close({
|
||||||
choice,
|
choice,
|
||||||
selectedUserList: this.selectedUserList
|
selectedUserList: this.selectedUserList,
|
||||||
|
groupName:
|
||||||
|
this.data.type === UserSelectDialogType.NewGroup
|
||||||
|
? this.inputForm.get('groupName').value
|
||||||
|
: ''
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,8 @@ import { MatMenuModule } from '@angular/material/menu';
|
||||||
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
||||||
import { MatTabsModule } from '@angular/material/tabs';
|
import { MatTabsModule } from '@angular/material/tabs';
|
||||||
import { MatToolbarModule } from '@angular/material/toolbar';
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
||||||
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
||||||
|
import { MatInputModule } from '@angular/material/input';
|
||||||
|
|
||||||
import { DragDropModule } from '@angular/cdk/drag-drop';
|
import { DragDropModule } from '@angular/cdk/drag-drop';
|
||||||
|
|
||||||
|
@ -25,12 +27,16 @@ import { UCapUiOrganizationModule } from '@ucap-webmessenger/ui-organization';
|
||||||
|
|
||||||
import { COMPONENTS } from './components';
|
import { COMPONENTS } from './components';
|
||||||
import { DIALOGS } from './dialogs';
|
import { DIALOGS } from './dialogs';
|
||||||
|
import { ReactiveFormsModule } from '@angular/forms';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FlexLayoutModule,
|
FlexLayoutModule,
|
||||||
DragDropModule,
|
DragDropModule,
|
||||||
|
ReactiveFormsModule,
|
||||||
|
MatFormFieldModule,
|
||||||
|
MatInputModule,
|
||||||
MatBadgeModule,
|
MatBadgeModule,
|
||||||
MatButtonModule,
|
MatButtonModule,
|
||||||
MatCardModule,
|
MatCardModule,
|
||||||
|
|
|
@ -227,6 +227,7 @@ export class Effects {
|
||||||
|
|
||||||
// not opened room :: unread count increased
|
// not opened room :: unread count increased
|
||||||
if (!roomInfo || roomInfo.roomSeq !== action.roomSeq) {
|
if (!roomInfo || roomInfo.roomSeq !== action.roomSeq) {
|
||||||
|
if (!!trgtRoomInfos && !!trgtRoomInfos[action.roomSeq]) {
|
||||||
const noReadCnt = trgtRoomInfos[action.roomSeq].noReadCnt;
|
const noReadCnt = trgtRoomInfos[action.roomSeq].noReadCnt;
|
||||||
this.store.dispatch(
|
this.store.dispatch(
|
||||||
SyncStore.updateUnreadCount({
|
SyncStore.updateUnreadCount({
|
||||||
|
@ -235,6 +236,7 @@ export class Effects {
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 대화 > 리스트 :: finalEventMessage refresh
|
// 대화 > 리스트 :: finalEventMessage refresh
|
||||||
this.store.dispatch(ChatStore.newEventMessage(action));
|
this.store.dispatch(ChatStore.newEventMessage(action));
|
||||||
|
|
|
@ -69,6 +69,12 @@ export const reducer = createReducer(
|
||||||
}
|
}
|
||||||
|
|
||||||
let unReadCount = 0;
|
let unReadCount = 0;
|
||||||
|
/** SYNC ROOM 으로 정보 수집시 증분값을 받는다면 기존 state 의 정보를 뒤져 noReadCount 를 계산 후 중분 값에 대한 noReadCount 를 더한다. */
|
||||||
|
// tslint:disable-next-line: forin
|
||||||
|
for (const key in state.room.entities) {
|
||||||
|
const value = state.room.entities[key];
|
||||||
|
unReadCount += value.noReadCnt;
|
||||||
|
}
|
||||||
action.roomList.map(item => (unReadCount += item.noReadCnt));
|
action.roomList.map(item => (unReadCount += item.noReadCnt));
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user