新增完整的Web UI管理控制台,包含以下主要功能: 1. 响应式设计的现代化界面 2. 实时监控系统状态和提供商统计 3. 配置管理功能,支持多种模型提供商 4. 文件上传和OAuth凭据管理 5. 路径路由调用示例和curl命令生成 6. 实时日志查看和事件流处理 7. 提供完整的UI文档说明 新增多个前端模块文件,包括导航、事件处理、文件上传等功能组件,并更新package.json添加multer依赖以支持文件上传功能。同时添加详细的UI_README.md文档说明所有功能特性和使用方法。
150 lines
3.8 KiB
JavaScript
150 lines
3.8 KiB
JavaScript
// 主应用入口文件 - 模块化版本
|
||
|
||
// 导入所有模块
|
||
import {
|
||
providerStats,
|
||
REFRESH_INTERVALS
|
||
} from './constants.js';
|
||
|
||
import {
|
||
showToast,
|
||
getProviderStats
|
||
} from './utils.js';
|
||
|
||
import {
|
||
initFileUpload,
|
||
fileUploadHandler
|
||
} from './file-upload.js';
|
||
|
||
import {
|
||
initNavigation
|
||
} from './navigation.js';
|
||
|
||
import {
|
||
initEventListeners,
|
||
setDataLoaders,
|
||
setReloadConfig
|
||
} from './event-handlers.js';
|
||
|
||
import {
|
||
initEventStream,
|
||
setProviderLoaders,
|
||
setConfigLoaders
|
||
} from './event-stream.js';
|
||
|
||
import {
|
||
loadSystemInfo,
|
||
updateTimeDisplay,
|
||
loadProviders,
|
||
openProviderManager
|
||
} from './provider-manager.js';
|
||
|
||
import {
|
||
loadConfiguration,
|
||
saveConfiguration
|
||
} from './config-manager.js';
|
||
|
||
import {
|
||
showProviderManagerModal,
|
||
refreshProviderConfig
|
||
} from './modal.js';
|
||
|
||
import {
|
||
initRoutingExamples
|
||
} from './routing-examples.js';
|
||
|
||
import {
|
||
initUploadConfigManager,
|
||
loadConfigList,
|
||
viewConfig,
|
||
deleteConfig,
|
||
closeConfigModal,
|
||
copyConfigContent,
|
||
reloadConfig
|
||
} from './upload-config-manager.js';
|
||
|
||
/**
|
||
* 加载初始数据
|
||
*/
|
||
function loadInitialData() {
|
||
loadSystemInfo();
|
||
loadProviders();
|
||
loadConfiguration();
|
||
// showToast('数据已刷新', 'success');
|
||
}
|
||
|
||
/**
|
||
* 初始化应用
|
||
*/
|
||
function initApp() {
|
||
// 设置数据加载器
|
||
setDataLoaders(loadInitialData, saveConfiguration);
|
||
|
||
// 设置reloadConfig函数
|
||
setReloadConfig(reloadConfig);
|
||
|
||
// 设置提供商加载器
|
||
setProviderLoaders(loadProviders, refreshProviderConfig);
|
||
|
||
// 设置配置加载器
|
||
setConfigLoaders(loadConfigList);
|
||
|
||
// 初始化各个模块
|
||
initNavigation();
|
||
initEventListeners();
|
||
initEventStream();
|
||
initFileUpload(); // 初始化文件上传功能
|
||
initRoutingExamples(); // 初始化路径路由示例功能
|
||
initUploadConfigManager(); // 初始化上传配置管理功能
|
||
loadInitialData();
|
||
|
||
// 显示欢迎消息
|
||
showToast('欢迎使用AIClent2API管理控制台!', 'success');
|
||
|
||
// 每5秒更新服务器时间和运行时间显示
|
||
setInterval(() => {
|
||
updateTimeDisplay();
|
||
}, 5000);
|
||
|
||
// 定期刷新系统信息
|
||
setInterval(() => {
|
||
loadProviders();
|
||
|
||
if (providerStats.activeProviders > 0) {
|
||
const stats = getProviderStats(providerStats);
|
||
console.log('=== 提供商统计报告 ===');
|
||
console.log(`活跃提供商: ${stats.activeProviders}`);
|
||
console.log(`健康提供商: ${stats.healthyProviders} (${stats.healthRatio})`);
|
||
console.log(`总账户数: ${stats.totalAccounts}`);
|
||
console.log(`总请求数: ${stats.totalRequests}`);
|
||
console.log(`总错误数: ${stats.totalErrors}`);
|
||
console.log(`成功率: ${stats.successRate}`);
|
||
console.log(`平均每提供商请求数: ${stats.avgUsagePerProvider}`);
|
||
console.log('========================');
|
||
}
|
||
}, REFRESH_INTERVALS.SYSTEM_INFO);
|
||
|
||
}
|
||
|
||
// DOM加载完成后初始化应用
|
||
document.addEventListener('DOMContentLoaded', initApp);
|
||
|
||
// 导出全局函数供其他模块使用
|
||
window.loadProviders = loadProviders;
|
||
window.openProviderManager = openProviderManager;
|
||
window.showProviderManagerModal = showProviderManagerModal;
|
||
window.refreshProviderConfig = refreshProviderConfig;
|
||
window.fileUploadHandler = fileUploadHandler;
|
||
|
||
// 上传配置管理相关全局函数
|
||
window.viewConfig = viewConfig;
|
||
window.deleteConfig = deleteConfig;
|
||
window.loadConfigList = loadConfigList;
|
||
window.closeConfigModal = closeConfigModal;
|
||
window.copyConfigContent = copyConfigContent;
|
||
window.reloadConfig = reloadConfig;
|
||
|
||
// 导出调试函数
|
||
window.getProviderStats = () => getProviderStats(providerStats);
|
||
|
||
console.log('AIClient2API 管理控制台已加载 - 模块化版本');
|