Files
cc-switch/src/renderer/components/EditProviderModal.tsx
farion1231 c268f962af 重大重构:从字段替换切换到完整配置文件切换系统
- 实现基于文件重命名的供应商切换机制,支持完整settings.json配置切换
- 移除所有向后兼容代码,简化为纯JSON配置模式
- 添加导入当前配置功能,解决首次使用时配置丢失问题
- 移除描述字段,简化用户界面
- 完整的错误处理和回滚机制确保配置安全
- 清理所有调试代码,优化代码质量
2025-08-07 15:48:30 +08:00

143 lines
3.7 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
import React, { useState, useEffect } from 'react'
import { Provider } from '../../shared/types'
import './AddProviderModal.css'
interface EditProviderModalProps {
provider: Provider
onSave: (provider: Provider) => void
onClose: () => void
}
const EditProviderModal: React.FC<EditProviderModalProps> = ({ provider, onSave, onClose }) => {
const [formData, setFormData] = useState({
name: provider.name,
websiteUrl: provider.websiteUrl || '',
settingsConfig: JSON.stringify(provider.settingsConfig, null, 2)
})
const [error, setError] = useState('')
// 初始化时更新表单数据
useEffect(() => {
setFormData({
name: provider.name,
websiteUrl: provider.websiteUrl || '',
settingsConfig: JSON.stringify(provider.settingsConfig, null, 2)
})
}, [provider])
const handleSubmit = (e: React.FormEvent) => {
e.preventDefault()
setError('')
if (!formData.name) {
setError('请填写供应商名称')
return
}
if (!formData.settingsConfig.trim()) {
setError('请填写配置内容')
return
}
let settingsConfig: object
try {
settingsConfig = JSON.parse(formData.settingsConfig)
} catch (err) {
setError('配置JSON格式错误请检查语法')
return
}
onSave({
...provider,
name: formData.name,
websiteUrl: formData.websiteUrl,
settingsConfig,
updatedAt: Date.now()
})
}
const handleChange = (e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {
const { name, value } = e.target
setFormData({
...formData,
[name]: value
})
}
return (
<div className="modal-overlay">
<div className="modal-content">
<h2></h2>
{error && (
<div className="error-message">
{error}
</div>
)}
<form onSubmit={handleSubmit}>
<div className="form-group">
<label htmlFor="name"> *</label>
<input
type="text"
id="name"
name="name"
value={formData.name}
onChange={handleChange}
placeholder="例如Anthropic 官方"
required
autoComplete="off"
/>
</div>
<div className="form-group">
<label htmlFor="websiteUrl"></label>
<input
type="url"
id="websiteUrl"
name="websiteUrl"
value={formData.websiteUrl}
onChange={handleChange}
placeholder="https://example.com可选"
autoComplete="off"
/>
</div>
<div className="form-group">
<label htmlFor="settingsConfig">Claude Code (JSON) *</label>
<textarea
id="settingsConfig"
name="settingsConfig"
value={formData.settingsConfig}
onChange={handleChange}
placeholder={`{
"env": {
"ANTHROPIC_BASE_URL": "https://api.anthropic.com",
"ANTHROPIC_AUTH_TOKEN": "sk-your-api-key-here"
}
}`}
rows={12}
style={{fontFamily: 'monospace', fontSize: '14px'}}
required
/>
<small className="field-hint">
Claude Code settings.json
</small>
</div>
<div className="form-actions">
<button type="button" className="cancel-btn" onClick={onClose}>
</button>
<button type="submit" className="submit-btn">
</button>
</div>
</form>
</div>
</div>
)
}
export default EditProviderModal