File size: 11,955 Bytes
b7bd3ec
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
// Internationalization (i18n) support
const translations = {
    en: {
        // Navigation
        'nav.title': 'HF Space Deployer',
        'nav.theme': 'Toggle Theme',
        'nav.language': 'Language',
        
        // Hero Section
        'hero.title': 'One-Click Deploy',
        'hero.subtitle': 'Deploy to HuggingFace Spaces instantly',
        'hero.deployTime': 'Deploy Time',
        'hero.freeHosting': 'Free Hosting',
        'hero.minutes': '2-5min',
        'hero.percentage': '100%',
        
        // Features
        'feature.fast.title': 'Lightning Fast',
        'feature.fast.desc': 'Deploy from Git in minutes',
        'feature.secure.title': 'Secure',
        'feature.secure.desc': 'Full control with your token',
        'feature.monitor.title': 'Real-time',
        'feature.monitor.desc': 'Live deployment status',
        
        // Form
        'form.title': 'Configuration',
        'form.token': 'HuggingFace Token',
        'form.token.placeholder': 'hf_...',
        'form.token.get': 'Get Token',
        'form.token.hint': 'Write permission required',
        'form.token.toggle': 'Toggle visibility',
        'form.token.clear': 'Clear cached token',
        'form.token.cleared': 'Token cache cleared',
        'form.repo': 'Git Repository',
        'form.repo.placeholder': 'https://github.com/user/repo.git',
        'form.repo.hint': 'GitHub, GitLab, etc.',
        'form.space': 'Space Name',
        'form.space.placeholder': 'my-app',
        'form.space.hint': 'Letters, numbers, hyphens only',
        'form.desc': 'Description',
        'form.desc.placeholder': 'Brief description...',
        'form.advanced': 'Advanced',
        'form.deployPath': 'Deploy Path',
        'form.deployPath.placeholder': '/',
        'form.deployPath.hint': 'Subdirectory to deploy (default: root)',
        'form.port': 'Port',
        'form.private': 'Private Space',
        'form.env': 'Environment Variables',
        'form.env.placeholder': 'KEY1=value\nKEY2=value',
        'form.env.hint': 'One per line',
        'form.submit': 'Deploy',
        
        // Requirements
        'req.title': 'Requirements',
        'req.dockerfile': 'Repository must contain Dockerfile',
        'req.token': 'Token needs write permissions',
        'req.time': 'Deployment takes 2-5 minutes',
        'req.docker': 'Supports Dockerized apps',
        
        // Pro Tips
        'tips.title': 'Tips',
        'tips.test': 'Test Dockerfile locally',
        'tips.env': 'Use env vars for secrets',
        'tips.size': 'Keep image size small',
        'tips.limits': 'Check HF resource limits',
        
        // Status Page
        'status.title': 'Deployment Status',
        'status.taskId': 'Task ID',
        'status.initializing': 'Initializing...',
        'status.preparing': 'Preparing your Space...',
        'status.queued': 'Queued',
        'status.queued.desc': 'Request received',
        'status.progress': 'In Progress',
        'status.progress.desc': 'Building and deploying...',
        'status.success': 'Success!',
        'status.success.desc': 'Your Space is live',
        'status.failed': 'Failed',
        'status.failed.desc': 'Deployment error',
        'status.url': 'Space URL',
        'status.visit': 'Visit Space',
        'status.error': 'Error Details',
        'status.troubleshoot': 'Troubleshooting',
        'status.newDeploy': 'New Deploy',
        'status.refresh': 'Refresh',
        'status.copy': 'Copy',
        'status.autoRefresh': 'Auto-refresh every 2s',
        
        // Loading
        'loading.title': 'Deploying...',
        'loading.desc': 'Please wait...',
        
        // Configuration Import/Export
        'config.import': 'Import',
        'config.export': 'Export',
        'config.import.title': 'Import Configuration',
        'config.import.info': 'Paste your configuration JSON or share configuration URL',
        'config.import.label': 'Configuration JSON',
        'config.import.placeholder': '{"space_name": "my-app", "git_repo_url": "https://github.com/..."}',
        'config.import.apply': 'Apply Configuration',
        'config.import.success': 'Configuration imported successfully',
        'config.import.error': 'Failed to import configuration',
        'config.import.empty': 'Please enter configuration JSON',
        'config.import.invalid': 'Invalid configuration format',
        'config.export.title': 'Export Configuration',
        'config.export.info': 'Configuration exported successfully',
        'config.export.label': 'Configuration JSON',
        'config.export.url': 'Share URL',
        'config.export.save': 'Save as File',
        'config.export.saved': 'Configuration saved to file',
        'config.copy': 'Copy',
        'config.copied': 'Configuration copied!',
        'config.url.copied': 'Share URL copied!',
        'config.cancel': 'Cancel',
        'config.close': 'Close',
        
        // Footer
        'footer.title': 'HF Space Deployer',
        'footer.desc': 'Quick deployment tool',
        
        // Copied toast
        'toast.copied': 'Copied!',
        'toast.copyFailed': 'Copy failed',
        'toast.deploySuccess': 'Deployment successful!',
        'toast.deployFailed': 'Deployment failed',
        'toast.requestFailed': 'Request failed'
    },
    
    zh: {
        // Navigation
        'nav.title': 'HF Space 部署器',
        'nav.theme': '切换主题',
        'nav.language': '语言',
        
        // Hero Section
        'hero.title': '一键部署',
        'hero.subtitle': '快速部署到 HuggingFace Spaces',
        'hero.deployTime': '部署时间',
        'hero.freeHosting': '免费托管',
        'hero.minutes': '2-5分钟',
        'hero.percentage': '100%',
        
        // Features
        'feature.fast.title': '极速部署',
        'feature.fast.desc': '分钟级 Git 部署',
        'feature.secure.title': '安全可靠',
        'feature.secure.desc': 'Token 完全掌控',
        'feature.monitor.title': '实时监控',
        'feature.monitor.desc': '部署状态实时更新',
        
        // Form
        'form.title': '配置设置',
        'form.token': 'HuggingFace 令牌',
        'form.token.placeholder': 'hf_...',
        'form.token.get': '获取令牌',
        'form.token.hint': '需要写入权限',
        'form.token.toggle': '切换可见性',
        'form.token.clear': '清除缓存令牌',
        'form.token.cleared': '令牌缓存已清除',
        'form.repo': 'Git 仓库',
        'form.repo.placeholder': 'https://github.com/用户名/仓库名.git',
        'form.repo.hint': '支持 GitHub、GitLab 等',
        'form.space': '空间名称',
        'form.space.placeholder': 'my-app',
        'form.space.hint': '仅限字母、数字、连字符',
        'form.desc': '描述',
        'form.desc.placeholder': '简短描述...',
        'form.advanced': '高级设置',
        'form.deployPath': '部署路径',
        'form.deployPath.placeholder': '/',
        'form.deployPath.hint': '要部署的子目录(默认:根目录)',
        'form.port': '端口',
        'form.private': '私有空间',
        'form.env': '环境变量',
        'form.env.placeholder': 'KEY1=value\nKEY2=value',
        'form.env.hint': '每行一个',
        'form.submit': '部署',
        
        // Requirements
        'req.title': '要求',
        'req.dockerfile': '仓库需包含 Dockerfile',
        'req.token': '令牌需要写入权限',
        'req.time': '部署需要 2-5 分钟',
        'req.docker': '支持 Docker 应用',
        
        // Pro Tips
        'tips.title': '提示',
        'tips.test': '先本地测试 Dockerfile',
        'tips.env': '敏感数据用环境变量',
        'tips.size': '保持镜像体积小',
        'tips.limits': '检查 HF 资源限制',
        
        // Status Page
        'status.title': '部署状态',
        'status.taskId': '任务 ID',
        'status.initializing': '初始化中...',
        'status.preparing': '准备 Space 中...',
        'status.queued': '排队中',
        'status.queued.desc': '已接收请求',
        'status.progress': '进行中',
        'status.progress.desc': '构建部署中...',
        'status.success': '成功!',
        'status.success.desc': 'Space 已上线',
        'status.failed': '失败',
        'status.failed.desc': '部署出错',
        'status.url': 'Space 地址',
        'status.visit': '访问 Space',
        'status.error': '错误详情',
        'status.troubleshoot': '故障排除',
        'status.newDeploy': '新建部署',
        'status.refresh': '刷新',
        'status.copy': '复制',
        'status.autoRefresh': '每2秒自动刷新',
        
        // Loading
        'loading.title': '部署中...',
        'loading.desc': '请稍候...',
        
        // Configuration Import/Export
        'config.import': '导入',
        'config.export': '导出',
        'config.import.title': '导入配置',
        'config.import.info': '粘贴配置 JSON 或分享配置链接',
        'config.import.label': '配置 JSON',
        'config.import.placeholder': '{"space_name": "my-app", "git_repo_url": "https://github.com/..."}',
        'config.import.apply': '应用配置',
        'config.import.success': '配置导入成功',
        'config.import.error': '配置导入失败',
        'config.import.empty': '请输入配置 JSON',
        'config.import.invalid': '配置格式无效',
        'config.export.title': '导出配置',
        'config.export.info': '配置导出成功',
        'config.export.label': '配置 JSON',
        'config.export.url': '分享链接',
        'config.export.save': '保存为文件',
        'config.export.saved': '配置已保存到文件',
        'config.copy': '复制',
        'config.copied': '配置已复制!',
        'config.url.copied': '分享链接已复制!',
        'config.cancel': '取消',
        'config.close': '关闭',
        
        // Footer
        'footer.title': 'HF Space 部署器',
        'footer.desc': '快速部署工具',
        
        // Copied toast
        'toast.copied': '已复制!',
        'toast.copyFailed': '复制失败',
        'toast.deploySuccess': '部署成功!',
        'toast.deployFailed': '部署失败',
        'toast.requestFailed': '请求失败'
    }
};

// Current language
let currentLang = localStorage.getItem('language') || 'en';

// Translate function
function t(key) {
    return translations[currentLang][key] || translations['en'][key] || key;
}

// Set language
function setLanguage(lang) {
    currentLang = lang;
    localStorage.setItem('language', lang);
    updatePageTranslations();
}

// Toggle language
function toggleLanguage() {
    const newLang = currentLang === 'en' ? 'zh' : 'en';
    setLanguage(newLang);
}

// Update all translations on page
function updatePageTranslations() {
    // Update all elements with data-i18n attribute
    document.querySelectorAll('[data-i18n]').forEach(element => {
        const key = element.getAttribute('data-i18n');
        element.textContent = t(key);
    });
    
    // Update all elements with data-i18n-placeholder attribute
    document.querySelectorAll('[data-i18n-placeholder]').forEach(element => {
        const key = element.getAttribute('data-i18n-placeholder');
        element.placeholder = t(key);
    });
    
    // Update all elements with data-i18n-title attribute
    document.querySelectorAll('[data-i18n-title]').forEach(element => {
        const key = element.getAttribute('data-i18n-title');
        element.title = t(key);
    });
    
    // Update document title
    document.title = t('nav.title');
    
    // Dispatch custom event
    document.dispatchEvent(new Event('languageChanged'));
}

// Initialize on page load
document.addEventListener('DOMContentLoaded', () => {
    updatePageTranslations();
});