File size: 6,183 Bytes
97ec0e5
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <title>Token 管理系统</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <div class="container">
        <!-- 登录表单 -->
        <div id="loginForm" class="login-form">
            <h2>🔐 Token 管理系统</h2>
            <form id="login">
                <div class="form-group">
                    <label>👤 用户名</label>
                    <input type="text" id="username" required autocomplete="username">
                </div>
                <div class="form-group">
                    <label>🔑 密码</label>
                    <input type="password" id="password" required autocomplete="current-password">
                </div>
                <button type="submit">登录</button>
            </form>
        </div>

        <!-- 主内容 -->
        <div id="mainContent" class="main-content hidden">
            <div class="header">
                <div class="tabs">
                    <button class="tab active" onclick="switchTab('tokens')">🎯 Token管理</button>
                    <button class="tab" onclick="switchTab('settings')">⚙️ 设置</button>
                </div>
                <button onclick="logout()">🚪 退出</button>
            </div>
            <div class="content">
                <!-- Token管理页面 -->
                <div id="tokensPage">
                <!-- 统计卡片 -->
                <div class="stats">
                    <div class="stat-card">
                        <div class="stat-value" id="totalTokens">0</div>
                        <div class="stat-label">总Token数</div>
                    </div>
                    <div class="stat-card" style="background: linear-gradient(135deg, var(--success), #059669);">
                        <div class="stat-value" id="enabledTokens">0</div>
                        <div class="stat-label">已启用</div>
                    </div>
                    <div class="stat-card" style="background: linear-gradient(135deg, var(--danger), #dc2626);">
                        <div class="stat-value" id="disabledTokens">0</div>
                        <div class="stat-label">已禁用</div>
                    </div>
                </div>

                <!-- 添加Token按钮组 -->
                <div class="add-form">
                    <h3>➕ 添加新Token<span class="help-tip" title="支持OAuth登录或手动填入Token">?</span></h3>
                    <div class="btn-group">
                        <button type="button" onclick="showOAuthModal()" class="btn btn-success">🔐 OAuth登录</button>
                        <button type="button" onclick="showManualModal()" class="btn btn-secondary">✏️ 手动填入</button>
                        <button type="button" onclick="loadTokens()" class="btn btn-warning">🔄 刷新</button>
                    </div>
                </div>

                <!-- Token网格 -->
                <div id="tokenList" class="token-grid">
                    <div class="empty-state">
                        <div class="empty-state-icon">📦</div>
                        <div class="empty-state-text">暂无Token</div>
                        <div class="empty-state-hint">点击上方按钮添加您的第一个Token</div>
                    </div>
                </div>
                </div>

                <!-- 设置页面 -->
                <div id="settingsPage" class="hidden">
                    <h3>⚙️ 系统配置</h3>
                    <form id="configForm" class="config-form">
                        <div class="config-section">
                            <h4>服务器配置</h4>
                            <div class="form-group"><label>端口 PORT</label><input type="number" name="PORT"></div>
                            <div class="form-group"><label>监听地址 HOST</label><input type="text" name="HOST"></div>
                        </div>
                        <div class="config-section">
                            <h4>默认参数</h4>
                            <div class="form-group"><label>温度 TEMPERATURE</label><input type="number" step="0.1" name="DEFAULT_TEMPERATURE"></div>
                            <div class="form-group"><label>Top P</label><input type="number" step="0.01" name="DEFAULT_TOP_P"></div>
                            <div class="form-group"><label>Top K</label><input type="number" name="DEFAULT_TOP_K"></div>
                            <div class="form-group"><label>最大Token数</label><input type="number" name="DEFAULT_MAX_TOKENS"></div>
                        </div>
                        <div class="config-section">
                            <h4>安全配置</h4>
                            <div class="form-group"><label>API密钥</label><input type="text" name="API_KEY"></div>
                            <div class="form-group"><label>最大请求大小</label><input type="text" name="MAX_REQUEST_SIZE"></div>
                        </div>
                        <div class="config-section">
                            <h4>其他配置</h4>
                            <div class="form-group"><label>超时时间(ms)</label><input type="number" name="TIMEOUT"></div>
                            <div class="form-group"><label>代理地址</label><input type="text" name="PROXY" placeholder="http://127.0.0.1:7897"></div>
                            <div class="form-group"><label>跳过ProjectId验证</label><select name="SKIP_PROJECT_ID_FETCH"><option value="false"></option><option value="true"></option></select></div>
                            <div class="form-group"><label>系统提示词</label><textarea name="SYSTEM_INSTRUCTION" rows="3"></textarea></div>
                        </div>
                        <button type="submit" class="btn btn-success">💾 保存配置</button>
                    </form>
                </div>
            </div>
        </div>
    </div>

    <script src="app.js"></script>
</body>
</html>