관리자 메뉴 카드: URL 줄 제거 + 설명 2줄 표시
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
d3db14a01c
commit
f89d13431a
1 changed files with 63 additions and 27 deletions
|
|
@ -4,7 +4,6 @@ import { api } from '../../api/client'
|
|||
|
||||
function MenuCard({ menu }) {
|
||||
const navigate = useNavigate()
|
||||
// 메뉴 url에서 slug 추출 (/boss-crystal → boss-crystal)
|
||||
const slug = (menu.url || '').replace(/^\/+/, '').split('/')[0]
|
||||
const adminPath = slug ? `/admin/${slug}` : `/admin/menus/${menu.id}`
|
||||
|
||||
|
|
@ -17,14 +16,16 @@ function MenuCard({ menu }) {
|
|||
return (
|
||||
<Link
|
||||
to={adminPath}
|
||||
className="group relative overflow-hidden rounded-2xl border border-white/5 bg-gradient-to-br from-gray-900/80 to-gray-900/40 p-5 hover:border-emerald-500/30 hover:from-emerald-500/5 hover:to-cyan-500/5 transition-all duration-300"
|
||||
className="group relative rounded-2xl border p-5 transition-transform duration-300 hover:scale-[1.02] border-[var(--card-border)]"
|
||||
style={{
|
||||
backgroundImage: 'linear-gradient(to bottom right, var(--card-bg-from), var(--card-bg-to))',
|
||||
boxShadow: 'var(--card-shadow)',
|
||||
}}
|
||||
>
|
||||
<div className="absolute -top-12 -right-12 w-32 h-32 rounded-full bg-emerald-500/0 group-hover:bg-emerald-500/10 blur-2xl transition-all duration-500" />
|
||||
|
||||
{/* 톱니바퀴 - 메뉴 정보 편집 */}
|
||||
<button
|
||||
onClick={handleEditClick}
|
||||
className="absolute top-3 right-3 w-8 h-8 rounded-lg border border-white/5 hover:border-white/20 hover:bg-white/5 text-gray-500 hover:text-gray-300 flex items-center justify-center text-sm transition opacity-0 group-hover:opacity-100 z-10"
|
||||
className="absolute top-3 right-3 w-8 h-8 rounded-lg border flex items-center justify-center text-sm opacity-0 group-hover:opacity-100 transition-opacity z-10 border-[var(--btn-border)] bg-[var(--btn-bg)] hover:bg-[var(--btn-bg-hover)]"
|
||||
style={{ color: 'var(--text-dim)' }}
|
||||
title="메뉴 정보 편집"
|
||||
aria-label="메뉴 정보 편집"
|
||||
>
|
||||
|
|
@ -32,13 +33,20 @@ function MenuCard({ menu }) {
|
|||
</button>
|
||||
|
||||
<div className="relative flex items-start gap-4">
|
||||
<div className="shrink-0 w-12 h-12 rounded-xl bg-gradient-to-br from-gray-800 to-gray-900 border border-white/5 flex items-center justify-center overflow-hidden group-hover:scale-110 group-hover:border-emerald-500/30 transition-all duration-300">
|
||||
<div
|
||||
className="shrink-0 w-12 h-12 rounded-xl border flex items-center justify-center overflow-hidden border-[var(--icon-box-border)]"
|
||||
style={{ backgroundImage: 'linear-gradient(to bottom right, var(--icon-box-from), var(--icon-box-to))' }}
|
||||
>
|
||||
<img src={menu.image?.url || '/default.png'} alt={menu.title} className="w-9 h-9 object-contain" />
|
||||
</div>
|
||||
<div className="flex-1 min-w-0 pr-8">
|
||||
<h3 className="font-semibold text-white group-hover:text-emerald-300 transition truncate">{menu.title}</h3>
|
||||
<p className="text-sm text-gray-400 mt-1 leading-relaxed truncate">{menu.description}</p>
|
||||
<p className="text-xs text-gray-600 mt-1 font-mono truncate">{menu.url}</p>
|
||||
<h3 className="font-medium truncate">{menu.title}</h3>
|
||||
<p
|
||||
className="text-sm mt-1 leading-relaxed line-clamp-2"
|
||||
style={{ color: 'var(--text-muted)' }}
|
||||
>
|
||||
{menu.description}
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</Link>
|
||||
|
|
@ -49,12 +57,16 @@ function AddCard({ to, icon, label }) {
|
|||
return (
|
||||
<Link
|
||||
to={to}
|
||||
className="group flex flex-col items-center justify-center gap-2 rounded-2xl border-2 border-dashed border-white/10 hover:border-emerald-500/40 bg-white/[0.02] hover:bg-emerald-500/5 p-5 min-h-[112px] transition-all"
|
||||
className="group flex flex-col items-center justify-center gap-2 rounded-2xl border-2 border-dashed p-5 min-h-[112px] transition-transform duration-300 hover:scale-[1.02] border-[var(--dashed-border)]"
|
||||
style={{ background: 'var(--skeleton-bg)' }}
|
||||
>
|
||||
<div className="w-10 h-10 rounded-full border border-white/10 group-hover:border-emerald-500/40 flex items-center justify-center text-gray-500 group-hover:text-emerald-400 transition">
|
||||
<div
|
||||
className="w-10 h-10 rounded-full border flex items-center justify-center border-[var(--dashed-border)]"
|
||||
style={{ color: 'var(--text-dim)' }}
|
||||
>
|
||||
{icon}
|
||||
</div>
|
||||
<span className="text-sm text-gray-500 group-hover:text-emerald-300 transition">{label}</span>
|
||||
<span className="text-sm" style={{ color: 'var(--text-dim)' }}>{label}</span>
|
||||
</Link>
|
||||
)
|
||||
}
|
||||
|
|
@ -72,15 +84,24 @@ export default function AdminHome() {
|
|||
<section className="space-y-4">
|
||||
<div className="flex items-center justify-between">
|
||||
<div>
|
||||
<h2 className="text-lg font-semibold">기능 관리</h2>
|
||||
<p className="text-sm text-gray-500 mt-0.5">메뉴 항목을 추가하거나 관리합니다</p>
|
||||
<h2 className="text-lg font-medium">기능 관리</h2>
|
||||
<p
|
||||
className="text-sm mt-0.5"
|
||||
style={{ color: 'var(--text-dim)' }}
|
||||
>
|
||||
메뉴 항목을 추가하거나 관리합니다
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="grid gap-3 sm:grid-cols-2 lg:grid-cols-3">
|
||||
{loading ? (
|
||||
Array.from({ length: 3 }).map((_, i) => (
|
||||
<div key={i} className="h-28 rounded-2xl bg-white/[0.02] animate-pulse" />
|
||||
<div
|
||||
key={i}
|
||||
className="h-28 rounded-2xl animate-pulse"
|
||||
style={{ background: 'var(--skeleton-bg)' }}
|
||||
/>
|
||||
))
|
||||
) : (
|
||||
<>
|
||||
|
|
@ -96,27 +117,41 @@ export default function AdminHome() {
|
|||
{/* 자원 관리 섹션 */}
|
||||
<section className="space-y-4">
|
||||
<div>
|
||||
<h2 className="text-lg font-semibold">자원 관리</h2>
|
||||
<p className="text-sm text-gray-500 mt-0.5">공용 이미지 등 사이트 자원을 관리합니다</p>
|
||||
<h2 className="text-lg font-medium">자원 관리</h2>
|
||||
<p
|
||||
className="text-sm mt-0.5"
|
||||
style={{ color: 'var(--text-dim)' }}
|
||||
>
|
||||
공용 이미지 등 사이트 자원을 관리합니다
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div className="grid gap-3 sm:grid-cols-2 lg:grid-cols-3">
|
||||
<Link
|
||||
to="/admin/images"
|
||||
className="group relative overflow-hidden rounded-2xl border border-white/5 bg-gradient-to-br from-gray-900/80 to-gray-900/40 p-5 hover:border-cyan-500/30 hover:from-cyan-500/5 hover:to-blue-500/5 transition-all duration-300"
|
||||
className="group relative rounded-2xl border p-5 transition-transform duration-300 hover:scale-[1.02] border-[var(--card-border)]"
|
||||
style={{
|
||||
backgroundImage: 'linear-gradient(to bottom right, var(--card-bg-from), var(--card-bg-to))',
|
||||
boxShadow: 'var(--card-shadow)',
|
||||
}}
|
||||
>
|
||||
<div className="absolute -top-12 -right-12 w-32 h-32 rounded-full bg-cyan-500/0 group-hover:bg-cyan-500/10 blur-2xl transition-all duration-500" />
|
||||
<div className="relative flex items-start gap-4">
|
||||
<div className="shrink-0 w-12 h-12 rounded-xl bg-gradient-to-br from-gray-800 to-gray-900 border border-white/5 flex items-center justify-center text-2xl group-hover:scale-110 group-hover:border-cyan-500/30 transition-all duration-300">
|
||||
<div
|
||||
className="shrink-0 w-12 h-12 rounded-xl border flex items-center justify-center text-2xl border-[var(--icon-box-border)]"
|
||||
style={{ backgroundImage: 'linear-gradient(to bottom right, var(--icon-box-from), var(--icon-box-to))' }}
|
||||
>
|
||||
🖼️
|
||||
</div>
|
||||
<div className="flex-1 min-w-0">
|
||||
<h3 className="font-semibold group-hover:text-cyan-300 transition">이미지 관리</h3>
|
||||
<p className="text-sm text-gray-400 mt-1 leading-relaxed">공용 이미지 업로드 및 관리</p>
|
||||
</div>
|
||||
<div className="text-gray-700 group-hover:text-cyan-400 group-hover:translate-x-1 transition-all duration-300">
|
||||
→
|
||||
<h3 className="font-medium">이미지 관리</h3>
|
||||
<p
|
||||
className="text-sm mt-1 leading-relaxed"
|
||||
style={{ color: 'var(--text-muted)' }}
|
||||
>
|
||||
공용 이미지 업로드 및 관리
|
||||
</p>
|
||||
</div>
|
||||
<div style={{ color: 'var(--text-dim)' }}>→</div>
|
||||
</div>
|
||||
</Link>
|
||||
</div>
|
||||
|
|
@ -127,7 +162,8 @@ export default function AdminHome() {
|
|||
<div className="pt-4 text-center">
|
||||
<button
|
||||
onClick={handleLogout}
|
||||
className="text-xs text-gray-600 hover:text-red-400 transition"
|
||||
className="text-xs transition-colors hover:text-red-500"
|
||||
style={{ color: 'var(--text-dim)' }}
|
||||
>
|
||||
관리자 로그아웃
|
||||
</button>
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue