feat: ChordGrid component
This commit is contained in:
47
app/app/components/chord-diagram/chord-grid.tsx
Normal file
47
app/app/components/chord-diagram/chord-grid.tsx
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
import { ChordDiagram } from './chord-diagram';
|
||||||
|
import type { Instrument } from './chord-diagram';
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
chords: string[];
|
||||||
|
instrument: Instrument;
|
||||||
|
onInstrumentChange: (i: Instrument) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function ChordGrid({ chords, instrument, onInstrumentChange }: Props) {
|
||||||
|
if (chords.length === 0) return null;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className="p-3">
|
||||||
|
{/* Instrument toggle */}
|
||||||
|
<div className="flex items-center gap-2 mb-3">
|
||||||
|
<span className="text-xs text-muted-foreground">Chords</span>
|
||||||
|
<div className="flex rounded-md border border-border overflow-hidden ml-auto">
|
||||||
|
<button
|
||||||
|
className={`px-2 py-1 text-xs transition-colors ${instrument === 'piano' ? 'bg-primary text-primary-foreground' : 'text-muted-foreground hover:bg-accent'}`}
|
||||||
|
onClick={() => onInstrumentChange('piano')}
|
||||||
|
>
|
||||||
|
Piano
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
className={`px-2 py-1 text-xs transition-colors ${instrument === 'guitar' ? 'bg-primary text-primary-foreground' : 'text-muted-foreground hover:bg-accent'}`}
|
||||||
|
onClick={() => onInstrumentChange('guitar')}
|
||||||
|
>
|
||||||
|
Guitar
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{/* Chord cards */}
|
||||||
|
<div className="flex flex-wrap gap-2">
|
||||||
|
{chords.map((chord) => (
|
||||||
|
<div
|
||||||
|
key={chord}
|
||||||
|
className="rounded-md border border-border bg-card"
|
||||||
|
>
|
||||||
|
<ChordDiagram chord={chord} instrument={instrument} />
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user