ERP-node/frontend/components/screen/panels/GridPanel.tsx

80 lines
2.7 KiB
TypeScript
Raw Normal View History

2025-09-02 16:18:38 +09:00
import React from "react";
import { Label } from "@/components/ui/label";
import { Checkbox } from "@/components/ui/checkbox";
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
import { Grid3X3 } from "lucide-react";
import { GridSettings } from "@/types/screen-management";
2025-09-02 16:18:38 +09:00
interface GridPanelProps {
gridSettings: GridSettings;
onGridSettingsChange: (settings: GridSettings) => void;
}
/**
* (10px )
*
* :
* - ON/OFF
* - ON/OFF
*
* ( ):
* - 크기: 10px
* - 간격: 10px
*/
export function GridPanel({ gridSettings, onGridSettingsChange }: GridPanelProps) {
const updateSetting = <K extends keyof GridSettings>(key: K, value: GridSettings[K]) => {
2025-09-02 16:18:38 +09:00
onGridSettingsChange({
...gridSettings,
[key]: value,
});
};
return (
<Card className="w-full">
<CardHeader className="space-y-1 pb-3">
<div className="flex items-center gap-2">
<Grid3X3 className="h-4 w-4" />
<CardTitle className="text-base"> </CardTitle>
2025-09-02 16:18:38 +09:00
</div>
</CardHeader>
<CardContent className="space-y-4">
{/* 격자 표시 */}
<div className="flex items-center justify-between">
<Label htmlFor="showGrid" className="flex items-center gap-2 text-sm font-medium">
<Grid3X3 className="h-4 w-4 text-muted-foreground" />
</Label>
<Checkbox
id="showGrid"
checked={gridSettings.showGrid ?? false}
onCheckedChange={(checked) => updateSetting("showGrid", checked as boolean)}
/>
2025-09-02 16:18:38 +09:00
</div>
{/* 격자 스냅 */}
<div className="flex items-center justify-between">
<Label htmlFor="snapToGrid" className="flex items-center gap-2 text-sm font-medium">
<Grid3X3 className="h-4 w-4 text-muted-foreground" />
</Label>
<Checkbox
id="snapToGrid"
checked={gridSettings.snapToGrid}
onCheckedChange={(checked) => updateSetting("snapToGrid", checked as boolean)}
/>
2025-09-02 16:18:38 +09:00
</div>
{/* 격자 정보 (읽기 전용) */}
<div className="mt-4 rounded-md bg-muted p-3 text-xs text-muted-foreground">
<p className="font-medium mb-1">🔧 </p>
<ul className="space-y-0.5">
<li> : <span className="font-semibold">10px </span></li>
<li> 10px </li>
<li> </li>
</ul>
2025-09-02 16:18:38 +09:00
</div>
</CardContent>
</Card>
2025-09-02 16:18:38 +09:00
);
}