From 0622fc2a3455e152fa4fc9da0a45a99ae05175fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EB=B3=B4=EA=B3=A4?= Date: Sat, 7 Mar 2026 23:07:17 +0900 Subject: [PATCH] =?UTF-8?q?feat:=20[planning-design]=20=EB=A9=94=EB=89=B4?= =?UTF-8?q?=20=ED=8A=B8=EB=A6=AC=20=ED=8E=B8=EC=A7=91=20=EB=AA=A8=EB=8B=AC?= =?UTF-8?q?=20UI=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - JSON prompt 방식 → 트리구조 모달 UI로 개선 - 상위/하위 메뉴 추가, 삭제, 이름 편집 지원 - 드래그 앤 드롭으로 메뉴 순서 변경 가능 - 접기/펼치기 토글 지원 --- .../views/rd/planning-design/index.blade.php | 193 +++++++++++++++++- 1 file changed, 185 insertions(+), 8 deletions(-) diff --git a/resources/views/rd/planning-design/index.blade.php b/resources/views/rd/planning-design/index.blade.php index e32f44dc..89e01318 100644 --- a/resources/views/rd/planning-design/index.blade.php +++ b/resources/views/rd/planning-design/index.blade.php @@ -621,6 +621,57 @@ } .sb-desc-remove:hover { color: #ef4444; background: #fef2f2; } +/* Menu Tree Editor Modal */ +.sb-menu-modal-overlay { + position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0.4); + display: flex; align-items: center; justify-content: center; +} +.sb-menu-modal { + background: #fff; border-radius: 12px; width: 480px; max-height: 80vh; + display: flex; flex-direction: column; box-shadow: 0 25px 50px rgba(0,0,0,0.15); +} +.sb-menu-modal-header { + display: flex; align-items: center; justify-content: space-between; + padding: 16px 20px; border-bottom: 1px solid #e2e8f0; +} +.sb-menu-modal-header h3 { font-size: 15px; font-weight: 700; color: #1e293b; margin: 0; } +.sb-menu-modal-body { flex: 1; overflow-y: auto; padding: 16px 20px; } +.sb-menu-modal-footer { + display: flex; justify-content: flex-end; gap: 8px; + padding: 12px 20px; border-top: 1px solid #e2e8f0; +} +.sb-mt-item { + display: flex; align-items: center; gap: 6px; padding: 5px 0; + border-bottom: 1px solid #f8fafc; +} +.sb-mt-item:hover { background: #f8fafc; border-radius: 6px; } +.sb-mt-drag { + cursor: grab; color: #cbd5e1; flex-shrink: 0; font-size: 14px; padding: 0 2px; + user-select: none; +} +.sb-mt-drag:active { cursor: grabbing; } +.sb-mt-icon { flex-shrink: 0; width: 18px; text-align: center; color: #94a3b8; font-size: 11px; cursor: pointer; } +.sb-mt-icon:hover { color: #475569; } +.sb-mt-name { + flex: 1; border: none; outline: none; font-size: 13px; padding: 4px 6px; + border-radius: 4px; color: #334155; background: transparent; +} +.sb-mt-name:focus { background: #f1f5f9; } +.sb-mt-actions { display: flex; gap: 2px; flex-shrink: 0; } +.sb-mt-btn { + width: 24px; height: 24px; border: none; background: transparent; + color: #94a3b8; cursor: pointer; border-radius: 4px; font-size: 13px; + display: flex; align-items: center; justify-content: center; +} +.sb-mt-btn:hover { background: #f1f5f9; color: #475569; } +.sb-mt-btn.danger:hover { background: #fef2f2; color: #ef4444; } +.sb-mt-children { padding-left: 24px; border-left: 2px solid #e2e8f0; margin-left: 10px; } +.sb-mt-add-root { + display: flex; align-items: center; gap: 6px; padding: 10px 0 4px; + font-size: 12px; color: var(--pc-indigo); cursor: pointer; font-weight: 500; +} +.sb-mt-add-root:hover { color: #4f46e5; } + /* Phase Swimlane (Timeline View) */ .pc-swimlane { position: absolute; top: 0; @@ -1233,6 +1284,61 @@ {{-- /Main Content Area --}} + {{-- Menu Tree Editor Modal --}} + + {{-- Node Detail Modal --}}