거래 상세 amountInfo

This commit is contained in:
focp212@naver.com
2025-10-20 14:52:49 +09:00
parent 0e8a5f0d89
commit 5d2af3fb06
3 changed files with 106 additions and 26 deletions

View File

@@ -295,6 +295,7 @@ export interface BillingDetailParams {
export interface AmountInfo { export interface AmountInfo {
mid?: string; mid?: string;
transactionRequestAmount?: number;
transactionAmount?: number; transactionAmount?: number;
escrowFee?: number; escrowFee?: number;
pointAmount?: number; pointAmount?: number;

View File

@@ -29,7 +29,6 @@ export const ListDateGroup = ({
const getListItem = () => { const getListItem = () => {
let rs = []; let rs = [];
console.log('items', items)
if(!!items && items.length>0){ if(!!items && items.length>0){
for(let i=0;i<items.length;i++){ for(let i=0;i<items.length;i++){
let key = 'ListItem-'+i; let key = 'ListItem-'+i;

View File

@@ -15,37 +15,39 @@ export const AmountInfoSection = ({
onClickToOpenInfo onClickToOpenInfo
}: InfoSectionProps) => { }: InfoSectionProps) => {
const { mutateAsync: downloadConfirmation } = useDownloadConfirmationMutation(); const { mutateAsync: downloadConfirmation } = useDownloadConfirmationMutation();
let newAmountInfo: Record<string, any> | undefined = amountInfo;
console.log('amountInfo --> ', amountInfo);
const subItems: Record<string, Record<string, string>> = { const subItems: Record<string, Record<string, string>> = {
mid: {name: 'MID', type: 'string'}, mid: {name: 'MID', type: 'string'},
transactionRequestAmount: {name: '거래요청금액', type: 'number'},
transactionAmount: {name: '거래금액', type: 'number'}, transactionAmount: {name: '거래금액', type: 'number'},
escrowFee: {name: '에스크로수수료', type: 'number'},
pointAmount: {name: '포인트금액', type: 'number'}, pointAmount: {name: '포인트금액', type: 'number'},
couponAmount: {name: '쿠폰금액', type: 'number'}, couponAmount: {name: '쿠폰금액', type: 'number'},
partServiceCode: {name: '간편결제코드', type: 'string' }, escrowFee: {name: '에스크로수수료', type: 'number'},
kakaoMoneyAmount: {name: '카카오머니', type: 'number'},
kakaoPointAmount: {name: '카카오포인트', type: 'number'},
kakaoDiscountAmount: {name: '카카오 즉시할인', type: 'number'}, kakaoDiscountAmount: {name: '카카오 즉시할인', type: 'number'},
naverPointAmount: {name: '네이버 포인트', type: 'number'},
tossMoneyAmount: {name: '토스머니', type: 'number'},
tossDiscountAmount: {name: '토스할인', type: 'number'}, tossDiscountAmount: {name: '토스할인', type: 'number'},
multiPointAmount: {name: '멀티포인트금액', type: 'number'}, paycoPointAmount: {name: '페이코포인트', type: 'number'},
multiCouponAmount: {name: '멀티쿠폰금액', type: 'number'}, paycoCouponAmount: {name: '페이코쿠폰', type: 'number'},
receiptAmount: {name: '영수증금액', type: 'number'},
cupDepositAmount: {name: '컵보증금', type: 'number'},
}; };
const showTop = ['01', '02', '03', '26'];
const openSubItems: Record<string, Array<string>> = { const openSubItems: Record<string, Array<string>> = {
// 신용카드 // 신용카드
'01': ['mid', 'cardAmount', 'pointAmount', '01': ['transactionAmount', 'pointAmount', 'couponAmount',
'couponAmount', 'escrowFee', 'kakaoMoney', 'escrowFee', 'kakaoMoneyAmount', 'kakaoPointAmount',
'kakaoPoint', 'kakaoInstantDiscount', 'naverPoint', 'kakaoDiscountAmount', 'naverPointAmount', 'tossMoneyAmount',
'tossMoney', 'tossDiscount', 'paycoPoint', 'paycoCoupon' 'tossDiscountAmount', 'paycoPointAmount', 'paycoCouponAmount'
], ],
// 계좌이체 // 계좌이체
'02': ['mid', 'transactionAmount', 'escrowFee'], '02': ['mid', 'transactionRequestAmount', 'transactionAmount', 'escrowFee'],
// 가상계좌 // 가상계좌
'03': ['mid', 'transactionAmount'], '03': ['mid', 'transactionRequestAmount', 'transactionAmount'],
// 휴대폰 // 휴대폰
'05': ['mid', 'transactionAmount'], '05': ['mid', 'transactionRequestAmount', 'transactionAmount'],
// 문화상품권 // 문화상품권
'14': ['mid', 'transactionAmount'], '14': ['mid', 'transactionAmount'],
// SSG머니 // SSG머니
@@ -58,32 +60,98 @@ export const AmountInfoSection = ({
'31': ['mid', 'transactionAmount'], '31': ['mid', 'transactionAmount'],
}; };
const checkValue = (val: any) => { const checkValue = (val: any) => {
return (!!val || val === 0); return (!!val || val === 0);
}; };
let newAmountInfo: Record<string, any> | undefined = amountInfo;
const getAmountValue = (k?: string) => {
let value = 0;
let rs = [];
if(!!k){
let value = 0;
if(k === 'kakaoMoneyAmount'
&& newAmountInfo?.partServiceCode === 'E016'
){
value = newAmountInfo['multiPointAmount'] || 0;
}
else if(k === 'kakaoPointAmount'
&& newAmountInfo?.partServiceCode === 'E016'
){
value = newAmountInfo['multiCouponAmount'] || 0;
}
else if(k === 'naverPointAmount'
&& newAmountInfo?.partServiceCode === 'E020'
){
value = newAmountInfo['multiPointAmount'] || 0;
}
else if(k === 'tossMoneyAmount'
&& newAmountInfo?.partServiceCode === 'E025'
){
value = newAmountInfo['multiPointAmount'] || 0;
}
else if(k === 'paycoPointAmount'
&& newAmountInfo?.partServiceCode === 'E015'
){
value = newAmountInfo['multiPointAmount'] || 0;
}
else if(k === 'paycoCouponAmount'
&& newAmountInfo?.partServiceCode === 'E015'
){
value = newAmountInfo['multiCouponAmount'] || 0;
}
else{
if(newAmountInfo){
value = newAmountInfo[k] || 0;
}
}
rs.push(
<NumericFormat
value={ value }
thousandSeparator
displayType="text"
></NumericFormat>
)
}
return rs;
};
const subLi = () => { const subLi = () => {
let rs = []; let rs = [];
if(!!newAmountInfo && !!serviceCode && !!openSubItems[serviceCode]){ if(!!newAmountInfo && !!serviceCode && !!openSubItems[serviceCode]){
for(let i=0;i<openSubItems[serviceCode].length;i++){ for(let i=0;i<openSubItems[serviceCode].length;i++){
let k = openSubItems[serviceCode][i]; let k = openSubItems[serviceCode][i];
if(!!k){ if(!!k){
let name = subItems[k]?.name;
if(serviceCode === '01'){
if(k === 'transactionAmount'){
name = '신용카드금액'
}
if(k === 'transactionRequestAmount'){
name = '승인요청금액';
}
}
rs.push( rs.push(
<li <li
key={`key-amount-item-${i}`} key={`key-amount-item-${i}`}
className="amount-item" className="amount-item"
> >
<span className="label">·&nbsp;&nbsp;{ subItems[k]?.name }</span> <span className="label">·&nbsp;&nbsp;{ name }</span>
<span className="value"> <span className="value">
{ (checkValue(newAmountInfo[k]) && subItems[k]?.type === 'string') && { (checkValue(newAmountInfo[k]) && subItems[k]?.type === 'string') &&
newAmountInfo[k] newAmountInfo[k]
} }
{ (checkValue(newAmountInfo[k]) && subItems[k]?.type === 'number') && { (subItems[k]?.type === 'number') &&
getAmountValue(k)
/*
<NumericFormat <NumericFormat
value={ newAmountInfo[k] } value={ newAmountInfo[k] || 0 }
thousandSeparator thousandSeparator
displayType="text" displayType="text"
></NumericFormat> ></NumericFormat>
*/
} }
{ (checkValue(newAmountInfo[k]) && subItems[k]?.type === 'date') && { (checkValue(newAmountInfo[k]) && subItems[k]?.type === 'date') &&
moment(newAmountInfo[k]).format('YYYY.MM.DD') moment(newAmountInfo[k]).format('YYYY.MM.DD')
@@ -118,11 +186,23 @@ export const AmountInfoSection = ({
<div className="txn-num-group"> <div className="txn-num-group">
<div className="txn-amount"> <div className="txn-amount">
<div className="value"> <div className="value">
<NumericFormat {
value={ amountInfo?.transactionAmount } (serviceCode === '01' || serviceCode === '02' || serviceCode === '03' || serviceCode === '26') &&
thousandSeparator <NumericFormat
displayType="text" value={ amountInfo?.transactionRequestAmount }
></NumericFormat> thousandSeparator
displayType="text"
></NumericFormat>
}
{
(serviceCode === '05' || serviceCode === '14' || serviceCode === '21'
|| serviceCode === '24' || serviceCode === '31') &&
<NumericFormat
value={ amountInfo?.transactionAmount }
thousandSeparator
displayType="text"
></NumericFormat>
}
<span className="unit"></span> <span className="unit"></span>
</div> </div>
<button <button