- 부가서비스 공통 ListDateGroupProps,ListItemProps 추가

This commit is contained in:
HyeonJongKim
2025-09-17 11:17:06 +09:00
parent 56ef85e3f3
commit 4f97767999
29 changed files with 407 additions and 191 deletions

View File

@@ -0,0 +1,107 @@
import { motion } from 'framer-motion';
import { SettlementAgencyBottomAgreeProps } from '../../model/types';
import { IMAGE_ROOT } from '@/shared/constants/common';
export const SettlementAgencyBottomAgree = ({
bottomAgreeOn,
setBottomAgreeOn
}: SettlementAgencyBottomAgreeProps) => {
const variants = {
hidden: { y: '100%' },
visible: { y: '0%' },
};
const onClickToClose = () => {
setBottomAgreeOn(false);
};
const onClickToSaveSettlementAgencyAgree = () => {
};
return (
<>
{bottomAgreeOn &&
<div className="bg-dim"></div>
}
<motion.div
className="bottomsheet"
initial="hidden"
animate={ (bottomAgreeOn)? 'visible': 'hidden' }
variants={ variants }
transition={{ duration: 0.5 }}
>
<div className="bottomsheet-header">
<div className="bottomsheet-title">
<h2> </h2>
<button
className="close-btn"
type="button"
>
<img
src={ IMAGE_ROOT + '/ico_close.svg' }
alt="닫기"
onClick={ () => onClickToClose() }
/>
</button>
</div>
</div>
<div className="agree-section">
<div className="agree-desc pb10"> <br/>.</div>
<div className="agree-desc pb10"> , .</div>
<div className="agree-desc pb16"> · <br/> .</div>
<div className="agree-desc pb16"> // , (10 ·) .</div>
<div className="agree-desc pb16"> (, ) · .</div>
<div className="sheet-divider"></div>
<div className="agree-radio-group">
<div className="check_box">
<input
id="r1"
className="checkbox"
type="radio"
name="r"
/>
<label
className="gtr"
htmlFor="r1"
></label>
</div>
<div className="check_box">
<input
id="r2"
className="checkbox"
type="radio"
name="r"
/>
<label
className="gtr"
htmlFor="r2"
></label>
</div>
<div className="check_box">
<input
className="checkbox"
id="r3"
type="radio"
name="r"
/>
<label
className="gtr"
htmlFor="r3"
></label>
</div>
</div>
</div>
<div className="bottomsheet-footer">
<button
className="btn-50 btn-blue flex-1"
type="button"
onClick={ () => onClickToSaveSettlementAgencyAgree() }
></button>
</div>
</motion.div>
</>
);
};

View File

@@ -0,0 +1,206 @@
import { PATHS } from '@/shared/constants/paths';
import { useNavigate } from '@/shared/lib/hooks/use-navigate';
import { IMAGE_ROOT } from '@/shared/constants/common';
export const SettlementAgencyDepositWrap = () => {
const { navigate } = useNavigate();
const onClickRegister = () => {
navigate(PATHS.additionalService.settlementAgency.register);
};
return (
<>
<div className="summary-section pt-30">
<div className="credit-controls">
<div>
<input
className="credit-period"
type="text"
value="2025.06.01 ~ 2025.06.31"
readOnly={ true }
/>
<button className="filter-btn">
<img
src={ IMAGE_ROOT + '/ico_setting.svg' }
alt="검색옵션"
/>
</button>
</div>
<button className="download-btn">
<img
src={ IMAGE_ROOT + '/ico_download.svg' }
alt="다운로드"
/>
</button>
</div>
<div className="credit-summary">
<div className="row">
<span className="label"> </span>
<strong className="amount22">83,745,200</strong>
</div>
<div className="row">
<span className="label"> </span>
<strong className="amount19">534,407</strong>
</div>
</div>
</div>
<div className="filter-section">
<div className="sort-options">
<button className="sort-btn active"></button>
<span className="sort-divider">|</span>
<button className="sort-btn"></button>
</div>
<div>
<div className="full-menu-keywords no-padding">
<span className="keyword-tag active"></span>
<span className="keyword-tag"></span>
<span className="keyword-tag"></span>
</div>
</div>
</div>
<div className="transaction-list">
<div className="">
<div className="date-header">25.06.08()</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot gray"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot gray"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot gray"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">( )</div>
<div className="transaction-details">
<span>10:10:00</span>
</div>
</div>
<div className="transaction-amount two">
<span className="amount">5,254,000</span>
<span className="unit">잔액 : 1,58,332</span>
</div>
</div>
</div>
</div>
</>
);
};

View File

@@ -0,0 +1,167 @@
import { PATHS } from '@/shared/constants/paths';
import { useNavigate } from '@/shared/lib/hooks/use-navigate';
import { IMAGE_ROOT } from '@/shared/constants/common';
export const SettlementAgencyManageWrap = () => {
const { navigate } = useNavigate();
const onClickToRegister = () => {
navigate(PATHS.additionalService.settlementAgency.register);
};
const onClickToDetail = () => {
navigate(PATHS.additionalService.settlementAgency.detail);
};
return (
<>
<section className="summary-section pt-30">
<div className="credit-controls">
<div>
<input
className="credit-period"
type="text"
value="2025.06.01 ~ 2025.06.30"
readOnly={ true }
/>
<button
className="filter-btn"
aria-label="필터"
>
<img
src={ IMAGE_ROOT + '/ico_setting.svg' }
alt="검색옵션"
/>
</button>
</div>
<button
className="download-btn"
aria-label="다운로드"
>
<img
src={ IMAGE_ROOT + '/ico_download.svg' }
alt="다운로드"
/>
</button>
</div>
<div className="account-frame">
<div className="credit-summary">
<div className="row horizontal">
<span className="label"> </span>
<span className="amount20">83,745,200<span className="unit"></span></span>
<span className="count.horizontal">(2,745)</span>
</div>
<div className="summary-amount divTop">
<span className="amount-text states"> </span>
<button>
<img
src={ IMAGE_ROOT + '/ico_divTop_arrow.svg' }
alt="화살표"
/>
</button>
</div>
</div>
<div className="summary-extend">
<ul className="summary-amount-list bdr-6">
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">50<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">150<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">0<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"> </span>
<span className="value">5<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">300<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">0<span className="unit"> </span></span>
</li>
<li className="summary-amount-item">
<span className="label"></span>
<span className="value">0<span className="unit"> </span></span>
</li>
</ul>
</div>
</div>
</section>
<section className="filter-section">
<div className="sort-options">
<button className="sort-btn active"></button>
<span className="sort-divider">|</span>
<button className="sort-btn"></button>
</div>
<div className="excrow">
<div className="notice-tabs sub">
<button className="tab36 on"></button>
<button className="tab36"></button>
<button className="tab36"></button>
</div>
</div>
</section>
<section className="transaction-list">
<div className="date-header">25.06.08()</div>
<div
className="transaction-item approved"
onClick={ () => onClickToDetail() }
>
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">AB25061012 (BACK001)</div>
<div className="transaction-details">
<span>정산일 : 06.08</span>
<span className="separator"></span>
<span></span>
</div>
</div>
<div className="transaction-amount">10,000,000</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot blue"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">AB25061012 (BACK001)</div>
<div className="transaction-details">
<span>정산일 : 06.08</span>
<span className="separator"></span>
<span></span>
</div>
</div>
<div className="transaction-amount">10,000,000</div>
</div>
<div className="transaction-item approved">
<div className="transaction-status">
<div className="status-dot gray"></div>
</div>
<div className="transaction-content">
<div className="transaction-title">AB25061012 (BACK001)</div>
<div className="transaction-details">
<span>정산일 : 06.08</span>
<span className="separator"></span>
<span></span>
</div>
</div>
<div className="transaction-amount">10,000,000</div>
</div>
</section>
<div className="apply-row">
<button
className ="btn-50 btn-blue flex-1"
onClick={ () => onClickToRegister() }
> </button>
</div>
</>
);
};

View File

@@ -0,0 +1,83 @@
import { PATHS } from '@/shared/constants/paths';
import { useNavigate } from '@/shared/lib/hooks/use-navigate';
import { IMAGE_ROOT } from '@/shared/constants/common';
export const SettlementAgencyMemberWrap = () => {
const { navigate } = useNavigate();
const onClickRegister = () => {
navigate(PATHS.additionalService.settlementAgency.register);
};
return (
<>
<div className="store-section">
<div className="store-filter">
<div className="store-input">
<select className="flex-1">
<option>nictest001m</option>
</select>
</div>
</div>
<div className="detail-divider"></div>
<div className="store-list">
<div className="store-item">
<div className="store-line">
<span className="dot blue"></span>
<div className="store-name">BACK5(5)</div>
<ul className="store-detail">
<li className="line">수수료 : 1%, </li>
<li className="line"> 여부 : 과세, </li>
<li className="line">정산일 : 매월 15</li>
</ul>
</div>
</div>
<div className="store-item">
<div className="store-line">
<span className="dot blue"></span>
<div className="store-name">BACK5(5)</div>
<ul className="store-detail">
<li className="line">수수료 : 1%, </li>
<li className="line"> 여부 : 과세, </li>
<li className="line">정산일 : 매월 15</li>
</ul>
</div>
</div>
<div className="store-item">
<div className="store-line">
<span className="dot blue"></span>
<div className="store-name">BACK5(5)</div>
<ul className="store-detail">
<li className="line">수수료 : 1%, </li>
<li className="line"> 여부 : 과세, </li>
<li className="line">정산일 : 매월 15</li>
</ul>
</div>
</div>
<div className="store-item">
<div className="store-line">
<span className="dot blue"></span>
<div className="store-name">BACK5(5)</div>
<ul className="store-detail">
<li className="line">수수료 : 1%, </li>
<li className="line"> 여부 : 과세, </li>
<li className="line">정산일 : 매월 15</li>
</ul>
</div>
</div>
<div className="store-item">
<div className="store-line">
<span className="dot blue"></span>
<div className="store-name">BACK5(5)</div>
<ul className="store-detail">
<li className="line">수수료 : 1%, </li>
<li className="line"> 여부 : 과세, </li>
<li className="line">정산일 : 매월 15</li>
</ul>
</div>
</div>
</div>
</div>
</>
);
};

View File

@@ -0,0 +1,44 @@
import { PATHS } from '@/shared/constants/paths';
import { useNavigate } from '@/shared/lib/hooks/use-navigate';
import {
SettlementAgencyTabKeys,
SettlementAgencyTabProps
} from '../../model/types';
export const SettlementAgencyTab = ({
activeTab
}: SettlementAgencyTabProps) => {
const { navigate } = useNavigate();
const onClickToNavigation = (tab: SettlementAgencyTabKeys) => {
if(activeTab !== tab){
if(tab === SettlementAgencyTabKeys.Manage){
navigate(PATHS.additionalService.settlementAgency.manage);
}
else if(tab === SettlementAgencyTabKeys.Deposit){
navigate(PATHS.additionalService.settlementAgency.deposit);
}
else if(tab === SettlementAgencyTabKeys.Member){
navigate(PATHS.additionalService.settlementAgency.member);
}
}
};
return (
<>
<div className="subTab three">
<button
className={`subtab-btn ${(activeTab === SettlementAgencyTabKeys.Manage)? 'active': ''}` }
onClick={ () => onClickToNavigation(SettlementAgencyTabKeys.Manage) }
> </button>
<button
className={`subtab-btn ${(activeTab === SettlementAgencyTabKeys.Deposit)? 'active': ''}` }
onClick={ () => onClickToNavigation(SettlementAgencyTabKeys.Deposit) }
> </button>
<button
className={`subtab-btn ${(activeTab === SettlementAgencyTabKeys.Member)? 'active': ''}` }
onClick={ () => onClickToNavigation(SettlementAgencyTabKeys.Member) }
></button>
</div>
</>
);
};