Akimitsujiro commited on
Commit
9bb55c9
·
verified ·
1 Parent(s): 01b239a

Update src/App.jsx

Browse files
Files changed (1) hide show
  1. src/App.jsx +51 -30
src/App.jsx CHANGED
@@ -4,8 +4,11 @@ import {
4
  Settings, Layers, Cpu, Maximize, Zap, Wifi, WifiOff, ChevronDown, ChevronUp, Play, RefreshCw, Link as LinkIcon
5
  } from 'lucide-react';
6
 
7
- // Link mặc định (Nếu sai, bạn thể nhập đè trên giao diện web)
8
- const DEFAULT_API_URL = "https://thay-link-ngrok-cua-ban-vao-day.ngrok-free.app";
 
 
 
9
 
10
  const SAMPLERS = [
11
  "Euler a", "Euler", "LMS", "Heun", "DPM2", "DPM2 a",
@@ -16,8 +19,6 @@ const SAMPLERS = [
16
  const App = () => {
17
  // --- STATE ---
18
  const [apiUrl, setApiUrl] = useState(DEFAULT_API_URL);
19
- const [isCustomUrl, setIsCustomUrl] = useState(false); // Check nếu user đang nhập tay
20
-
21
  const [prompt, setPrompt] = useState('A futuristic city with neon lights, cyberpunk style');
22
  const [negPrompt, setNegPrompt] = useState('blurry, bad quality, watermark, text, ugly, distorted, nsfw');
23
 
@@ -52,33 +53,53 @@ const App = () => {
52
  setLogs(prev => [`[${timestamp}] ${message}`, ...prev].slice(0, 50));
53
  };
54
 
55
- // Hàm kết nối server (dùng cho cả lúc mới vào và lúc bấm nút Connect)
56
- const connectToServer = async (urlToConnect) => {
57
- const targetUrl = urlToConnect || apiUrl;
58
-
59
- // Nếu vẫn là link mặc định chưa sửa thì bỏ qua
60
- if (targetUrl.includes("thay-link")) {
61
- setServerStatus('disconnected');
62
- return;
63
- }
64
-
65
- // Clean URL (bỏ dấu / ở cuối nếu có)
66
- const cleanUrl = targetUrl.replace(/\/$/, "");
67
- if (cleanUrl !== apiUrl) setApiUrl(cleanUrl);
68
-
69
  setFetchingInfo(true);
70
  setError('');
71
-
 
72
  try {
73
- addLog(`Connecting to: ${cleanUrl}...`);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
74
 
 
75
  const res = await fetch(`${cleanUrl}/info`, {
76
  headers: { "ngrok-skip-browser-warning": "69420" }
77
  });
78
 
79
  if (!res.ok) {
80
  const text = await res.text();
81
- throw new Error(`Server Error (${res.status}): ${text.slice(0, 50)}...`);
82
  }
83
 
84
  const data = await res.json();
@@ -92,13 +113,13 @@ const App = () => {
92
  if (data.upscalers?.length > 0) setUpscalers(data.upscalers);
93
 
94
  setServerStatus('connected');
95
- addLog(`✅ Connected! Found ${data.models.length} checkpoints.`);
96
 
97
  } catch (err) {
98
  console.error(err);
99
  setServerStatus('disconnected');
100
  setError(err.message);
101
- addLog(`❌ Connection Failed: ${err.message}`);
102
  } finally {
103
  setFetchingInfo(false);
104
  }
@@ -111,13 +132,13 @@ const App = () => {
111
 
112
  const handleGenerate = async () => {
113
  if (serverStatus !== 'connected') {
114
- setError('Please connect to server first!');
115
  return;
116
  }
117
 
118
  setLoading(true);
119
  setError('');
120
- addLog(`🎨 Generating...`);
121
 
122
  try {
123
  let upscalerValue = "None";
@@ -139,17 +160,17 @@ const App = () => {
139
  body: JSON.stringify(payload),
140
  });
141
 
142
- if (!response.ok) throw new Error(`Server Error: ${response.status}`);
143
  const data = await response.json();
144
 
145
  if (data.image) {
146
  setGeneratedImage(data.image);
147
- addLog('✨ Image finished!');
148
  }
149
 
150
  } catch (err) {
151
  setError(err.message);
152
- addLog(`Error: ${err.message}`);
153
  } finally {
154
  setLoading(false);
155
  }
@@ -197,14 +218,14 @@ const App = () => {
197
  className="flex-1 bg-slate-950 border border-slate-700 text-[10px] rounded-lg px-2 py-2 outline-none focus:border-red-500 font-mono"
198
  />
199
  <button
200
- onClick={() => connectToServer()}
201
  disabled={fetchingInfo}
202
  className="bg-red-500/20 hover:bg-red-500/30 text-red-400 border border-red-500/50 rounded-lg px-3 py-2 transition-colors"
203
  >
204
  {fetchingInfo ? <Loader2 className="w-4 h-4 animate-spin" /> : <RefreshCw className="w-4 h-4" />}
205
  </button>
206
  </div>
207
- <p className="text-[10px] text-slate-500 mt-2">Paste link Ngrok từ Kaggle vào đây bấm Connect.</p>
208
  </section>
209
  )}
210
 
 
4
  Settings, Layers, Cpu, Maximize, Zap, Wifi, WifiOff, ChevronDown, ChevronUp, Play, RefreshCw, Link as LinkIcon
5
  } from 'lucide-react';
6
 
7
+ // 👇 LINK DATABASE CỦA BẠN (Thay link Firebase của bạn vào đây)
8
+ const FIREBASE_DB_URL = "https://uploadlink-28426-default-rtdb.firebaseio.com/api_url.json";
9
+
10
+ // Link dự phòng (Local hoặc mặc định)
11
+ const DEFAULT_API_URL = "pretty-dory-noble.ngrok-free.app";
12
 
13
  const SAMPLERS = [
14
  "Euler a", "Euler", "LMS", "Heun", "DPM2", "DPM2 a",
 
19
  const App = () => {
20
  // --- STATE ---
21
  const [apiUrl, setApiUrl] = useState(DEFAULT_API_URL);
 
 
22
  const [prompt, setPrompt] = useState('A futuristic city with neon lights, cyberpunk style');
23
  const [negPrompt, setNegPrompt] = useState('blurry, bad quality, watermark, text, ugly, distorted, nsfw');
24
 
 
53
  setLogs(prev => [`[${timestamp}] ${message}`, ...prev].slice(0, 50));
54
  };
55
 
56
+ // Hàm kết nối server (Logic Firebase + Manual)
57
+ const connectToServer = async (manualUrl = null) => {
 
 
 
 
 
 
 
 
 
 
 
 
58
  setFetchingInfo(true);
59
  setError('');
60
+ let targetUrl = manualUrl || apiUrl;
61
+
62
  try {
63
+ // 1. Nếu không nhập tay, thử lấy từ Firebase trước
64
+ if (!manualUrl && FIREBASE_DB_URL.includes("firebaseio.com")) {
65
+ addLog("☁️ Đang lấy link từ Firebase...");
66
+ try {
67
+ const fireRes = await fetch(FIREBASE_DB_URL);
68
+ if (fireRes.ok) {
69
+ const fireUrl = await fireRes.json();
70
+ if (fireUrl && fireUrl.startsWith("http")) {
71
+ targetUrl = fireUrl;
72
+ addLog(`🔗 Tìm thấy server: ${fireUrl}`);
73
+ }
74
+ }
75
+ } catch (e) {
76
+ console.warn("Lỗi Firebase:", e);
77
+ addLog("⚠️ Không lấy được link từ Firebase, dùng link mặc định.");
78
+ }
79
+ }
80
+
81
+ // Clean URL
82
+ const cleanUrl = targetUrl.replace(/\/$/, "");
83
+ setApiUrl(cleanUrl); // Cập nhật UI
84
+
85
+ // FIX: Xử lý nhẹ nhàng nếu là link mặc định thay vì báo lỗi đỏ
86
+ if (cleanUrl.includes("thay-link")) {
87
+ setServerStatus('disconnected');
88
+ addLog("⚠️ Chưa có link Server. Vui lòng nhập link Ngrok vào ô bên dưới.");
89
+ setFetchingInfo(false);
90
+ return; // Dừng tại đây, không ném lỗi
91
+ }
92
+
93
+ addLog(`Kiểm tra kết nối: ${cleanUrl}...`);
94
 
95
+ // 2. Gọi API /info để lấy danh sách model
96
  const res = await fetch(`${cleanUrl}/info`, {
97
  headers: { "ngrok-skip-browser-warning": "69420" }
98
  });
99
 
100
  if (!res.ok) {
101
  const text = await res.text();
102
+ throw new Error(`Lỗi Server (${res.status}): ${text.slice(0, 50)}`);
103
  }
104
 
105
  const data = await res.json();
 
113
  if (data.upscalers?.length > 0) setUpscalers(data.upscalers);
114
 
115
  setServerStatus('connected');
116
+ addLog(`✅ Kết nối thành công!`);
117
 
118
  } catch (err) {
119
  console.error(err);
120
  setServerStatus('disconnected');
121
  setError(err.message);
122
+ addLog(`❌ Kết nối thất bại: ${err.message}`);
123
  } finally {
124
  setFetchingInfo(false);
125
  }
 
132
 
133
  const handleGenerate = async () => {
134
  if (serverStatus !== 'connected') {
135
+ setError('Vui lòng kết nối Server trước!');
136
  return;
137
  }
138
 
139
  setLoading(true);
140
  setError('');
141
+ addLog(`🎨 Đang vẽ...`);
142
 
143
  try {
144
  let upscalerValue = "None";
 
160
  body: JSON.stringify(payload),
161
  });
162
 
163
+ if (!response.ok) throw new Error(`Lỗi Server: ${response.status}`);
164
  const data = await response.json();
165
 
166
  if (data.image) {
167
  setGeneratedImage(data.image);
168
+ addLog('✨ Đã vẽ xong!');
169
  }
170
 
171
  } catch (err) {
172
  setError(err.message);
173
+ addLog(`Lỗi: ${err.message}`);
174
  } finally {
175
  setLoading(false);
176
  }
 
218
  className="flex-1 bg-slate-950 border border-slate-700 text-[10px] rounded-lg px-2 py-2 outline-none focus:border-red-500 font-mono"
219
  />
220
  <button
221
+ onClick={() => connectToServer(apiUrl)}
222
  disabled={fetchingInfo}
223
  className="bg-red-500/20 hover:bg-red-500/30 text-red-400 border border-red-500/50 rounded-lg px-3 py-2 transition-colors"
224
  >
225
  {fetchingInfo ? <Loader2 className="w-4 h-4 animate-spin" /> : <RefreshCw className="w-4 h-4" />}
226
  </button>
227
  </div>
228
+ <p className="text-[10px] text-slate-500 mt-2">Dán link Ngrok (hoặc kiểm tra Firebase) rồi bấm nút Connect.</p>
229
  </section>
230
  )}
231