Files
sam-manage/app/Http/Controllers/Finance/FinanceDashboardController.php
김보곤 a9a9cc4c7e feat:재무 대시보드 최근 거래내역을 바로빌 데이터로 표시
- barobill_bank_transactions 테이블에서 최근 7일 거래 조회
- 입금/출금/잔액 컬럼 표시
- 전체보기 링크를 계좌 입출금내역 페이지로 변경

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-06 08:19:45 +09:00

71 lines
2.2 KiB
PHP

<?php
namespace App\Http\Controllers\Finance;
use App\Http\Controllers\Controller;
use App\Models\Barobill\BankTransaction as BarobillBankTransaction;
use App\Models\Finance\BankAccount;
use App\Models\Finance\FundSchedule;
use App\Services\BankAccountService;
use App\Services\FundScheduleService;
use Illuminate\Contracts\View\View;
class FinanceDashboardController extends Controller
{
public function __construct(
private BankAccountService $bankAccountService,
private FundScheduleService $fundScheduleService
) {}
/**
* 재무 대시보드
*/
public function index(): View
{
// 계좌 요약
$accountSummary = $this->bankAccountService->getSummary();
// 자금 일정 요약
$scheduleSummary = $this->fundScheduleService->getSummary();
// 이번 달 자금 일정 요약
$monthlySummary = $this->fundScheduleService->getMonthlySummary(
now()->year,
now()->month
);
// 향후 7일 자금 일정
$upcomingSchedules = $this->fundScheduleService->getUpcomingSchedules(7);
// 최근 거래내역 (바로빌 - 최근 7일, 최대 10건)
$tenantId = session('selected_tenant_id', 1);
$weekAgo = now()->subDays(7)->format('Ymd');
$today = now()->format('Ymd');
$recentTransactions = BarobillBankTransaction::where('tenant_id', $tenantId)
->whereBetween('trans_date', [$weekAgo, $today])
->orderBy('trans_date', 'desc')
->orderBy('trans_time', 'desc')
->limit(10)
->get();
// 계좌별 잔액
$accountBalances = BankAccount::active()
->ordered()
->get(['id', 'bank_name', 'account_number', 'account_name', 'balance', 'account_type']);
// 은행별 통계
$bankStats = $this->bankAccountService->getStatsByBank();
return view('finance.dashboard', compact(
'accountSummary',
'scheduleSummary',
'monthlySummary',
'upcomingSchedules',
'recentTransactions',
'accountBalances',
'bankStats'
));
}
}