Merge branch 'feature/BETERAN-BACKEND-APP-BROWSER-init' of https://gitlab.loafle.net/bet/beteran-backend-app-browser into feature/BETERAN-BACKEND-APP-BROWSER-init
This commit is contained in:
commit
c1c9cb038c
|
@ -105,8 +105,8 @@
|
||||||
<div
|
<div
|
||||||
class="flex flex-col flex-auto sm:mb-18 overflow-hidden sm:overflow-y-auto"
|
class="flex flex-col flex-auto sm:mb-18 overflow-hidden sm:overflow-y-auto"
|
||||||
>
|
>
|
||||||
<ng-container *ngIf="deposits$ | async as deposits">
|
<ng-container *ngIf="bankDeposit$ | async as bankDeposit">
|
||||||
<ng-container *ngIf="deposits.length > 0; else noDeposit">
|
<ng-container *ngIf="bankDeposit.length > 0; else noDeposit">
|
||||||
<div class="grid">
|
<div class="grid">
|
||||||
<!-- Header -->
|
<!-- Header -->
|
||||||
<div
|
<div
|
||||||
|
@ -145,9 +145,13 @@
|
||||||
<div class="hidden lg:block">삭제</div>
|
<div class="hidden lg:block">삭제</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Rows -->
|
<!-- Rows -->
|
||||||
<ng-container *ngIf="deposits$ | async as deposits">
|
<ng-container *ngIf="bankDeposit$ | async as bankDeposit">
|
||||||
<ng-container
|
<ng-container
|
||||||
*ngFor="let deposit of deposits; trackBy: __trackByFn"
|
*ngFor="
|
||||||
|
let deposit of bankDeposit;
|
||||||
|
trackBy: __trackByFn;
|
||||||
|
let idx = index
|
||||||
|
"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
class="deposit-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
class="deposit-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
||||||
|
@ -155,45 +159,55 @@
|
||||||
<div>
|
<div>
|
||||||
<mat-checkbox></mat-checkbox>
|
<mat-checkbox></mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div>{{ deposit.highRank }}</div>
|
<!-- 상부 -->
|
||||||
|
<div>test {{ idx }}</div>
|
||||||
|
<!-- 아이디, 닉네임 -->
|
||||||
<div>
|
<div>
|
||||||
<div
|
<div
|
||||||
(click)="viewUserDetail(deposit.id!)"
|
(click)="viewUserDetail(deposit.getMemberId())"
|
||||||
style="cursor: pointer"
|
style="cursor: pointer"
|
||||||
>
|
>
|
||||||
{{ deposit.signinId }}
|
test {{ idx }}
|
||||||
</div>
|
</div>
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ deposit.nickname }}
|
test {{ idx }}
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 등급, 레벨, 상태 -->
|
||||||
<div>
|
<div>
|
||||||
{{ deposit.rank }}
|
test {{ idx }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
LV{{ deposit.level }}
|
test {{ idx }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ deposit.state }}
|
test {{ idx }}
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 예금주 -->
|
||||||
<div class="hidden sm:block">
|
<div class="hidden sm:block">
|
||||||
{{ deposit.accountHolder }}
|
{{ deposit.getName() }}
|
||||||
</div>
|
</div>
|
||||||
<div>{{ deposit.calculateType }}</div>
|
<!-- 정산종류 -->
|
||||||
<div>{{ deposit.note }}</div>
|
<div>{{ idx % 2 === 0 ? "롤링" : "콤프" }}</div>
|
||||||
<div>{{ deposit.depositAmount }}</div>
|
<!-- 비고 -->
|
||||||
|
<div>test {{ idx }}</div>
|
||||||
|
<!-- 입금예정금액 -->
|
||||||
|
<div>test {{ idx }}</div>
|
||||||
|
<!-- 등록날짜, 처리날짜 -->
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block">
|
||||||
{{ deposit.registrationDate }}
|
{{ deposit.getCreatedAt() | date: "yyyy-MM-dd HH:mm" }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ deposit.processDate }}
|
{{ deposit.getStateChangedAt() | date: "yyyy-MM-dd HH:mm" }}
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 입금, 출금 -->
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block">
|
||||||
입금{{ deposit.deposit }}
|
<span>41,200,000원</span>
|
||||||
|
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
출금{{ deposit.withdraw }}
|
<span>19,000,000원</span>
|
||||||
|
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
계{{ deposit.totalMoney }}
|
<span>22,200,000원</span>
|
||||||
</div>
|
|
||||||
<div class="hidden md:block">
|
|
||||||
{{ deposit.gameMoney }}
|
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 게임중머니 -->
|
||||||
|
<div class="hidden md:block">test {{ idx }}</div>
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block">
|
||||||
<button
|
<button
|
||||||
mat-flat-button
|
mat-flat-button
|
||||||
|
|
|
@ -22,6 +22,7 @@ import {
|
||||||
map,
|
map,
|
||||||
merge,
|
merge,
|
||||||
Observable,
|
Observable,
|
||||||
|
of,
|
||||||
Subject,
|
Subject,
|
||||||
switchMap,
|
switchMap,
|
||||||
takeUntil,
|
takeUntil,
|
||||||
|
@ -32,7 +33,9 @@ import { FuseConfirmationService } from '@fuse/services/confirmation';
|
||||||
import { Deposit } from '../models/deposit';
|
import { Deposit } from '../models/deposit';
|
||||||
import { DepositPagination } from '../models/deposit-pagination';
|
import { DepositPagination } from '../models/deposit-pagination';
|
||||||
import { DepositService } from '../services/deposit.service';
|
import { DepositService } from '../services/deposit.service';
|
||||||
import { Router } from '@angular/router';
|
import { ActivatedRoute, Router } from '@angular/router';
|
||||||
|
import { ListMemberBankDepositsResponse } from 'app/modules/proto/c2se/member_bank_deposit_pb';
|
||||||
|
import { MemberBankDeposit } from 'app/modules/proto/models/member_bank_deposit_pb';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'deposit-list',
|
selector: 'deposit-list',
|
||||||
|
@ -69,7 +72,7 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
@ViewChild(MatPaginator) private _paginator!: MatPaginator;
|
@ViewChild(MatPaginator) private _paginator!: MatPaginator;
|
||||||
@ViewChild(MatSort) private _sort!: MatSort;
|
@ViewChild(MatSort) private _sort!: MatSort;
|
||||||
|
|
||||||
deposits$!: Observable<Deposit[] | undefined>;
|
bankDeposit$!: Observable<MemberBankDeposit[] | undefined>;
|
||||||
|
|
||||||
__isSearchOpened = false;
|
__isSearchOpened = false;
|
||||||
isLoading = false;
|
isLoading = false;
|
||||||
|
@ -83,6 +86,7 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
* Constructor
|
* Constructor
|
||||||
*/
|
*/
|
||||||
constructor(
|
constructor(
|
||||||
|
private _activatedRoute: ActivatedRoute,
|
||||||
private _changeDetectorRef: ChangeDetectorRef,
|
private _changeDetectorRef: ChangeDetectorRef,
|
||||||
private _fuseConfirmationService: FuseConfirmationService,
|
private _fuseConfirmationService: FuseConfirmationService,
|
||||||
private _formBuilder: FormBuilder,
|
private _formBuilder: FormBuilder,
|
||||||
|
@ -110,7 +114,20 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Get the products
|
// Get the products
|
||||||
this.deposits$ = this._depositService.deposits$;
|
|
||||||
|
this._activatedRoute.data.subscribe((data) => {
|
||||||
|
let listBankDepositResult: ListMemberBankDepositsResponse.Result =
|
||||||
|
data['bankDeposit'];
|
||||||
|
this.bankDeposit$ = of(listBankDepositResult.getMemberBankDepositsList());
|
||||||
|
|
||||||
|
console.log(
|
||||||
|
'bankWithdraw: ',
|
||||||
|
listBankDepositResult.getMemberBankDepositsList()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Mark for check
|
||||||
|
this._changeDetectorRef.markForCheck();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -3,7 +3,10 @@ import { Route } from '@angular/router';
|
||||||
import { ListComponent } from './components/list.component';
|
import { ListComponent } from './components/list.component';
|
||||||
import { ViewComponent } from '../../member/user/components/view.component';
|
import { ViewComponent } from '../../member/user/components/view.component';
|
||||||
|
|
||||||
import { DepositsResolver } from './resolvers/deposit.resolver';
|
import {
|
||||||
|
BankDepositResolver,
|
||||||
|
DepositsResolver,
|
||||||
|
} from './resolvers/deposit.resolver';
|
||||||
import { UserResolver } from '../../dashboards/user/user.resolvers';
|
import { UserResolver } from '../../dashboards/user/user.resolvers';
|
||||||
|
|
||||||
export const depositRoutes: Route[] = [
|
export const depositRoutes: Route[] = [
|
||||||
|
@ -11,7 +14,7 @@ export const depositRoutes: Route[] = [
|
||||||
path: '',
|
path: '',
|
||||||
component: ListComponent,
|
component: ListComponent,
|
||||||
resolve: {
|
resolve: {
|
||||||
deposits: DepositsResolver,
|
bankDeposit: BankDepositResolver,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -5,6 +5,8 @@ import {
|
||||||
Router,
|
Router,
|
||||||
RouterStateSnapshot,
|
RouterStateSnapshot,
|
||||||
} from '@angular/router';
|
} from '@angular/router';
|
||||||
|
import { MemberBankDepositService } from 'app/modules/polyglot/member_bank_deposit/services/member_bank_deposit.service';
|
||||||
|
import { ListMemberBankDepositsResponse } from 'app/modules/proto/c2se/member_bank_deposit_pb';
|
||||||
import { catchError, Observable, throwError } from 'rxjs';
|
import { catchError, Observable, throwError } from 'rxjs';
|
||||||
|
|
||||||
import { Deposit } from '../models/deposit';
|
import { Deposit } from '../models/deposit';
|
||||||
|
@ -85,3 +87,33 @@ export class DepositsResolver implements Resolve<any> {
|
||||||
return this._depositService.getDeposits();
|
return this._depositService.getDeposits();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Injectable({
|
||||||
|
providedIn: 'root',
|
||||||
|
})
|
||||||
|
export class BankDepositResolver implements Resolve<any> {
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
constructor(private _bankDepositService: MemberBankDepositService) {}
|
||||||
|
|
||||||
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
// @ Public methods
|
||||||
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolver
|
||||||
|
*
|
||||||
|
* @param route
|
||||||
|
* @param state
|
||||||
|
*/
|
||||||
|
resolve(
|
||||||
|
route: ActivatedRouteSnapshot,
|
||||||
|
state: RouterStateSnapshot
|
||||||
|
):
|
||||||
|
| Observable<ListMemberBankDepositsResponse.Result>
|
||||||
|
| Promise<ListMemberBankDepositsResponse.Result>
|
||||||
|
| ListMemberBankDepositsResponse.Result {
|
||||||
|
return this._bankDepositService.listMemberBankDeposits();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -35,6 +35,24 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Search -->
|
<!-- Search -->
|
||||||
|
<div class="flex items-center mt-2 mb-2 ml-6">
|
||||||
|
<div>
|
||||||
|
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
||||||
|
환전처리
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
||||||
|
대기처리
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<button mat-flat-button class="bet-mat-small-8" [color]="'warn'">
|
||||||
|
환전취소
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
<div
|
<div
|
||||||
*ngIf="__isSearchOpened"
|
*ngIf="__isSearchOpened"
|
||||||
class="relative flex flex-col sm:flex-row flex-0 sm:items-center sm:justify-between py-4 px-6 md:px-8 border-b"
|
class="relative flex flex-col sm:flex-row flex-0 sm:items-center sm:justify-between py-4 px-6 md:px-8 border-b"
|
||||||
|
@ -91,27 +109,12 @@
|
||||||
</div>
|
</div>
|
||||||
<!-- Main -->
|
<!-- Main -->
|
||||||
<div class="flex flex-auto overflow-hidden">
|
<div class="flex flex-auto overflow-hidden">
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
|
||||||
환전처리
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
|
||||||
대기처리
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'warn'">
|
|
||||||
환전취소
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<!-- Products list -->
|
<!-- Products list -->
|
||||||
<div
|
<div
|
||||||
class="flex flex-col flex-auto sm:mb-18 overflow-hidden sm:overflow-y-auto"
|
class="flex flex-col flex-auto sm:mb-18 overflow-hidden sm:overflow-y-auto"
|
||||||
>
|
>
|
||||||
<ng-container *ngIf="withdraws$ | async as withdraws">
|
<ng-container *ngIf="bankWithdraw$ | async as bankWithdraw">
|
||||||
<ng-container *ngIf="withdraws.length > 0; else noWithdraw">
|
<ng-container *ngIf="bankWithdraw.length > 0; else noWithdraw">
|
||||||
<div class="grid">
|
<div class="grid">
|
||||||
<!-- Header -->
|
<!-- Header -->
|
||||||
<div
|
<div
|
||||||
|
@ -120,37 +123,54 @@
|
||||||
<div>
|
<div>
|
||||||
<mat-checkbox></mat-checkbox>
|
<mat-checkbox></mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div>상부</div>
|
|
||||||
<div>
|
<div>
|
||||||
|
구분
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
아이디
|
아이디
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
닉네임
|
닉네임
|
||||||
</div>
|
</div>
|
||||||
<div>
|
|
||||||
등급
|
|
||||||
<hr style="margin: 7px 0px" />
|
|
||||||
레벨
|
|
||||||
<hr style="margin: 7px 0px" />
|
|
||||||
상태
|
|
||||||
</div>
|
|
||||||
<div class="hidden sm:block">예금주</div>
|
|
||||||
<div>정산종류</div>
|
|
||||||
<div>비고</div>
|
|
||||||
<div>환전신청금액</div>
|
<div>환전신청금액</div>
|
||||||
|
<div>정산종류</div>
|
||||||
|
<div>
|
||||||
|
은행명
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
|
계좌번호
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
|
예금주
|
||||||
|
</div>
|
||||||
|
<div>비고</div>
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block">
|
||||||
등록날짜
|
등록날짜
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
처리날짜
|
처리날짜
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden md:block">입금출금</div>
|
<div class="hidden md:block">
|
||||||
<div class="hidden lg:block">회원정보</div>
|
입금
|
||||||
<div class="hidden lg:block">배팅정보</div>
|
<hr style="margin: 7px 0px" />
|
||||||
|
출금
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
|
보유금
|
||||||
|
</div>
|
||||||
|
<div class="hidden lg:block">
|
||||||
|
상위
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
|
회원정보
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
|
배팅정보
|
||||||
|
</div>
|
||||||
|
<div class="hidden lg:block">상태</div>
|
||||||
<div class="hidden lg:block">삭제</div>
|
<div class="hidden lg:block">삭제</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Rows -->
|
<!-- Rows -->
|
||||||
<ng-container *ngIf="withdraws$ | async as withdraws">
|
<ng-container *ngIf="bankWithdraw$ | async as bankWithdraw">
|
||||||
<ng-container
|
<ng-container
|
||||||
*ngFor="let withdraw of withdraws; trackBy: __trackByFn"
|
*ngFor="
|
||||||
|
let withdraw of bankWithdraw;
|
||||||
|
trackBy: __trackByFn;
|
||||||
|
let idx = index
|
||||||
|
"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
class="withdraw-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
class="withdraw-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
||||||
|
@ -158,43 +178,62 @@
|
||||||
<div>
|
<div>
|
||||||
<mat-checkbox></mat-checkbox>
|
<mat-checkbox></mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div>{{ withdraw.highRank }}</div>
|
|
||||||
<div>
|
<div>
|
||||||
|
회원
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
<div
|
<div
|
||||||
(click)="viewUserDetail(withdraw.id!)"
|
(click)="viewUserDetail(withdraw.getMemberId())"
|
||||||
style="cursor: pointer"
|
style="cursor: pointer"
|
||||||
>
|
>
|
||||||
{{ withdraw.signinId }}
|
test {{ idx }}
|
||||||
</div>
|
</div>
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ withdraw.nickname }}
|
test {{ idx }}
|
||||||
</div>
|
</div>
|
||||||
|
<!--환전신청금액-->
|
||||||
|
<div>{{ withdraw.getAccountNumber() }}</div>
|
||||||
|
<!--정산종류-->
|
||||||
|
<div>{{ idx % 2 === 0 ? "롤링" : "콤프" }}</div>
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
{{ withdraw.rank }}
|
<!-- 은행명, 계좌번호, 예금주-->
|
||||||
|
{{ withdraw.getBankName() }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
LV{{ withdraw.level }}
|
LV{{ withdraw.getAccountNumber() }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ withdraw.state }}
|
{{ withdraw.getName() }}
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden sm:block">
|
<!-- 비고 -->
|
||||||
{{ withdraw.accountHolder }}
|
<div [matTooltip]="__getMemoTooltop(withdraw)">@</div>
|
||||||
</div>
|
|
||||||
<div>{{ withdraw.calculateType }}</div>
|
<!-- 등록날짜/처리날짜-->
|
||||||
<div>{{ withdraw.note }}</div>
|
|
||||||
<div>{{ withdraw.exchangeApplicationAmount }}</div>
|
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block">
|
||||||
{{ withdraw.registrationDate }}
|
{{ withdraw.getCreatedAt() | date: "yyyy-MM-dd HH:mm" }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ withdraw.processDate }}
|
{{
|
||||||
|
withdraw.getStateChangedAt() | date: "yyyy-MM-dd HH:mm"
|
||||||
|
}}
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 입금/출금/보유금-->
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block">
|
||||||
입금{{ withdraw.deposit }}
|
<span>41,200,000원</span>
|
||||||
|
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
출금{{ withdraw.withdraw }}
|
<span>19,000,000원</span>
|
||||||
|
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
계{{ withdraw.totalMoney }}
|
<span>22,200,000원</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block">
|
||||||
|
<button
|
||||||
|
mat-flat-button
|
||||||
|
class="bet-mat-small-8"
|
||||||
|
[color]="'primary'"
|
||||||
|
>
|
||||||
|
[매장]kgon5
|
||||||
|
</button>
|
||||||
|
<hr style="margin: 7px 0px" />
|
||||||
<button
|
<button
|
||||||
mat-flat-button
|
mat-flat-button
|
||||||
class="bet-mat-small-8"
|
class="bet-mat-small-8"
|
||||||
|
@ -202,25 +241,18 @@
|
||||||
>
|
>
|
||||||
회원정보
|
회원정보
|
||||||
</button>
|
</button>
|
||||||
</div>
|
<hr style="margin: 7px 0px" />
|
||||||
<div class="hidden lg:block">
|
|
||||||
<button
|
<button
|
||||||
mat-flat-button
|
mat-flat-button
|
||||||
class="bet-mat-small-8"
|
class="bet-mat-small-8"
|
||||||
[color]="'primary'"
|
[color]="'primary'"
|
||||||
>
|
>
|
||||||
배팅정보
|
배팅리스트
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<div class="hidden lg:block">
|
|
||||||
<button
|
|
||||||
mat-flat-button
|
|
||||||
class="bet-mat-small-8"
|
|
||||||
[color]="'primary'"
|
|
||||||
>
|
|
||||||
취소
|
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="hidden lg:block">완료</div>
|
||||||
|
<div class="hidden lg:block">삭제</div>
|
||||||
</div>
|
</div>
|
||||||
</ng-container>
|
</ng-container>
|
||||||
</ng-container>
|
</ng-container>
|
||||||
|
@ -246,20 +278,5 @@
|
||||||
</div>
|
</div>
|
||||||
</ng-template>
|
</ng-template>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
|
||||||
환전처리
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'primary'">
|
|
||||||
대기처리
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<button mat-flat-button class="bet-mat-small-8" [color]="'warn'">
|
|
||||||
환전취소
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -22,6 +22,7 @@ import {
|
||||||
map,
|
map,
|
||||||
merge,
|
merge,
|
||||||
Observable,
|
Observable,
|
||||||
|
of,
|
||||||
Subject,
|
Subject,
|
||||||
switchMap,
|
switchMap,
|
||||||
takeUntil,
|
takeUntil,
|
||||||
|
@ -32,7 +33,9 @@ import { FuseConfirmationService } from '@fuse/services/confirmation';
|
||||||
import { Withdraw } from '../models/withdraw';
|
import { Withdraw } from '../models/withdraw';
|
||||||
import { WithdrawPagination } from '../models/withdraw-pagination';
|
import { WithdrawPagination } from '../models/withdraw-pagination';
|
||||||
import { WithdrawService } from '../services/withdraw.service';
|
import { WithdrawService } from '../services/withdraw.service';
|
||||||
import { Router } from '@angular/router';
|
import { ActivatedRoute, Router } from '@angular/router';
|
||||||
|
import { ListMemberBankWithdrawsResponse } from 'app/modules/proto/c2se/member_bank_withdraw_pb';
|
||||||
|
import { MemberBankWithdraw } from 'app/modules/proto/models/member_bank_withdraw_pb';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'withdraw-list',
|
selector: 'withdraw-list',
|
||||||
|
@ -52,9 +55,13 @@ import { Router } from '@angular/router';
|
||||||
}
|
}
|
||||||
|
|
||||||
@screen lg {
|
@screen lg {
|
||||||
grid-template-columns: 60px 60px auto 112px 96px 96px 72px;
|
grid-template-columns: 40px 140px auto 80px 140px 40px 120px 120px 120px 40px 40px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.mat-tooltip {
|
||||||
|
white-space: pre-line;
|
||||||
|
}
|
||||||
`,
|
`,
|
||||||
],
|
],
|
||||||
encapsulation: ViewEncapsulation.None,
|
encapsulation: ViewEncapsulation.None,
|
||||||
|
@ -65,7 +72,7 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
@ViewChild(MatPaginator) private _paginator!: MatPaginator;
|
@ViewChild(MatPaginator) private _paginator!: MatPaginator;
|
||||||
@ViewChild(MatSort) private _sort!: MatSort;
|
@ViewChild(MatSort) private _sort!: MatSort;
|
||||||
|
|
||||||
withdraws$!: Observable<Withdraw[] | undefined>;
|
bankWithdraw$!: Observable<MemberBankWithdraw[] | undefined>;
|
||||||
|
|
||||||
__isSearchOpened = false;
|
__isSearchOpened = false;
|
||||||
isLoading = false;
|
isLoading = false;
|
||||||
|
@ -79,6 +86,7 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
* Constructor
|
* Constructor
|
||||||
*/
|
*/
|
||||||
constructor(
|
constructor(
|
||||||
|
private _activatedRoute: ActivatedRoute,
|
||||||
private _changeDetectorRef: ChangeDetectorRef,
|
private _changeDetectorRef: ChangeDetectorRef,
|
||||||
private _fuseConfirmationService: FuseConfirmationService,
|
private _fuseConfirmationService: FuseConfirmationService,
|
||||||
private _formBuilder: FormBuilder,
|
private _formBuilder: FormBuilder,
|
||||||
|
@ -106,7 +114,22 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Get the products
|
// Get the products
|
||||||
this.withdraws$ = this._withdrawService.withdraws$;
|
|
||||||
|
this._activatedRoute.data.subscribe((data) => {
|
||||||
|
let listBankWithdrawResult: ListMemberBankWithdrawsResponse.Result =
|
||||||
|
data['bankWithdraw'];
|
||||||
|
this.bankWithdraw$ = of(
|
||||||
|
listBankWithdrawResult.getMemberBankWithdrawsList()
|
||||||
|
);
|
||||||
|
|
||||||
|
console.log(
|
||||||
|
'bankWithdraw: ',
|
||||||
|
listBankWithdrawResult.getMemberBankWithdrawsList()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Mark for check
|
||||||
|
this._changeDetectorRef.markForCheck();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -202,4 +225,13 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
__trackByFn(index: number, item: any): any {
|
__trackByFn(index: number, item: any): any {
|
||||||
return item.id || index;
|
return item.id || index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__getMemoTooltop(withdraw: MemberBankWithdraw): string {
|
||||||
|
if (!withdraw.getMemo() || withdraw.getMemo() === '') {
|
||||||
|
return '메모없음';
|
||||||
|
}
|
||||||
|
|
||||||
|
const resultMemoTooltip = withdraw.getMemo();
|
||||||
|
return resultMemoTooltip;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@ import {
|
||||||
Router,
|
Router,
|
||||||
RouterStateSnapshot,
|
RouterStateSnapshot,
|
||||||
} from '@angular/router';
|
} from '@angular/router';
|
||||||
|
import { MemberBankWithdrawService } from 'app/modules/polyglot/member_bank_withdraw/services/member_bank_withdraw.service';
|
||||||
|
import { ListMemberBankWithdrawsResponse } from 'app/modules/proto/c2se/member_bank_withdraw_pb';
|
||||||
import { catchError, Observable, throwError } from 'rxjs';
|
import { catchError, Observable, throwError } from 'rxjs';
|
||||||
|
|
||||||
import { Withdraw } from '../models/withdraw';
|
import { Withdraw } from '../models/withdraw';
|
||||||
|
@ -85,3 +87,33 @@ export class WithdrawsResolver implements Resolve<any> {
|
||||||
return this._withdrawService.getWithdraws();
|
return this._withdrawService.getWithdraws();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Injectable({
|
||||||
|
providedIn: 'root',
|
||||||
|
})
|
||||||
|
export class BankWithdrawResolver implements Resolve<any> {
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
constructor(private _bankWithdrawService: MemberBankWithdrawService) {}
|
||||||
|
|
||||||
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
// @ Public methods
|
||||||
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolver
|
||||||
|
*
|
||||||
|
* @param route
|
||||||
|
* @param state
|
||||||
|
*/
|
||||||
|
resolve(
|
||||||
|
route: ActivatedRouteSnapshot,
|
||||||
|
state: RouterStateSnapshot
|
||||||
|
):
|
||||||
|
| Observable<ListMemberBankWithdrawsResponse.Result>
|
||||||
|
| Promise<ListMemberBankWithdrawsResponse.Result>
|
||||||
|
| ListMemberBankWithdrawsResponse.Result {
|
||||||
|
return this._bankWithdrawService.listMemberBankWithdraws();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -3,7 +3,10 @@ import { Route } from '@angular/router';
|
||||||
import { ListComponent } from './components/list.component';
|
import { ListComponent } from './components/list.component';
|
||||||
import { ViewComponent } from '../../member/user/components/view.component';
|
import { ViewComponent } from '../../member/user/components/view.component';
|
||||||
|
|
||||||
import { WithdrawsResolver } from './resolvers/withdraw.resolver';
|
import {
|
||||||
|
BankWithdrawResolver,
|
||||||
|
WithdrawsResolver,
|
||||||
|
} from './resolvers/withdraw.resolver';
|
||||||
import { UserResolver } from '../../dashboards/user/user.resolvers';
|
import { UserResolver } from '../../dashboards/user/user.resolvers';
|
||||||
|
|
||||||
export const withdrawRoutes: Route[] = [
|
export const withdrawRoutes: Route[] = [
|
||||||
|
@ -11,7 +14,7 @@ export const withdrawRoutes: Route[] = [
|
||||||
path: '',
|
path: '',
|
||||||
component: ListComponent,
|
component: ListComponent,
|
||||||
resolve: {
|
resolve: {
|
||||||
withdraws: WithdrawsResolver,
|
bankWithdraw: BankWithdrawResolver,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -149,12 +149,15 @@
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block">
|
||||||
{{ partner.getMemberClass()?.getName() }}
|
{{ partner.getMemberClass()?.getName() }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
LV{{ partner.getMemberLevel()?.getName() }}
|
LV
|
||||||
|
{{ partner.getMemberLevel()?.getName()?.substring(5, 6) }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ partner.getState() }}
|
{{ __getStateString(partner) }}
|
||||||
</div>
|
</div>
|
||||||
<!-- 예금주 -->
|
<!-- 예금주 -->
|
||||||
<div class="hidden lg:block">예금주</div>
|
<div class="hidden lg:block">
|
||||||
|
{{ partner.getBankAccount()?.getName() }}
|
||||||
|
</div>
|
||||||
<!-- 정산종류 -->
|
<!-- 정산종류 -->
|
||||||
<div class="hidden lg:block">정산종류</div>
|
<div class="hidden lg:block">정산종류</div>
|
||||||
<!-- 보유금 -->
|
<!-- 보유금 -->
|
||||||
|
|
|
@ -367,4 +367,10 @@ export class ListComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
`;
|
`;
|
||||||
return resultTooltip;
|
return resultTooltip;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__getStateString(state: any): string {
|
||||||
|
console.log(state.getState());
|
||||||
|
|
||||||
|
return '정상';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,24 +11,21 @@
|
||||||
</div>
|
</div>
|
||||||
<!-- Title -->
|
<!-- Title -->
|
||||||
<div class="text-4xl font-extrabold tracking-tight">User</div>
|
<div class="text-4xl font-extrabold tracking-tight">User</div>
|
||||||
|
|
||||||
<!-- Actions -->
|
<!-- Actions -->
|
||||||
<div class="flex shrink-0 items-center mt-6 sm:mt-0 sm:ml-4">
|
<div class="flex shrink-0 items-center mt-6 sm:mt-0 sm:ml-4">
|
||||||
<!-- Search -->
|
<!-- Search -->
|
||||||
<div>
|
<span>총회원수:<span style="color: red">38</span>명</span>
|
||||||
<span>총회원수:<span style="color: red">38</span>명</span>
|
<span>진행중금액:<span style="color: red">0</span>원</span>
|
||||||
<span>진행중금액:<span style="color: red">0</span>원</span>
|
<span>총 보유머니:<span style="color: red">21,437,873</span>원</span
|
||||||
<span>총 보유머니:<span style="color: red">21,437,873</span>원</span
|
>
|
||||||
>
|
<span>총 콤프:<span style="color: red">394,860</span>원</span>
|
||||||
<span>총 콤프:<span style="color: red">394,860</span>원</span
|
<span>총 합계:<span style="color: blue">21,832,733</span>원</span>
|
||||||
>
|
|
||||||
<span>총 합계:<span style="color: blue">21,832,733</span>원</span>
|
|
||||||
</div>
|
|
||||||
<button mat-icon-button (click)="__onClickSearch()">
|
<button mat-icon-button (click)="__onClickSearch()">
|
||||||
<mat-icon [svgIcon]="'heroicons_outline:search'"></mat-icon>
|
<mat-icon [svgIcon]="'heroicons_outline:search'"></mat-icon>
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Memo -->
|
<!-- Memo -->
|
||||||
<div
|
<div
|
||||||
class="relative flex flex-col sm:flex-row flex-0 sm:items-center sm:justify-between py-4 px-6 md:px-8 border-b"
|
class="relative flex flex-col sm:flex-row flex-0 sm:items-center sm:justify-between py-4 px-6 md:px-8 border-b"
|
||||||
|
@ -161,13 +158,13 @@
|
||||||
matSortDisableClear
|
matSortDisableClear
|
||||||
class="user-grid z-10 sticky top-0 grid gap-4 py-4 px-6 md:px-8 shadow text-md font-semibold text-secondary bg-gray-50 dark:bg-black dark:bg-opacity-5"
|
class="user-grid z-10 sticky top-0 grid gap-4 py-4 px-6 md:px-8 shadow text-md font-semibold text-secondary bg-gray-50 dark:bg-black dark:bg-opacity-5"
|
||||||
>
|
>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
<mat-checkbox></mat-checkbox>
|
<mat-checkbox></mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div>관리</div>
|
<div style="text-align: center">관리</div>
|
||||||
<div>요율</div>
|
<div style="text-align: center">요율</div>
|
||||||
<div>상부</div>
|
<div style="text-align: center">상부</div>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
<div>아이디</div>
|
<div>아이디</div>
|
||||||
|
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
|
@ -175,23 +172,31 @@
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
연락처
|
연락처
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
등급
|
등급
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
레벨
|
레벨
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
상태
|
상태
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden sm:block">예금주</div>
|
<div class="hidden sm:block" style="text-align: center">
|
||||||
<div class="hidden md:block">보유금</div>
|
예금주
|
||||||
<div class="hidden md:block">
|
</div>
|
||||||
|
<div class="hidden md:block" style="text-align: center">
|
||||||
|
보유금
|
||||||
|
</div>
|
||||||
|
<div class="hidden md:block" style="text-align: center">
|
||||||
게임중머니
|
게임중머니
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
금일콤프
|
금일콤프
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden md:block">총입출</div>
|
<div class="hidden md:block" style="text-align: center">
|
||||||
<div class="hidden lg:block">카지노->캐쉬</div>
|
총입출
|
||||||
<div class="hidden lg:block">로그</div>
|
</div>
|
||||||
|
<div class="hidden lg:block" style="text-align: center">
|
||||||
|
카지노->캐쉬
|
||||||
|
</div>
|
||||||
|
<div class="hidden lg:block" style="text-align: center">로그</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Rows -->
|
<!-- Rows -->
|
||||||
<ng-container *ngIf="users$ | async as users">
|
<ng-container *ngIf="users$ | async as users">
|
||||||
|
@ -201,10 +206,10 @@
|
||||||
<div
|
<div
|
||||||
class="user-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
class="user-grid grid items-center gap-4 py-3 px-6 md:px-8 border-b"
|
||||||
>
|
>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
<mat-checkbox></mat-checkbox>
|
<mat-checkbox></mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block" style="text-align: center">
|
||||||
<div
|
<div
|
||||||
mat-button
|
mat-button
|
||||||
[matMenuTriggerFor]="menu"
|
[matMenuTriggerFor]="menu"
|
||||||
|
@ -243,7 +248,7 @@
|
||||||
<div>
|
<div>
|
||||||
{{ user.highRank }}
|
{{ user.highRank }}
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
<div
|
<div
|
||||||
(click)="viewUserDetail(user.id!)"
|
(click)="viewUserDetail(user.id!)"
|
||||||
style="cursor: pointer"
|
style="cursor: pointer"
|
||||||
|
@ -255,36 +260,36 @@
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ user.phoneNumber }}
|
{{ user.phoneNumber }}
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div style="text-align: center">
|
||||||
{{ user.rank }}
|
{{ user.rank }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
LV{{ user.level }}
|
{{ user.level }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ user.state }}
|
{{ user.state }}
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden sm:block">
|
<div class="hidden sm:block" style="text-align: center">
|
||||||
{{ user.accountHolder }}
|
{{ user.accountHolder }}
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block" style="text-align: center">
|
||||||
캐쉬{{ user.ownCash }}
|
캐쉬{{ user.ownCash }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
콤프{{ user.ownComp }}P
|
콤프{{ user.ownComp }}P
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
쿠폰{{ user.ownCoupon }}
|
쿠폰{{ user.ownCoupon }}
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block" style="text-align: center">
|
||||||
{{ user.gameMoney }}
|
{{ user.gameMoney }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
{{ user.todayComp }}P
|
{{ user.todayComp }}P
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden md:block">
|
<div class="hidden md:block" style="text-align: center">
|
||||||
입금{{ user.totalDeposit }}
|
입금{{ user.totalDeposit }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
출금{{ user.totalWithdraw }}
|
출금{{ user.totalWithdraw }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
차익{{ user.balance }}
|
차익{{ user.balance }}
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block" style="text-align: center">
|
||||||
<button
|
<button
|
||||||
mat-flat-button
|
mat-flat-button
|
||||||
class="bet-mat-small-8"
|
class="bet-mat-small-8"
|
||||||
|
@ -301,7 +306,7 @@
|
||||||
게임머니회수
|
게임머니회수
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="hidden lg:block">
|
<div class="hidden lg:block" style="text-align: center">
|
||||||
가입{{ user.registrationDate }}
|
가입{{ user.registrationDate }}
|
||||||
<hr style="margin: 7px 0px" />
|
<hr style="margin: 7px 0px" />
|
||||||
최종{{ user.finalSigninDate }}
|
최종{{ user.finalSigninDate }}
|
||||||
|
|
|
@ -111,9 +111,9 @@
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>아이디</mat-label>
|
<mat-label>아이디</mat-label>
|
||||||
<input
|
<input
|
||||||
id="signinId"
|
id="username"
|
||||||
matInput
|
matInput
|
||||||
[formControlName]="'signinId'"
|
[formControlName]="'username'"
|
||||||
/>
|
/>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
|
@ -155,9 +155,9 @@
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>핸드폰</mat-label>
|
<mat-label>핸드폰</mat-label>
|
||||||
<input
|
<input
|
||||||
id="phoneNumber"
|
id="mobilePhoneNumber"
|
||||||
matInput
|
matInput
|
||||||
[formControlName]="'phoneNumber'"
|
[formControlName]="'mobilePhoneNumber'"
|
||||||
/>
|
/>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
</div>
|
</div>
|
||||||
|
@ -166,17 +166,22 @@
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>레벨</mat-label>
|
<mat-label>레벨</mat-label>
|
||||||
<mat-select id="level" [formControlName]="'level'">
|
<mat-select
|
||||||
<!-- <ng-container *ngFor="let category of categories"> -->
|
[formControlName]="'levelId'"
|
||||||
<mat-option value="level">
|
placeholder="레벨 선택"
|
||||||
cartegory option
|
>
|
||||||
|
<mat-option
|
||||||
|
*ngFor="let level of memberLevels"
|
||||||
|
[value]="'level.getId()'"
|
||||||
|
>
|
||||||
|
{{ level.getName() }}
|
||||||
</mat-option>
|
</mat-option>
|
||||||
<!-- </ng-container> -->
|
<!-- <mat-option [value]="'0'"> 국민은행 </mat-option> -->
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>상태</mat-label>
|
<mat-label>상태</mat-label>
|
||||||
<mat-select id="state" [formControlName]="'status'">
|
<mat-select id="state" [formControlName]="'state'">
|
||||||
<!-- <ng-container *ngFor="let brand of brands"> -->
|
<!-- <ng-container *ngFor="let brand of brands"> -->
|
||||||
<mat-option value="brand.id">
|
<mat-option value="brand.id">
|
||||||
brand option
|
brand option
|
||||||
|
@ -200,14 +205,28 @@
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>은행명</mat-label>
|
<mat-label>은행명</mat-label>
|
||||||
<mat-select [formControlName]="'bankname'">
|
|
||||||
<!-- <ng-container *ngFor="let brand of brands"> -->
|
<mat-select
|
||||||
<mat-option value="brand.id">
|
[formControlName]="'bankId'"
|
||||||
brand option
|
placeholder="은행 선택"
|
||||||
|
>
|
||||||
|
<mat-option
|
||||||
|
*ngFor="let bank of banks"
|
||||||
|
[value]="bank.getId()"
|
||||||
|
>
|
||||||
|
{{ bank.getName() }}
|
||||||
</mat-option>
|
</mat-option>
|
||||||
<!-- </ng-container> -->
|
<!-- <mat-option [value]="'0'"> 국민은행 </mat-option> -->
|
||||||
</mat-select>
|
</mat-select>
|
||||||
|
<!-- <mat-error
|
||||||
|
*ngIf="
|
||||||
|
composeForm.get('bankId')?.hasError('required')
|
||||||
|
"
|
||||||
|
>
|
||||||
|
은행명은 필수 입력입니다.
|
||||||
|
</mat-error> -->
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>계좌번호</mat-label>
|
<mat-label>계좌번호</mat-label>
|
||||||
<input
|
<input
|
||||||
|
@ -257,14 +276,23 @@
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<mat-form-field class="w-2/3 pr-2">
|
<mat-form-field class="w-2/3 pr-2">
|
||||||
<mat-label>사이트변경</mat-label>
|
<mat-label>사이트변경</mat-label>
|
||||||
<mat-select [formControlName]="'changeSite'">
|
|
||||||
<!-- <ng-container *ngFor="let vendor of vendors"> -->
|
<mat-select
|
||||||
<mat-option value="vendor.id">
|
[formControlName]="'changeSite'"
|
||||||
vendor option
|
placeholder="사이트 선택"
|
||||||
|
>
|
||||||
|
<mat-option
|
||||||
|
*ngFor="let site of sites"
|
||||||
|
[value]="site.getId()"
|
||||||
|
>
|
||||||
|
{{ site.getUrl() }}
|
||||||
</mat-option>
|
</mat-option>
|
||||||
<!-- </ng-container> -->
|
|
||||||
</mat-select>
|
</mat-select>
|
||||||
|
<!-- <mat-error *ngIf="composeForm.get('siteId')?.hasError('required')">
|
||||||
|
사이트명은 필수 입력입니다.
|
||||||
|
</mat-error> -->
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
|
||||||
<mat-form-field class="w-1/3 pr-2">
|
<mat-form-field class="w-1/3 pr-2">
|
||||||
<mat-label>추천횟수</mat-label>
|
<mat-label>추천횟수</mat-label>
|
||||||
<input
|
<input
|
||||||
|
|
|
@ -35,6 +35,12 @@ import { ActivatedRoute } from '@angular/router';
|
||||||
import { GetMemberResponse } from 'app/modules/proto/c2se/member_pb';
|
import { GetMemberResponse } from 'app/modules/proto/c2se/member_pb';
|
||||||
import { MemberModel } from 'app/modules/proto/models/member_pb';
|
import { MemberModel } from 'app/modules/proto/models/member_pb';
|
||||||
import { MemberService } from 'app/modules/polyglot/member/services/member.service';
|
import { MemberService } from 'app/modules/polyglot/member/services/member.service';
|
||||||
|
import { MemberLevelService } from 'app/modules/polyglot/member_level/services/member_level.service';
|
||||||
|
import { BankService } from 'app/modules/polyglot/bank/services/bank.service';
|
||||||
|
import { MemberLevel } from 'app/modules/proto/models/member_level_pb';
|
||||||
|
import { Bank } from 'app/modules/proto/models/bank_pb';
|
||||||
|
import { SiteService } from 'app/modules/polyglot/site/services/site.service';
|
||||||
|
import { Site } from 'app/modules/proto/models/site_pb';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'user-view',
|
selector: 'user-view',
|
||||||
|
@ -73,6 +79,10 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
/* selectedUser?: User; */
|
/* selectedUser?: User; */
|
||||||
selectedUser?: MemberModel;
|
selectedUser?: MemberModel;
|
||||||
|
|
||||||
|
memberLevels!: MemberLevel[];
|
||||||
|
banks!: Bank[];
|
||||||
|
sites!: Site[];
|
||||||
|
|
||||||
private _unsubscribeAll: Subject<any> = new Subject<any>();
|
private _unsubscribeAll: Subject<any> = new Subject<any>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -84,7 +94,10 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
private _fuseConfirmationService: FuseConfirmationService,
|
private _fuseConfirmationService: FuseConfirmationService,
|
||||||
private _formBuilder: FormBuilder,
|
private _formBuilder: FormBuilder,
|
||||||
private _userService: UserService,
|
private _userService: UserService,
|
||||||
private _memberService: MemberService
|
private _memberService: MemberService,
|
||||||
|
private _memberLevelService: MemberLevelService,
|
||||||
|
private _bankService: BankService,
|
||||||
|
private _siteService: SiteService
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------------------
|
||||||
|
@ -97,18 +110,18 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
this.memberViewForm = this._formBuilder.group({
|
this.memberViewForm = this._formBuilder.group({
|
||||||
id: [''],
|
id: [''],
|
||||||
signinId: [{ value: '', disabled: true }],
|
username: [{ value: '', disabled: true }],
|
||||||
signinPw: [{ value: '' }],
|
signinPw: [{ value: '' }],
|
||||||
exchangePw: [''],
|
exchangePw: [''],
|
||||||
description: [''],
|
description: [''],
|
||||||
tags: [[]],
|
tags: [[]],
|
||||||
nickname: [{ value: '', disabled: true }],
|
nickname: [{ value: '', disabled: true }],
|
||||||
ownCash: [''],
|
ownCash: [''],
|
||||||
phoneNumber: [''],
|
mobilePhoneNumber: [''],
|
||||||
level: [''],
|
level: [''],
|
||||||
status: [''],
|
state: [''],
|
||||||
isExcahngeMoney: [''],
|
isExcahngeMoney: [''],
|
||||||
bankname: [''],
|
bankId: [''],
|
||||||
accountNumber: [''],
|
accountNumber: [''],
|
||||||
accountHolder: [''],
|
accountHolder: [''],
|
||||||
comp: [''],
|
comp: [''],
|
||||||
|
@ -143,6 +156,18 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
|
|
||||||
/* this.user$ = this._userService.user$; */
|
/* this.user$ = this._userService.user$; */
|
||||||
|
|
||||||
|
this._siteService
|
||||||
|
.listSites()
|
||||||
|
.then((result) => (this.sites = result.getSitesList()));
|
||||||
|
this._memberLevelService.listMemberLevels().then((result) => {
|
||||||
|
this.memberLevels = result
|
||||||
|
.getMemberLevelsList()
|
||||||
|
.filter((v) => !!v.getShow());
|
||||||
|
});
|
||||||
|
this._bankService
|
||||||
|
.listBanks()
|
||||||
|
.then((result) => (this.banks = result.getBanksList()));
|
||||||
|
|
||||||
this._activatedRoute.data.subscribe((data) => {
|
this._activatedRoute.data.subscribe((data) => {
|
||||||
let member: GetMemberResponse.Result = data['member'];
|
let member: GetMemberResponse.Result = data['member'];
|
||||||
|
|
||||||
|
@ -150,13 +175,14 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
|
|
||||||
/* console.log('dddd', listMemberResult.getMembersList()); */
|
/* console.log('dddd', listMemberResult.getMembersList()); */
|
||||||
this.memberViewForm.patchValue({
|
this.memberViewForm.patchValue({
|
||||||
signinId: this.selectedUser?.getUsername(),
|
username: this.selectedUser?.getUsername(),
|
||||||
signinPw: '1234',
|
signinPw: '',
|
||||||
exchangePw: '1234',
|
exchangePw: '',
|
||||||
phoneNumber: this.selectedUser?.getMobilePhoneNumber(),
|
mobilePhoneNumber: this.selectedUser?.getMobilePhoneNumber(),
|
||||||
level: this.selectedUser?.getMemberLevel()?.getName(),
|
levelId: this.selectedUser?.getMemberLevel()?.getId(),
|
||||||
status: this.selectedUser?.getState(),
|
state: this.selectedUser?.getState(),
|
||||||
nickname: this.selectedUser?.getNickname(),
|
nickname: this.selectedUser?.getNickname(),
|
||||||
|
bankId: this.selectedUser?.getBankAccount()?.getId(),
|
||||||
});
|
});
|
||||||
// Mark for check
|
// Mark for check
|
||||||
this._changeDetectorRef.markForCheck();
|
this._changeDetectorRef.markForCheck();
|
||||||
|
@ -210,12 +236,12 @@ export class ViewComponent implements OnInit, AfterViewInit, OnDestroy {
|
||||||
__modifyMember(): void {
|
__modifyMember(): void {
|
||||||
const valueForm = this.memberViewForm.value;
|
const valueForm = this.memberViewForm.value;
|
||||||
console.log('v: ', valueForm);
|
console.log('v: ', valueForm);
|
||||||
this._memberService.updateMember(
|
/* this._memberService.updateMember(
|
||||||
this.selectedUser!.getId(),
|
this.selectedUser!.getId(),
|
||||||
this.selectedUser!.getSite()!.getId(),
|
this.selectedUser!.getSite()!.getId(),
|
||||||
this.selectedUser!.getMemberLevel()!.getId(),
|
this.selectedUser!.getMemberLevel()!.getId(),
|
||||||
'beteran',
|
'beteran',
|
||||||
valueForm.phoneNumber
|
valueForm.mobilePhoneNumber
|
||||||
);
|
); */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ import { MatChipsModule } from '@angular/material/chips';
|
||||||
import { MatMenuModule } from '@angular/material/menu';
|
import { MatMenuModule } from '@angular/material/menu';
|
||||||
import { MatDividerModule } from '@angular/material/divider';
|
import { MatDividerModule } from '@angular/material/divider';
|
||||||
import { MatDialogModule } from '@angular/material/dialog';
|
import { MatDialogModule } from '@angular/material/dialog';
|
||||||
|
import { MatCardModule } from '@angular/material/card';
|
||||||
|
|
||||||
import { FuseCardModule } from '@fuse/components/card';
|
import { FuseCardModule } from '@fuse/components/card';
|
||||||
|
|
||||||
|
@ -56,6 +57,7 @@ import { userRoutes } from 'app/modules/admin/member/user/user.routing';
|
||||||
MatMenuModule,
|
MatMenuModule,
|
||||||
MatDividerModule,
|
MatDividerModule,
|
||||||
MatDialogModule,
|
MatDialogModule,
|
||||||
|
MatCardModule,
|
||||||
|
|
||||||
FuseCardModule,
|
FuseCardModule,
|
||||||
],
|
],
|
||||||
|
|
Loading…
Reference in New Issue
Block a user