jan/web-app/src/containers/dialogs/EditJsonMCPserver.tsx
Faisal Amir a29152aa76
fix: text component scaling (#5090)
* fix: text component scaling

* chore: update scaling text xs to 0.75
2025-05-25 01:09:07 +07:00

89 lines
2.5 KiB
TypeScript

import { useState, useEffect } from 'react'
import {
Dialog,
DialogContent,
DialogHeader,
DialogTitle,
DialogFooter,
} from '@/components/ui/dialog'
import { Button } from '@/components/ui/button'
import { MCPServerConfig } from '@/hooks/useMCPServers'
import CodeEditor from '@uiw/react-textarea-code-editor'
import '@uiw/react-textarea-code-editor/dist.css'
interface EditJsonMCPserverProps {
open: boolean
onOpenChange: (open: boolean) => void
serverName: string | null // null means editing all servers
initialData: MCPServerConfig | Record<string, MCPServerConfig>
onSave: (data: MCPServerConfig | Record<string, MCPServerConfig>) => void
}
export default function EditJsonMCPserver({
open,
onOpenChange,
serverName,
initialData,
onSave,
}: EditJsonMCPserverProps) {
const [jsonContent, setJsonContent] = useState('')
const [error, setError] = useState<string | null>(null)
// Initialize the editor with the provided data
useEffect(() => {
if (open && initialData) {
try {
setJsonContent(JSON.stringify(initialData, null, 2))
setError(null)
} catch {
setError('Failed to parse initial data')
}
}
}, [open, initialData])
const handleSave = () => {
try {
const parsedData = JSON.parse(jsonContent)
onSave(parsedData)
onOpenChange(false)
setError(null)
} catch {
setError('Invalid JSON format')
}
}
return (
<Dialog open={open} onOpenChange={onOpenChange}>
<DialogContent>
<DialogHeader>
<DialogTitle>
{serverName
? `Edit JSON for MCP Server: ${serverName}`
: 'Edit All MCP Servers JSON'}
</DialogTitle>
</DialogHeader>
<div className="space-y-2">
<div className="border border-main-view-fg/10 rounded-md overflow-hidden">
<CodeEditor
value={jsonContent}
language="json"
placeholder="Enter JSON configuration"
onChange={(e) => setJsonContent(e.target.value)}
style={{
fontFamily: 'ui-monospace',
backgroundColor: 'transparent',
}}
className="w-full !text-sm "
/>
</div>
{error && <div className="text-destructive text-sm">{error}</div>}
</div>
<DialogFooter>
<Button onClick={handleSave}>Save</Button>
</DialogFooter>
</DialogContent>
</Dialog>
)
}