feat: 主布局 + 左侧模式面板

This commit is contained in:
2026-06-17 00:21:19 +08:00
parent 3186502edb
commit 8aacd3bea2
5 changed files with 103 additions and 5 deletions
@@ -0,0 +1,27 @@
import { useQrState } from '../store/qrContext';
import { MODES, MODE_LABELS } from '../types';
export default function ModePanel() {
const { state, dispatch } = useQrState();
return (
<div className="w-48 border-r border-gray-200 dark:border-gray-800 p-3 flex flex-col gap-1 bg-white/60 dark:bg-gray-900/60 backdrop-blur-sm">
<div className="text-xs font-semibold text-gray-400 uppercase tracking-wider mb-2 px-2">
</div>
{MODES.map(mode => (
<button
key={mode}
onClick={() => dispatch({ type: 'SET_MODE', payload: mode })}
className={`px-3 py-2 rounded-lg text-left text-sm transition-all ${
state.mode === mode
? 'bg-gradient-to-r from-blue-500 to-cyan-500 text-white shadow-md shadow-blue-500/20'
: 'text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800'
}`}
>
{MODE_LABELS[mode]}
</button>
))}
</div>
);
}