Files
jongryangje/app/Views/admin/user/index.php
taekyoungc ab40a90f69 feat: 기본코드 bag 목록과 관리자 CRUD 분리
- /bag/code-kinds, /bag/code-details/{ck_idx} 조회 (LoginAuthFilter, Roles::canManageCodeMaster)
- admin에서는 종류·세부 목록 제거, 등록·수정·삭제만 유지 후 bag으로 리다이렉트
- 사이트 메뉴·기본코드 링크 SQL, CSV 동기화 스크립트·README 보강
- 관리자 대시보드: 발주·판매 테이블 미존재 시 통계 비활성화
- 회원 로그인 잠금(mb_login_fail_count, mb_locked_until) 및 관리자 잠금 해제

Made-with: Cursor
2026-03-30 15:07:09 +09:00

80 lines
3.7 KiB
PHP

<?= view('components/print_header', ['printTitle' => '회원 목록']) ?>
<section class="border-b border-gray-300 p-2 shrink-0 bg-control-panel">
<div class="flex flex-wrap items-center justify-between gap-y-2">
<span class="text-sm font-bold text-gray-700">회원 목록</span>
<div class="flex items-center gap-2">
<button onclick="window.print()" class="no-print border border-btn-print-border text-gray-600 px-3 py-1 rounded-sm text-sm hover:bg-gray-50 transition">인쇄</button>
<a href="<?= base_url('admin/users/create') ?>" class="bg-btn-search text-white px-4 py-1.5 rounded-sm flex items-center gap-1 text-sm shadow hover:opacity-90 transition border border-transparent">회원 등록</a>
</div>
</div>
</section>
<div class="border border-gray-300 overflow-auto mt-2">
<table class="w-full data-table">
<thead>
<tr>
<th class="w-16">번호</th>
<th>아이디</th>
<th>이름</th>
<th>이메일</th>
<th>역할</th>
<th>상태</th>
<th>로그인 잠금</th>
<th>가입일</th>
<th>관리</th>
</tr>
</thead>
<tbody class="text-right">
<?php foreach ($list as $row): ?>
<tr>
<td class="text-center"><?= esc($row->mb_idx) ?></td>
<td class="text-left pl-2"><?= esc($row->mb_id) ?></td>
<td class="text-left pl-2"><?= esc($row->mb_name) ?></td>
<td class="text-left pl-2"><?= esc($row->mb_email ?? '') ?></td>
<td class="text-center"><?= esc($roles->getLevelName((int) $row->mb_level)) ?></td>
<td class="text-center">
<?php
$approvalStatus = $approvalMap[(int) $row->mb_idx] ?? null;
if ($approvalStatus === 'pending') {
echo '승인대기';
} elseif ($approvalStatus === 'rejected') {
echo '승인반려';
} else {
echo ((int) $row->mb_state === 1 ? '정상' : ((int) $row->mb_state === 2 ? '정지' : '탈퇴'));
}
?>
</td>
<td class="text-left pl-2 text-sm">
<?php
$until = $row->mb_locked_until ?? null;
$loginLocked = $until !== null && $until !== '' && strtotime((string) $until) > time();
if ($loginLocked) {
echo '잠금~' . esc(date('Y-m-d H:i', strtotime((string) $until)));
} else {
$fail = (int) ($row->mb_login_fail_count ?? 0);
echo $fail > 0 ? '실패 ' . $fail . '회' : '—';
}
?>
</td>
<td class="text-left pl-2"><?= esc($row->mb_regdate ?? '') ?></td>
<td class="text-center">
<?php if ((int) $row->mb_state !== 0): ?>
<?php if ($loginLocked): ?>
<form action="<?= base_url('admin/users/unlock-login/' . $row->mb_idx) ?>" method="POST" class="inline mr-1" onsubmit="return confirm('로그인 잠금을 해제할까요?');">
<?= csrf_field() ?>
<button type="submit" class="text-amber-700 hover:underline">잠금해제</button>
</form>
<?php endif; ?>
<a href="<?= base_url('admin/users/edit/' . $row->mb_idx) ?>" class="text-blue-600 hover:underline">수정</a>
<form action="<?= base_url('admin/users/delete/' . $row->mb_idx) ?>" method="POST" class="inline ml-1" onsubmit="return confirm('탈퇴 처리하시겠습니까?');">
<?= csrf_field() ?>
<button type="submit" class="text-red-600 hover:underline">삭제</button>
</form>
<?php else: ?>—<?php endif; ?>
</td>
</tr>
<?php endforeach; ?>
</tbody>
</table>
</div>
<?php if (isset($pager)): ?><div class="mt-3"><?= $pager->links() ?></div><?php endif; ?>