修改了页面的布局
This commit is contained in:
@@ -32,7 +32,8 @@
|
|||||||
"Bash(find:*)",
|
"Bash(find:*)",
|
||||||
"Bash(./test_upload.sh:*)",
|
"Bash(./test_upload.sh:*)",
|
||||||
"Bash(./test_all.sh)",
|
"Bash(./test_all.sh)",
|
||||||
"Bash(/data/code/FT_Platform/YG_FT_Platform/test_data_dir.sh:*)"
|
"Bash(/data/code/FT_Platform/YG_FT_Platform/test_data_dir.sh:*)",
|
||||||
|
"Bash(grep:*)"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,55 +4,69 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>添加自定义工具 / 远光软件微调平台</title>
|
<title>添加自定义工具 / 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
|
||||||
.sidebar-item-active {
|
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
|
||||||
}
|
|
||||||
.sidebar-section-title {
|
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
|
||||||
}
|
|
||||||
.form-input {
|
|
||||||
@apply w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none transition-colors;
|
|
||||||
}
|
|
||||||
.form-label {
|
|
||||||
@apply block text-sm font-medium text-gray-700 mb-1;
|
|
||||||
}
|
|
||||||
.icon-option {
|
|
||||||
@apply w-10 h-10 rounded-lg border border-gray-200 flex items-center justify-center cursor-pointer hover:border-primary hover:bg-primary/5 transition-all;
|
|
||||||
}
|
|
||||||
.icon-option.selected {
|
|
||||||
@apply border-primary bg-primary/10;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.form-label {
|
||||||
|
display: block;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #374151;
|
||||||
|
margin-bottom: 0.25rem;
|
||||||
|
}
|
||||||
|
.icon-option {
|
||||||
|
width: 2.5rem;
|
||||||
|
height: 2.5rem;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
border: 1px solid #e5e7eb;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.icon-option:hover {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.icon-option.selected {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.1);
|
||||||
|
}
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.border-primary { border-color: #1890ff; }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -61,52 +75,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型对比</span>
|
<span class="ml-2">模型对比</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -114,7 +128,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<a href="main.html?page=data-generate" class="text-gray-500 hover:text-gray-700 flex items-center">
|
<a href="main.html?page=data-generate" class="text-gray-500 hover:text-gray-700 flex items-center">
|
||||||
@@ -317,7 +331,6 @@
|
|||||||
|
|
||||||
// 提交表单
|
// 提交表单
|
||||||
function submitForm() {
|
function submitForm() {
|
||||||
console.log('submitForm called');
|
|
||||||
const form = document.getElementById('toolForm');
|
const form = document.getElementById('toolForm');
|
||||||
const formData = new FormData(form);
|
const formData = new FormData(form);
|
||||||
const name = formData.get('name').trim();
|
const name = formData.get('name').trim();
|
||||||
|
|||||||
@@ -4,66 +4,74 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>上传数据集 / 远光软件微调平台</title>
|
<title>上传数据集 / 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
|
||||||
.sidebar-item-active {
|
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
|
||||||
}
|
|
||||||
.sidebar-section-title {
|
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
|
||||||
}
|
|
||||||
.form-select {
|
|
||||||
@apply w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none transition-colors appearance-none bg-white;
|
|
||||||
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
|
||||||
background-position: right 0.5rem center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: 1.5em 1.5em;
|
|
||||||
padding-right: 2.5rem;
|
|
||||||
}
|
|
||||||
.tab-active {
|
|
||||||
@apply bg-primary/10 text-primary font-medium;
|
|
||||||
}
|
|
||||||
.radio-dot {
|
|
||||||
@apply w-2 h-2 rounded-full bg-transparent transition-all;
|
|
||||||
}
|
|
||||||
.radio-custom:checked ~ .flex .w-4 {
|
|
||||||
@apply border-primary bg-primary/10;
|
|
||||||
}
|
|
||||||
.radio-custom:checked ~ .flex .w-4 .radio-dot {
|
|
||||||
@apply bg-primary;
|
|
||||||
}
|
|
||||||
.upload-area:hover, .upload-area.drag-over {
|
|
||||||
@apply border-primary bg-primary/5;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.form-select {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
appearance: none;
|
||||||
|
background-color: white;
|
||||||
|
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
||||||
|
background-position: right 0.5rem center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 1.5em 1.5em;
|
||||||
|
padding-right: 2.5rem;
|
||||||
|
}
|
||||||
|
.form-select:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.radio-dot {
|
||||||
|
width: 0.5rem;
|
||||||
|
height: 0.5rem;
|
||||||
|
border-radius: 50%;
|
||||||
|
background-color: transparent;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.upload-area:hover,
|
||||||
|
.upload-area.drag-over {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.border-primary { border-color: #1890ff; }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -72,52 +80,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型部署</span>
|
<span class="ml-2">模型部署</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -125,7 +133,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<a href="main.html?page=dataset-manage" class="text-gray-500 hover:text-gray-700 flex items-center">
|
<a href="main.html?page=dataset-manage" class="text-gray-500 hover:text-gray-700 flex items-center">
|
||||||
|
|||||||
@@ -4,52 +4,76 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>创建训练任务 / 远光软件微调平台</title>
|
<title>创建训练任务 / 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
|
||||||
.sidebar-item-active {
|
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
|
||||||
}
|
|
||||||
.sidebar-section-title {
|
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
|
||||||
}
|
|
||||||
.card-radio {
|
|
||||||
@apply border border-gray-200 rounded-lg p-4 cursor-pointer transition-all;
|
|
||||||
}
|
|
||||||
.card-radio.active {
|
|
||||||
@apply border-primary bg-blue-50;
|
|
||||||
}
|
|
||||||
.card-radio:hover {
|
|
||||||
@apply border-gray-300;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.form-select {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
appearance: none;
|
||||||
|
background-color: white;
|
||||||
|
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
||||||
|
background-position: right 0.5rem center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 1.5em 1.5em;
|
||||||
|
padding-right: 2.5rem;
|
||||||
|
}
|
||||||
|
.form-select:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.card-radio {
|
||||||
|
border: 1px solid #e5e7eb;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
padding: 1rem;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.card-radio.active {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.card-radio:hover {
|
||||||
|
border-color: #d1d5db;
|
||||||
|
}
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.border-primary { border-color: #1890ff; }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -58,52 +82,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型部署</span>
|
<span class="ml-2">模型部署</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -111,7 +135,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<a href="main.html" class="text-gray-500 hover:text-gray-700 flex items-center">
|
<a href="main.html" class="text-gray-500 hover:text-gray-700 flex items-center">
|
||||||
@@ -135,7 +159,7 @@
|
|||||||
<!-- 内容区域 -->
|
<!-- 内容区域 -->
|
||||||
<main class="flex-1 overflow-y-auto p-6 bg-gray-50">
|
<main class="flex-1 overflow-y-auto p-6 bg-gray-50">
|
||||||
<!-- 页面标题 -->
|
<!-- 页面标题 -->
|
||||||
<div class="bg-white rounded-lg shadow-sm p-4 border-b border-gray-100 mb-4">
|
<div class="bg-white rounded-lg shadow-sm w-full p-4 border-b border-gray-100 mb-4">
|
||||||
<div class="flex items-center text-sm">
|
<div class="flex items-center text-sm">
|
||||||
<span class="text-primary cursor-pointer hover:underline" onclick="window.location.href='main.html'">模型调优</span>
|
<span class="text-primary cursor-pointer hover:underline" onclick="window.location.href='main.html'">模型调优</span>
|
||||||
<span class="mx-2 text-gray-300">/</span>
|
<span class="mx-2 text-gray-300">/</span>
|
||||||
@@ -144,15 +168,15 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 表单内容 -->
|
<!-- 表单内容 -->
|
||||||
<div class="bg-white rounded-lg shadow-sm">
|
<div class="bg-white rounded-lg shadow-sm w-full">
|
||||||
<div class="p-6">
|
<div class="p-6">
|
||||||
<form id="createForm">
|
<form id="createForm">
|
||||||
<!-- 基本信息 -->
|
<!-- 基本信息 -->
|
||||||
<div class="mb-6">
|
<div class="mb-6">
|
||||||
<h3 class="text-sm font-semibold text-gray-700 mb-4 pb-2 border-b border-gray-100">基本信息</h3>
|
<h3 class="text-sm font-semibold text-gray-700 mb-4 pb-2 border-b border-gray-100">基本信息</h3>
|
||||||
<div class="flex items-center mb-4">
|
<div class="mb-4">
|
||||||
<label class="w-24 text-sm text-gray-600">任务名称</label>
|
<label class="block text-sm text-gray-600 mb-3">任务名称</label>
|
||||||
<div class="flex-1 max-w-md">
|
<div>
|
||||||
<input type="text" name="name" class="w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none" placeholder="请输入任务名称" maxlength="50">
|
<input type="text" name="name" class="w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none" placeholder="请输入任务名称" maxlength="50">
|
||||||
<p class="text-xs text-gray-400 mt-1"><span id="nameCount">0</span> / 50</p>
|
<p class="text-xs text-gray-400 mt-1"><span id="nameCount">0</span> / 50</p>
|
||||||
</div>
|
</div>
|
||||||
@@ -210,7 +234,7 @@
|
|||||||
<span class="text-sm">自定义模型</span>
|
<span class="text-sm">自定义模型</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div class="pl-24">
|
<div>
|
||||||
<select name="base_model" class="w-64 px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none">
|
<select name="base_model" class="w-64 px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none">
|
||||||
<option value="">请选择</option>
|
<option value="">请选择</option>
|
||||||
<option value="qwen-3-4b-instruct">通义千问3-4B-Instruct</option>
|
<option value="qwen-3-4b-instruct">通义千问3-4B-Instruct</option>
|
||||||
@@ -242,10 +266,9 @@
|
|||||||
<div class="mb-6">
|
<div class="mb-6">
|
||||||
<h3 class="text-sm font-semibold text-gray-700 mb-4 pb-2 border-b border-gray-100">数据配置</h3>
|
<h3 class="text-sm font-semibold text-gray-700 mb-4 pb-2 border-b border-gray-100">数据配置</h3>
|
||||||
|
|
||||||
<!-- 训练集 -->
|
|
||||||
<div class="mb-6">
|
<div class="mb-6">
|
||||||
<label class="block text-sm text-gray-600 mb-3">训练集</label>
|
<label class="block text-sm text-gray-600 mb-3">训练集</label>
|
||||||
<div id="trainDatasetList" class="pl-24 space-y-2">
|
<div id="trainDatasetList" class="space-y-2">
|
||||||
<!-- 数据集单选选项将通过JS动态加载 -->
|
<!-- 数据集单选选项将通过JS动态加载 -->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -253,7 +276,7 @@
|
|||||||
<!-- 验证集 -->
|
<!-- 验证集 -->
|
||||||
<div class="mb-6">
|
<div class="mb-6">
|
||||||
<label class="block text-sm text-gray-600 mb-3">验证集 <span class="text-red-500">*</span></label>
|
<label class="block text-sm text-gray-600 mb-3">验证集 <span class="text-red-500">*</span></label>
|
||||||
<div class="pl-24 flex items-center space-x-6 mb-3">
|
<div class="flex items-center space-x-6 mb-3">
|
||||||
<label class="flex items-center">
|
<label class="flex items-center">
|
||||||
<input type="radio" name="valid_split" value="auto" checked class="mr-2" onchange="toggleValidSplit()">
|
<input type="radio" name="valid_split" value="auto" checked class="mr-2" onchange="toggleValidSplit()">
|
||||||
<span class="text-sm">自动切分</span>
|
<span class="text-sm">自动切分</span>
|
||||||
@@ -263,12 +286,12 @@
|
|||||||
<span class="text-sm">选择数据集</span>
|
<span class="text-sm">选择数据集</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div id="autoSplitSection" class="pl-24 flex items-center">
|
<div id="autoSplitSection" class="flex items-center">
|
||||||
<span class="text-sm text-gray-600 mr-2">从当前训练集随机分割</span>
|
<span class="text-sm text-gray-600 mr-2">从当前训练集随机分割</span>
|
||||||
<input type="number" name="valid_ratio" value="10" class="w-16 px-2 py-1 border border-gray-300 rounded text-sm text-center focus:border-primary focus:outline-none">
|
<input type="number" name="valid_ratio" value="10" class="w-16 px-2 py-1 border border-gray-300 rounded text-sm text-center focus:border-primary focus:outline-none">
|
||||||
<span class="text-sm text-gray-600 ml-2">% 作为验证集</span>
|
<span class="text-sm text-gray-600 ml-2">% 作为验证集</span>
|
||||||
</div>
|
</div>
|
||||||
<div id="customSplitSection" class="pl-24 hidden">
|
<div id="customSplitSection" class="hidden">
|
||||||
<div id="validDatasetList" class="space-y-2">
|
<div id="validDatasetList" class="space-y-2">
|
||||||
<!-- 验证集单选选项将通过JS动态加载 -->
|
<!-- 验证集单选选项将通过JS动态加载 -->
|
||||||
</div>
|
</div>
|
||||||
@@ -283,7 +306,7 @@
|
|||||||
<!-- 模型名称 -->
|
<!-- 模型名称 -->
|
||||||
<div class="mb-4">
|
<div class="mb-4">
|
||||||
<label class="block text-sm text-gray-600 mb-3">模型名称</label>
|
<label class="block text-sm text-gray-600 mb-3">模型名称</label>
|
||||||
<div class="pl-24">
|
<div>
|
||||||
<input type="text" name="output_model_name" class="w-64 px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none" placeholder="请输入模型名称" maxlength="50">
|
<input type="text" name="output_model_name" class="w-64 px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none" placeholder="请输入模型名称" maxlength="50">
|
||||||
<p class="text-xs text-gray-400 mt-1"><span id="modelNameCount">0</span> / 50</p>
|
<p class="text-xs text-gray-400 mt-1"><span id="modelNameCount">0</span> / 50</p>
|
||||||
</div>
|
</div>
|
||||||
@@ -295,7 +318,7 @@
|
|||||||
<span class="text-sm text-gray-600 mr-2">模型加密</span>
|
<span class="text-sm text-gray-600 mr-2">模型加密</span>
|
||||||
<span class="px-2 py-0.5 bg-green-100 text-green-700 text-xs rounded">安全升级</span>
|
<span class="px-2 py-0.5 bg-green-100 text-green-700 text-xs rounded">安全升级</span>
|
||||||
</div>
|
</div>
|
||||||
<p class="text-xs text-gray-400 mt-1 ml-24">为保障您的数据安全,平台会为导出的模型文件开启 OSS 服务端加密</p>
|
<p class="text-xs text-gray-400 mt-1">为保障您的数据安全,平台会为导出的模型文件开启 OSS 服务端加密</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
@@ -4,41 +4,28 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>远光软件微调平台 - 登录</title>
|
<title>远光软件微调平台 - 登录</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.login-card-shadow {
|
||||||
theme: {
|
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
|
||||||
extend: {
|
|
||||||
colors: {
|
|
||||||
primary: '#1890ff',
|
|
||||||
sidebarBg: '#001529',
|
|
||||||
sidebarText: '#bfcbd9',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.input-focus {
|
||||||
<style type="text/tailwindcss">
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
@layer utilities {
|
|
||||||
.content-auto {
|
|
||||||
content-visibility: auto;
|
|
||||||
}
|
|
||||||
.input-focus {
|
|
||||||
@apply focus:border-primary focus:ring-1 focus:ring-primary focus:outline-none;
|
|
||||||
}
|
|
||||||
.login-card-shadow {
|
|
||||||
@apply shadow-lg shadow-primary/10 hover:shadow-xl hover:shadow-primary/15 transition-shadow;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.input-focus:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2);
|
||||||
|
}
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.text-danger { color: #f5222d; }
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.bg-danger\/5 { background-color: rgba(245, 34, 45, 0.05); }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 min-h-screen flex items-center justify-center p-4">
|
<body class="login-page antialiased bg-gray-50 min-h-screen flex items-center justify-center p-4" style="background-color: #DBE0F9;">
|
||||||
<!-- 登录主容器 -->
|
<!-- 登录主容器 -->
|
||||||
<div class="w-full max-w-md">
|
<div class="w-full max-w-md">
|
||||||
<!-- 登录卡片 -->
|
<!-- 登录卡片 -->
|
||||||
|
|||||||
@@ -4,59 +4,148 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>模型调优 - 远光软件微调平台</title>
|
<title>模型调优 - 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
tableHeader: '#fafafa',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
}
|
||||||
.content-auto {
|
.sidebar-item-active {
|
||||||
content-visibility: auto;
|
background-color: rgba(24, 144, 255, 0.1);
|
||||||
}
|
color: #1890ff;
|
||||||
.sidebar-item-active {
|
border-left: 4px solid #1890ff;
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
}
|
||||||
}
|
.table-row-hover:hover {
|
||||||
.table-row-hover {
|
background-color: #f9fafb;
|
||||||
@apply hover:bg-gray-50 transition-colors;
|
transition: background-color 0.2s;
|
||||||
}
|
}
|
||||||
.sidebar-section-title {
|
.table-header-bg {
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
background-color: #fafafa !important;
|
||||||
}
|
}
|
||||||
.card-radio {
|
.card-radio {
|
||||||
@apply border border-gray-200 rounded-lg p-4 cursor-pointer transition-all;
|
border: 1px solid #e5e7eb;
|
||||||
}
|
border-radius: 0.5rem;
|
||||||
.card-radio.active {
|
padding: 1rem;
|
||||||
@apply border-primary bg-blue-50;
|
cursor: pointer;
|
||||||
}
|
transition: all 0.2s;
|
||||||
.card-radio:hover {
|
}
|
||||||
@apply border-gray-300;
|
.card-radio.active {
|
||||||
}
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.card-radio:hover {
|
||||||
|
border-color: #d1d5db;
|
||||||
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2);
|
||||||
|
}
|
||||||
|
.form-label {
|
||||||
|
display: block;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #374151;
|
||||||
|
margin-bottom: 0.25rem;
|
||||||
|
}
|
||||||
|
.form-select {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
appearance: none;
|
||||||
|
background-color: white;
|
||||||
|
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
||||||
|
background-position: right 0.5rem center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 1.5em 1.5em;
|
||||||
|
padding-right: 2.5rem;
|
||||||
|
}
|
||||||
|
.form-select:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.icon-option {
|
||||||
|
width: 2.5rem;
|
||||||
|
height: 2.5rem;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
border: 1px solid #e5e7eb;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.icon-option:hover {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.icon-option.selected {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.1);
|
||||||
|
}
|
||||||
|
.tab-active {
|
||||||
|
background-color: rgba(24, 144, 255, 0.1);
|
||||||
|
color: #1890ff;
|
||||||
|
font-weight: 500;
|
||||||
|
}
|
||||||
|
.radio-dot {
|
||||||
|
width: 0.5rem;
|
||||||
|
height: 0.5rem;
|
||||||
|
border-radius: 50%;
|
||||||
|
background-color: transparent;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.upload-area:hover,
|
||||||
|
.upload-area.drag-over {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.bg-primary {
|
||||||
|
background-color: #1890ff;
|
||||||
|
}
|
||||||
|
.text-primary {
|
||||||
|
color: #1890ff;
|
||||||
|
}
|
||||||
|
.border-primary {
|
||||||
|
border-color: #1890ff;
|
||||||
|
}
|
||||||
|
.text-danger {
|
||||||
|
color: #f5222d;
|
||||||
|
}
|
||||||
|
.hover\:bg-primary\/90:hover {
|
||||||
|
background-color: rgba(24, 144, 255, 0.9);
|
||||||
|
}
|
||||||
|
:root {
|
||||||
|
--primary: #1890ff;
|
||||||
|
--danger: #f5222d;
|
||||||
|
--success: #52c41a;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -65,52 +154,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="#" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="#" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="#" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="#" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型对比</span>
|
<span class="ml-2">模型对比</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="#" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="#" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="#" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="#" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="#" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -118,7 +207,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-6">
|
<div class="flex items-center space-x-6">
|
||||||
<button class="md:hidden text-gray-500 hover:text-gray-700">
|
<button class="md:hidden text-gray-500 hover:text-gray-700">
|
||||||
@@ -128,7 +217,7 @@
|
|||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<div class="relative group">
|
<div class="relative group">
|
||||||
<img src="https://picsum.photos/id/1005/32/32" class="w-8 h-8 rounded-full cursor-pointer" alt="用户头像">
|
<img src="https://picsum.photos/id/1005/32/32" class="w-8 h-8 rounded-full cursor-pointer" alt="用户头像">
|
||||||
<div class="absolute right-0 top-full mt-2 bg-white rounded shadow-lg py-1 hidden group-hover:block border border-gray-100 min-w-[140px]">
|
<div class="absolute right-0 top-full mt-1 bg-white rounded shadow-lg py-1 hidden group-hover:block border border-gray-100 min-w-[140px] z-50">
|
||||||
<a href="login.html" class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-50 whitespace-nowrap">
|
<a href="login.html" class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-50 whitespace-nowrap">
|
||||||
<i class="fa fa-sign-out mr-1"></i>退出登录
|
<i class="fa fa-sign-out mr-1"></i>退出登录
|
||||||
</a>
|
</a>
|
||||||
@@ -255,14 +344,9 @@
|
|||||||
},
|
},
|
||||||
'config': {
|
'config': {
|
||||||
title: '平台性能',
|
title: '平台性能',
|
||||||
api: 'sys-config',
|
skipFetch: true,
|
||||||
hasCreate: false,
|
hasCreate: false,
|
||||||
isForm: true,
|
isHardwareMonitor: true
|
||||||
formFields: [
|
|
||||||
{ name: 'config_key', label: '配置键', type: 'text' },
|
|
||||||
{ name: 'config_value', label: '配置值', type: 'text' },
|
|
||||||
{ name: 'description', label: '描述', type: 'text' }
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -301,10 +385,10 @@
|
|||||||
document.querySelectorAll('.nav-link').forEach(link => {
|
document.querySelectorAll('.nav-link').forEach(link => {
|
||||||
if (link.dataset.page === defaultPage) {
|
if (link.dataset.page === defaultPage) {
|
||||||
link.classList.add('sidebar-item-active');
|
link.classList.add('sidebar-item-active');
|
||||||
link.classList.remove('hover:bg-sidebarBg/20', 'transition-colors');
|
link.classList.remove('hover:bg-[#001529]/20', 'transition-colors');
|
||||||
} else {
|
} else {
|
||||||
link.classList.remove('sidebar-item-active');
|
link.classList.remove('sidebar-item-active');
|
||||||
link.classList.add('hover:bg-sidebarBg/20', 'transition-colors');
|
link.classList.add('hover:bg-[#001529]/20', 'transition-colors');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -318,10 +402,10 @@
|
|||||||
// 更新高亮状态
|
// 更新高亮状态
|
||||||
document.querySelectorAll('.nav-link').forEach(l => {
|
document.querySelectorAll('.nav-link').forEach(l => {
|
||||||
l.classList.remove('sidebar-item-active');
|
l.classList.remove('sidebar-item-active');
|
||||||
l.classList.add('hover:bg-sidebarBg/20', 'transition-colors');
|
l.classList.add('hover:bg-[#001529]/20', 'transition-colors');
|
||||||
});
|
});
|
||||||
this.classList.add('sidebar-item-active');
|
this.classList.add('sidebar-item-active');
|
||||||
this.classList.remove('hover:bg-sidebarBg/20', 'transition-colors');
|
this.classList.remove('hover:bg-[#001529]/20', 'transition-colors');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -343,7 +427,10 @@
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
// 渲染页面
|
// 渲染页面
|
||||||
if (config.isForm) {
|
if (config.isHardwareMonitor) {
|
||||||
|
// 硬件监控页面使用模拟数据,不调用API
|
||||||
|
container.innerHTML = renderConfigPage(config, null);
|
||||||
|
} else if (config.isForm) {
|
||||||
const data = await fetchData(`${API_BASE}/${config.api}`);
|
const data = await fetchData(`${API_BASE}/${config.api}`);
|
||||||
container.innerHTML = renderConfigPage(config, data);
|
container.innerHTML = renderConfigPage(config, data);
|
||||||
} else if (config.isTools) {
|
} else if (config.isTools) {
|
||||||
@@ -419,7 +506,7 @@
|
|||||||
<div class="overflow-x-auto">
|
<div class="overflow-x-auto">
|
||||||
<table class="w-full">
|
<table class="w-full">
|
||||||
<thead>
|
<thead>
|
||||||
<tr class="bg-tableHeader text-gray-500 text-sm">
|
<tr class="table-header-bg text-gray-500 text-sm">
|
||||||
${columns.map(col => `<th class="px-4 py-3 text-left font-medium">${col.title}</th>`).join('')}
|
${columns.map(col => `<th class="px-4 py-3 text-left font-medium">${col.title}</th>`).join('')}
|
||||||
<th class="px-4 py-3 text-left font-medium">操作</th>
|
<th class="px-4 py-3 text-left font-medium">操作</th>
|
||||||
</tr>
|
</tr>
|
||||||
@@ -556,51 +643,411 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 渲染配置页面
|
// 渲染配置页面(硬件监控)
|
||||||
function renderConfigPage(config, data) {
|
function renderConfigPage(config, data) {
|
||||||
return `
|
return `
|
||||||
<div class="bg-white rounded-lg shadow-sm mb-6">
|
<div class="bg-white rounded-lg shadow-sm mb-6">
|
||||||
<div class="flex items-center justify-between p-4 border-b border-gray-100">
|
<div class="flex items-center justify-between p-4 border-b border-gray-100">
|
||||||
<h2 class="text-lg font-medium">${config.title}</h2>
|
<h2 class="text-lg font-medium">${config.title}</h2>
|
||||||
|
<div class="flex items-center text-sm text-gray-500">
|
||||||
|
<i class="fa fa-refresh mr-2"></i>
|
||||||
|
<span class="mr-2">刷新频率:</span>
|
||||||
|
<select id="refreshInterval" onchange="changeRefreshRate()" class="px-2 py-1 border border-gray-300 rounded text-sm focus:border-primary focus:outline-none">
|
||||||
|
<option value="1000">1秒</option>
|
||||||
|
<option value="3000">3秒</option>
|
||||||
|
<option value="5000" selected>5秒</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="p-6">
|
<div class="p-6">
|
||||||
<form class="space-y-6" onsubmit="event.preventDefault(); saveConfig()">
|
<!-- 第一行:CPU、内存、磁盘 -->
|
||||||
<div>
|
<div class="grid grid-cols-1 md:grid-cols-3 gap-6 mb-6">
|
||||||
<h3 class="text-base font-medium text-gray-800 mb-4">基本设置</h3>
|
<!-- CPU监控 -->
|
||||||
<div class="space-y-4">
|
<div class="border border-gray-200 rounded-lg p-5">
|
||||||
<div>
|
<div class="flex items-center justify-between mb-4">
|
||||||
<label class="block text-sm font-medium text-gray-700 mb-1">平台名称</label>
|
<div class="flex items-center">
|
||||||
<input type="text" class="w-full px-3 py-2 border border-gray-300 rounded-lg" value="远光软件微调平台">
|
<div class="w-10 h-10 rounded-lg bg-blue-100 flex items-center justify-center mr-3">
|
||||||
|
<i class="fa fa-microchip text-blue-600 text-lg"></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">CPU 使用率</h3>
|
||||||
|
<p class="text-xs text-gray-500" id="cpuCores">4 核心</p>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div class="text-right">
|
||||||
<label class="block text-sm font-medium text-gray-700 mb-1">API地址</label>
|
<span class="text-2xl font-medium text-gray-800" id="cpuPercent">0%</span>
|
||||||
<input type="text" class="w-full px-3 py-2 border border-gray-300 rounded-lg" placeholder="https://api.example.com">
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- CPU进度条 -->
|
||||||
|
<div class="relative h-4 bg-gray-100 rounded-full overflow-hidden">
|
||||||
|
<div id="cpuBar" class="absolute left-0 top-0 h-full bg-gradient-to-r from-green-400 to-blue-500 transition-all duration-500" style="width: 0%"></div>
|
||||||
|
</div>
|
||||||
|
<!-- 核心使用率 -->
|
||||||
|
<div class="mt-4 grid grid-cols-4 gap-2" id="cpuCoresList">
|
||||||
|
<div class="text-center p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">核心1</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="core1">0%</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-center p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">核心2</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="core2">0%</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-center p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">核心3</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="core3">0%</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-center p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">核心4</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="core4">0%</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="border-t border-gray-100 pt-6">
|
|
||||||
<h3 class="text-base font-medium text-gray-800 mb-4">模型配置</h3>
|
<!-- 内存监控 -->
|
||||||
<div class="space-y-4">
|
<div class="border border-gray-200 rounded-lg p-5">
|
||||||
<div>
|
<div class="flex items-center justify-between mb-4">
|
||||||
<label class="block text-sm font-medium text-gray-700 mb-1">默认基础模型</label>
|
<div class="flex items-center">
|
||||||
<select class="w-full px-3 py-2 border border-gray-300 rounded-lg">
|
<div class="w-10 h-10 rounded-lg bg-purple-100 flex items-center justify-center mr-3">
|
||||||
<option>通义千问3-4B-Instruct</option>
|
<i class="fa fa-database text-purple-600 text-lg"></i>
|
||||||
<option>通义千问7B-Instruct</option>
|
</div>
|
||||||
</select>
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">内存使用</h3>
|
||||||
|
<p class="text-xs text-gray-500" id="memoryTotal">总计: 16 GB</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-right">
|
||||||
|
<span class="text-2xl font-medium text-gray-800" id="memoryPercent">0%</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- 内存进度条 -->
|
||||||
|
<div class="relative h-4 bg-gray-100 rounded-full overflow-hidden">
|
||||||
|
<div id="memoryBar" class="absolute left-0 top-0 h-full bg-gradient-to-r from-yellow-400 to-orange-500 transition-all duration-500" style="width: 0%"></div>
|
||||||
|
</div>
|
||||||
|
<!-- 内存详情 -->
|
||||||
|
<div class="mt-4 flex justify-between text-sm">
|
||||||
|
<div class="text-center">
|
||||||
|
<div class="text-xs text-gray-500">已用</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="memoryUsed">0 GB</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-center">
|
||||||
|
<div class="text-xs text-gray-500">可用</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="memoryAvailable">0 GB</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-center">
|
||||||
|
<div class="text-xs text-gray-500">缓存</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="memoryCached">0 GB</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="border-t border-gray-100 pt-6">
|
|
||||||
<button type="submit" class="bg-primary text-white px-4 py-2 rounded-lg hover:bg-primary/90">
|
<!-- 磁盘监控 -->
|
||||||
保存配置
|
<div class="border border-gray-200 rounded-lg p-5">
|
||||||
</button>
|
<div class="flex items-center justify-between mb-4">
|
||||||
|
<div class="flex items-center">
|
||||||
|
<div class="w-10 h-10 rounded-lg bg-green-100 flex items-center justify-center mr-3">
|
||||||
|
<i class="fa fa-hdd-o text-green-600 text-lg"></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">磁盘使用</h3>
|
||||||
|
<p class="text-xs text-gray-500" id="diskTotal">SSD 512 GB</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-right">
|
||||||
|
<span class="text-2xl font-medium text-gray-800" id="diskPercent">0%</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- 磁盘进度条 -->
|
||||||
|
<div class="relative h-4 bg-gray-100 rounded-full overflow-hidden">
|
||||||
|
<div id="diskBar" class="absolute left-0 top-0 h-full bg-gradient-to-r from-emerald-400 to-teal-500 transition-all duration-500" style="width: 0%"></div>
|
||||||
|
</div>
|
||||||
|
<!-- 磁盘详情 -->
|
||||||
|
<div class="mt-4 grid grid-cols-3 gap-2 text-center">
|
||||||
|
<div class="p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">已用空间</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="diskUsed">0 GB</div>
|
||||||
|
</div>
|
||||||
|
<div class="p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">可用空间</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="diskAvailable">0 GB</div>
|
||||||
|
</div>
|
||||||
|
<div class="p-2 bg-gray-50 rounded">
|
||||||
|
<div class="text-xs text-gray-500">读写速度</div>
|
||||||
|
<div class="text-sm font-medium text-gray-800" id="diskSpeed">0 MB/s</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</div>
|
||||||
|
|
||||||
|
<!-- 第二行:GPU监控(横向占满,2列网格) -->
|
||||||
|
<div class="mb-6">
|
||||||
|
<div class="flex items-center mb-4">
|
||||||
|
<div class="w-10 h-10 rounded-lg bg-red-100 flex items-center justify-center mr-3">
|
||||||
|
<i class="fa fa-microchip text-red-600 text-lg"></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">GPU监控</h3>
|
||||||
|
<p class="text-xs text-gray-500" id="gpuCount">多GPU并行监控</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- GPU列表(2列网格,滚动) -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-4" id="gpuList" style="max-height: 400px; overflow-y: auto;">
|
||||||
|
<!-- GPU卡片由initGPUList()动态生成 -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 第三行:网络和系统(2列) -->
|
||||||
|
<div class="grid grid-cols-1 md:grid-cols-2 gap-6">
|
||||||
|
<!-- 网络流量 -->
|
||||||
|
<div class="border border-gray-200 rounded-lg p-5">
|
||||||
|
<div class="flex items-center mb-4">
|
||||||
|
<div class="w-10 h-10 rounded-lg bg-cyan-100 flex items-center justify-center mr-3">
|
||||||
|
<i class="fa fa-globe text-cyan-600 text-lg"></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">网络流量</h3>
|
||||||
|
<p class="text-xs text-gray-500">实时带宽使用</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="grid grid-cols-2 gap-4">
|
||||||
|
<div class="p-3 bg-blue-50 rounded-lg">
|
||||||
|
<div class="flex items-center mb-2">
|
||||||
|
<i class="fa fa-arrow-down text-blue-600 mr-2"></i>
|
||||||
|
<span class="text-xs text-gray-600">下载速度</span>
|
||||||
|
</div>
|
||||||
|
<div class="text-lg font-medium text-gray-800" id="downloadSpeed">0 MB/s</div>
|
||||||
|
</div>
|
||||||
|
<div class="p-3 bg-green-50 rounded-lg">
|
||||||
|
<div class="flex items-center mb-2">
|
||||||
|
<i class="fa fa-arrow-up text-green-600 mr-2"></i>
|
||||||
|
<span class="text-xs text-gray-600">上传速度</span>
|
||||||
|
</div>
|
||||||
|
<div class="text-lg font-medium text-gray-800" id="uploadSpeed">0 MB/s</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="mt-4 flex justify-between text-xs text-gray-500">
|
||||||
|
<span>总流入: <span id="totalDownload">0 GB</span></span>
|
||||||
|
<span>总流出: <span id="totalUpload">0 GB</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- 系统信息 -->
|
||||||
|
<div class="border border-gray-200 rounded-lg p-5">
|
||||||
|
<div class="flex items-center mb-4">
|
||||||
|
<div class="w-10 h-10 rounded-lg bg-indigo-100 flex items-center justify-center mr-3">
|
||||||
|
<i class="fa fa-info-circle text-indigo-600 text-lg"></i>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="text-sm font-medium text-gray-800">系统信息</h3>
|
||||||
|
<p class="text-xs text-gray-500">服务器状态</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="space-y-3 text-sm">
|
||||||
|
<div class="flex justify-between py-2 border-b border-gray-100">
|
||||||
|
<span class="text-gray-500">操作系统</span>
|
||||||
|
<span class="text-gray-800 font-medium" id="osInfo">Ubuntu 22.04 LTS</span>
|
||||||
|
</div>
|
||||||
|
<div class="flex justify-between py-2 border-b border-gray-100">
|
||||||
|
<span class="text-gray-500">运行时间</span>
|
||||||
|
<span class="text-gray-800 font-medium" id="uptime">0 天 0 时 0 分</span>
|
||||||
|
</div>
|
||||||
|
<div class="flex justify-between py-2 border-b border-gray-100">
|
||||||
|
<span class="text-gray-500">进程数</span>
|
||||||
|
<span class="text-gray-800 font-medium" id="processCount">0</span>
|
||||||
|
</div>
|
||||||
|
<div class="flex justify-between py-2">
|
||||||
|
<span class="text-gray-500">负载均值</span>
|
||||||
|
<span class="text-gray-800 font-medium" id="loadAvg">0.00, 0.00, 0.00</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 刷新间隔定时器
|
||||||
|
let refreshTimer = null;
|
||||||
|
let currentRefreshInterval = 5000;
|
||||||
|
|
||||||
|
// 刷新硬件信息
|
||||||
|
function refreshHardwareInfo() {
|
||||||
|
// 更新CPU
|
||||||
|
const cpuUsage = Math.floor(Math.random() * 30) + 20;
|
||||||
|
document.getElementById('cpuPercent').textContent = cpuUsage + '%';
|
||||||
|
document.getElementById('cpuBar').style.width = cpuUsage + '%';
|
||||||
|
document.getElementById('core1').textContent = Math.floor(Math.random() * 40 + 20) + '%';
|
||||||
|
document.getElementById('core2').textContent = Math.floor(Math.random() * 40 + 15) + '%';
|
||||||
|
document.getElementById('core3').textContent = Math.floor(Math.random() * 40 + 25) + '%';
|
||||||
|
document.getElementById('core4').textContent = Math.floor(Math.random() * 40 + 10) + '%';
|
||||||
|
|
||||||
|
// 更新内存
|
||||||
|
const memUsed = (Math.random() * 4 + 6).toFixed(1);
|
||||||
|
const memTotal = 16;
|
||||||
|
const memPercent = Math.floor((memUsed / memTotal) * 100);
|
||||||
|
document.getElementById('memoryPercent').textContent = memPercent + '%';
|
||||||
|
document.getElementById('memoryBar').style.width = memPercent + '%';
|
||||||
|
document.getElementById('memoryUsed').textContent = memUsed + ' GB';
|
||||||
|
document.getElementById('memoryAvailable').textContent = (memTotal - memUsed).toFixed(1) + ' GB';
|
||||||
|
document.getElementById('memoryCached').textContent = (Math.random() * 3 + 1).toFixed(1) + ' GB';
|
||||||
|
|
||||||
|
// 更新磁盘
|
||||||
|
const diskUsed = Math.floor(Math.random() * 100 + 150);
|
||||||
|
const diskTotal = 512;
|
||||||
|
const diskPercent = Math.floor((diskUsed / diskTotal) * 100);
|
||||||
|
document.getElementById('diskPercent').textContent = diskPercent + '%';
|
||||||
|
document.getElementById('diskBar').style.width = diskPercent + '%';
|
||||||
|
document.getElementById('diskUsed').textContent = diskUsed + ' GB';
|
||||||
|
document.getElementById('diskAvailable').textContent = (diskTotal - diskUsed) + ' GB';
|
||||||
|
document.getElementById('diskSpeed').textContent = (Math.random() * 500 + 100).toFixed(0) + ' MB/s';
|
||||||
|
|
||||||
|
// 更新多GPU信息
|
||||||
|
updateGPUInfo();
|
||||||
|
|
||||||
|
// 更新网络
|
||||||
|
document.getElementById('downloadSpeed').textContent = (Math.random() * 100 + 10).toFixed(1) + ' MB/s';
|
||||||
|
document.getElementById('uploadSpeed').textContent = (Math.random() * 50 + 5).toFixed(1) + ' MB/s';
|
||||||
|
document.getElementById('totalDownload').textContent = (Math.random() * 500 + 100).toFixed(1) + ' GB';
|
||||||
|
document.getElementById('totalUpload').textContent = (Math.random() * 200 + 50).toFixed(1) + ' GB';
|
||||||
|
|
||||||
|
// 更新系统信息
|
||||||
|
const days = Math.floor(Math.random() * 30);
|
||||||
|
const hours = Math.floor(Math.random() * 24);
|
||||||
|
const mins = Math.floor(Math.random() * 60);
|
||||||
|
document.getElementById('uptime').textContent = days + ' 天 ' + hours + ' 时 ' + mins + ' 分';
|
||||||
|
document.getElementById('processCount').textContent = Math.floor(Math.random() * 200 + 100);
|
||||||
|
document.getElementById('loadAvg').textContent = (Math.random() * 2).toFixed(2) + ', ' + (Math.random() * 1.5).toFixed(2) + ', ' + (Math.random() * 1).toFixed(2);
|
||||||
|
|
||||||
|
// 更新时间
|
||||||
|
// const now = new Date();
|
||||||
|
// document.getElementById('updateTime').textContent = now.toLocaleTimeString('zh-CN');
|
||||||
|
}
|
||||||
|
|
||||||
|
// GPU配置 - 支持模拟1-8块GPU
|
||||||
|
const GPU_COUNT = 4; // 可配置GPU数量
|
||||||
|
const gpuConfigs = [
|
||||||
|
{ name: 'NVIDIA RTX 3090', memory: 24 },
|
||||||
|
{ name: 'NVIDIA RTX 4090', memory: 24 },
|
||||||
|
{ name: 'NVIDIA A100', memory: 80 },
|
||||||
|
{ name: 'NVIDIA V100', memory: 32 },
|
||||||
|
{ name: 'NVIDIA T4', memory: 16 },
|
||||||
|
{ name: 'NVIDIA L40S', memory: 48 },
|
||||||
|
{ name: 'NVIDIA H100', memory: 80 },
|
||||||
|
{ name: 'NVIDIA RTX 4080', memory: 16 }
|
||||||
|
];
|
||||||
|
|
||||||
|
// 初始化GPU列表
|
||||||
|
function initGPUList() {
|
||||||
|
const gpuList = document.getElementById('gpuList');
|
||||||
|
const gpuCount = Math.min(GPU_COUNT, 8);
|
||||||
|
document.getElementById('gpuCount').textContent = `检测到 ${gpuCount} 块 GPU`;
|
||||||
|
|
||||||
|
let gpuCardsHTML = '';
|
||||||
|
for (let i = 0; i < gpuCount; i++) {
|
||||||
|
const config = gpuConfigs[i % gpuConfigs.length];
|
||||||
|
gpuCardsHTML += `
|
||||||
|
<div class="border border-gray-200 rounded-lg p-2 bg-gradient-to-br from-gray-50 to-gray-100" id="gpuCard${i}">
|
||||||
|
<div class="flex items-center justify-between mb-1">
|
||||||
|
<div class="flex items-center min-w-0">
|
||||||
|
<div class="w-6 h-6 rounded bg-red-100 flex items-center justify-center mr-2 flex-shrink-0">
|
||||||
|
<i class="fa fa-microchip text-red-600 text-xs"></i>
|
||||||
|
</div>
|
||||||
|
<div class="min-w-0">
|
||||||
|
<div class="text-xs font-medium text-gray-800 truncate" id="gpuName${i}" title="${config.name}">${config.name}</div>
|
||||||
|
<div class="text-[10px] text-gray-400">PCIe ${Math.floor(Math.random() * 4 + 1)}:00.0</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="text-right flex-shrink-0 ml-2">
|
||||||
|
<span class="text-sm font-bold text-gray-800" id="gpuPercent${i}">0%</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="relative h-1.5 bg-gray-200 rounded-full overflow-hidden mb-2">
|
||||||
|
<div id="gpuBar${i}" class="absolute left-0 top-0 h-full bg-gradient-to-r from-green-400 via-yellow-400 to-red-400 transition-all duration-500" style="width: 0%"></div>
|
||||||
|
</div>
|
||||||
|
<div class="grid grid-cols-4 gap-1 text-center text-[10px]">
|
||||||
|
<div class="bg-white/80 rounded py-0.5">
|
||||||
|
<div class="text-gray-400">显存</div>
|
||||||
|
<div class="font-medium text-gray-700 truncate" id="gpuMem${i}" title="0/${config.memory} GB">0/${config.memory}G</div>
|
||||||
|
</div>
|
||||||
|
<div class="bg-white/80 rounded py-0.5">
|
||||||
|
<div class="text-gray-400">温度</div>
|
||||||
|
<div class="font-medium text-gray-700" id="gpuTemp${i}">0°C</div>
|
||||||
|
</div>
|
||||||
|
<div class="bg-white/80 rounded py-0.5">
|
||||||
|
<div class="text-gray-400">功耗</div>
|
||||||
|
<div class="font-medium text-gray-700" id="gpuPower${i}">0W</div>
|
||||||
|
</div>
|
||||||
|
<div class="bg-white/80 rounded py-0.5">
|
||||||
|
<div class="text-gray-400">Fan</div>
|
||||||
|
<div class="font-medium text-gray-700" id="gpuFan${i}">0%</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
}
|
||||||
|
gpuList.innerHTML = gpuCardsHTML;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 更新GPU信息
|
||||||
|
function updateGPUInfo() {
|
||||||
|
const gpuCount = Math.min(GPU_COUNT, 8);
|
||||||
|
let totalUsedMemory = 0;
|
||||||
|
let totalMemory = 0;
|
||||||
|
|
||||||
|
for (let i = 0; i < gpuCount; i++) {
|
||||||
|
const config = gpuConfigs[i % gpuConfigs.length];
|
||||||
|
const gpuUsage = Math.floor(Math.random() * 60 + 20);
|
||||||
|
const memUsed = (Math.random() * config.memory * 0.7 + config.memory * 0.1).toFixed(1);
|
||||||
|
const temp = Math.floor(Math.random() * 30 + 40);
|
||||||
|
const power = Math.floor(Math.random() * 150 + 100);
|
||||||
|
const fan = Math.floor(gpuUsage + Math.random() * 10);
|
||||||
|
|
||||||
|
totalUsedMemory += parseFloat(memUsed);
|
||||||
|
totalMemory += config.memory;
|
||||||
|
|
||||||
|
document.getElementById(`gpuPercent${i}`).textContent = gpuUsage + '%';
|
||||||
|
document.getElementById(`gpuBar${i}`).style.width = gpuUsage + '%';
|
||||||
|
document.getElementById(`gpuMem${i}`).textContent = `${parseFloat(memUsed).toFixed(1)}/${config.memory} GB`;
|
||||||
|
document.getElementById(`gpuTemp${i}`).textContent = temp + '°C';
|
||||||
|
document.getElementById(`gpuPower${i}`).textContent = power + ' W';
|
||||||
|
document.getElementById(`gpuFan${i}`).textContent = fan + '%';
|
||||||
|
|
||||||
|
// 根据温度改变颜色
|
||||||
|
const tempEl = document.getElementById(`gpuTemp${i}`);
|
||||||
|
if (temp >= 80) {
|
||||||
|
tempEl.className = 'font-medium text-red-600';
|
||||||
|
} else if (temp >= 70) {
|
||||||
|
tempEl.className = 'font-medium text-yellow-600';
|
||||||
|
} else {
|
||||||
|
tempEl.className = 'font-medium text-gray-800';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 更新总显存
|
||||||
|
document.getElementById('gpuTotalMemory').textContent = `${totalUsedMemory.toFixed(1)}/${totalMemory} GB`;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 启动硬件监控自动刷新
|
||||||
|
function startRefreshTimer() {
|
||||||
|
if (refreshTimer) {
|
||||||
|
clearInterval(refreshTimer);
|
||||||
|
}
|
||||||
|
refreshTimer = setInterval(refreshHardwareInfo, currentRefreshInterval);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 改变刷新频率
|
||||||
|
function changeRefreshRate() {
|
||||||
|
const select = document.getElementById('refreshInterval');
|
||||||
|
currentRefreshInterval = parseInt(select.value);
|
||||||
|
startRefreshTimer();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 页面加载后初始化并启动定时器
|
||||||
|
document.addEventListener('DOMContentLoaded', function() {
|
||||||
|
initGPUList();
|
||||||
|
startRefreshTimer();
|
||||||
|
});
|
||||||
|
|
||||||
function saveConfig() {
|
function saveConfig() {
|
||||||
showMessage('提示', '配置保存功能开发中...', 'info');
|
showMessage('提示', '配置保存功能开发中...', 'info');
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,51 +4,80 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>新建评测 / 远光软件微调平台</title>
|
<title>新建评测 / 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
|
||||||
.sidebar-item-active {
|
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
|
||||||
}
|
|
||||||
.sidebar-section-title {
|
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
|
||||||
}
|
|
||||||
.form-select {
|
|
||||||
@apply w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none transition-colors appearance-none bg-white;
|
|
||||||
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
|
||||||
background-position: right 0.5rem center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: 1.5em 1.5em;
|
|
||||||
padding-right: 2.5rem;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.form-label {
|
||||||
|
display: block;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
font-weight: 500;
|
||||||
|
color: #374151;
|
||||||
|
margin-bottom: 0.25rem;
|
||||||
|
}
|
||||||
|
.form-select {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
appearance: none;
|
||||||
|
background-color: white;
|
||||||
|
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
||||||
|
background-position: right 0.5rem center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 1.5em 1.5em;
|
||||||
|
padding-right: 2.5rem;
|
||||||
|
}
|
||||||
|
.form-select:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.card-radio {
|
||||||
|
border: 1px solid #e5e7eb;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
padding: 1rem;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: all 0.2s;
|
||||||
|
}
|
||||||
|
.card-radio.active {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.border-primary { border-color: #1890ff; }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -57,52 +86,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型部署</span>
|
<span class="ml-2">模型部署</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -110,7 +139,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<a href="main.html?page=model-eval" class="text-gray-500 hover:text-gray-700 flex items-center">
|
<a href="main.html?page=model-eval" class="text-gray-500 hover:text-gray-700 flex items-center">
|
||||||
|
|||||||
@@ -4,49 +4,67 @@
|
|||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>添加模型 / 远光软件微调平台</title>
|
<title>添加模型 / 远光软件微调平台</title>
|
||||||
<script src="https://cdn.tailwindcss.com"></script>
|
<script src="../lib/tailwindcss/tailwind.js"></script>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/font-awesome@4.7.0/css/font-awesome.min.css" rel="stylesheet">
|
<link href="../lib/font-awesome/css/font-awesome.min.css" rel="stylesheet">
|
||||||
<script>
|
<style>
|
||||||
tailwind.config = {
|
.sidebar-section-title {
|
||||||
theme: {
|
padding: 0.5rem 1rem;
|
||||||
extend: {
|
font-size: 0.75rem;
|
||||||
colors: {
|
color: rgba(191, 203, 217, 0.7);
|
||||||
primary: '#1890ff',
|
font-weight: 500;
|
||||||
sidebarBg: '#001529',
|
text-transform: uppercase;
|
||||||
sidebarText: '#bfcbd9',
|
letter-spacing: 0.05em;
|
||||||
headerBg: '#fff',
|
|
||||||
danger: '#f5222d',
|
|
||||||
success: '#52c41a',
|
|
||||||
},
|
|
||||||
fontFamily: {
|
|
||||||
sans: ['Inter', 'system-ui', 'sans-serif'],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
.nav-link:hover {
|
||||||
<style type="text/tailwindcss">
|
background-color: rgba(0, 21, 41, 0.2);
|
||||||
@layer utilities {
|
|
||||||
.sidebar-item-active {
|
|
||||||
@apply bg-primary/10 text-primary border-l-4 border-primary;
|
|
||||||
}
|
|
||||||
.sidebar-section-title {
|
|
||||||
@apply px-4 py-2 text-xs text-sidebarText/70 font-medium uppercase tracking-wider;
|
|
||||||
}
|
|
||||||
.form-input {
|
|
||||||
@apply w-full px-3 py-2 border border-gray-300 rounded-lg text-sm focus:border-primary focus:outline-none transition-colors;
|
|
||||||
}
|
|
||||||
.form-label {
|
|
||||||
@apply block text-sm font-medium text-gray-700 mb-1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
.form-input {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
}
|
||||||
|
.form-input:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.form-select {
|
||||||
|
width: 100%;
|
||||||
|
padding: 0.5rem 0.75rem;
|
||||||
|
border: 1px solid #d1d5db;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
font-size: 0.875rem;
|
||||||
|
transition: border-color 0.2s, outline 0.2s;
|
||||||
|
appearance: none;
|
||||||
|
background-color: white;
|
||||||
|
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
|
||||||
|
background-position: right 0.5rem center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-size: 1.5em 1.5em;
|
||||||
|
padding-right: 2.5rem;
|
||||||
|
}
|
||||||
|
.form-select:focus {
|
||||||
|
border-color: #1890ff;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.upload-area:hover,
|
||||||
|
.upload-area.drag-over {
|
||||||
|
border-color: #1890ff;
|
||||||
|
background-color: rgba(24, 144, 255, 0.05);
|
||||||
|
}
|
||||||
|
.bg-primary { background-color: #1890ff; }
|
||||||
|
.text-primary { color: #1890ff; }
|
||||||
|
.border-primary { border-color: #1890ff; }
|
||||||
|
:root { --primary: #1890ff; --danger: #f5222d; --success: #52c41a; }
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
<body class="antialiased bg-gray-50 flex h-screen overflow-hidden">
|
||||||
<!-- 侧边导航 -->
|
<!-- 侧边导航 -->
|
||||||
<aside class="w-64 bg-sidebarBg text-sidebarText flex-shrink-0 hidden md:block flex flex-col h-full">
|
<aside class="w-64 text-[#bfcbd9] flex-shrink-0 hidden md:block flex flex-col h-full" style="background-color: #001529;">
|
||||||
<!-- 平台LOGO区域 -->
|
<!-- 平台LOGO区域 -->
|
||||||
<div class="p-4 border-b border-sidebarBg/30 flex items-center">
|
<div class="p-4 border-b border-[#001529]/30 flex items-center">
|
||||||
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
<img src="../assets/logo/logo.png" alt="Logo" class="w-6 h-6 object-contain mr-2">
|
||||||
<span class="text-white font-medium">远光软件微调平台</span>
|
<span class="text-white font-medium">远光软件微调平台</span>
|
||||||
</div>
|
</div>
|
||||||
@@ -55,52 +73,52 @@
|
|||||||
<nav class="flex-1 overflow-y-auto py-2">
|
<nav class="flex-1 overflow-y-auto py-2">
|
||||||
<!-- 第一分区:模型服务 -->
|
<!-- 第一分区:模型服务 -->
|
||||||
<div class="sidebar-section-title">模型服务</div>
|
<div class="sidebar-section-title">模型服务</div>
|
||||||
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html" data-page="fine-tune" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cogs w-5 text-center"></i>
|
<i class="fa fa-cogs w-5 text-center"></i>
|
||||||
<span class="ml-2">模型调优</span>
|
<span class="ml-2">模型调优</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=my-models" data-page="my-models" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">我的模型</span>
|
<span class="ml-2">我的模型</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-eval" data-page="model-eval" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-line-chart w-5 text-center"></i>
|
<i class="fa fa-line-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">模型评测</span>
|
<span class="ml-2">模型评测</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-deploy" data-page="model-deploy" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-server w-5 text-center"></i>
|
<i class="fa fa-server w-5 text-center"></i>
|
||||||
<span class="ml-2">模型部署</span>
|
<span class="ml-2">模型部署</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第二分区:资源管理 -->
|
<!-- 第二分区:资源管理 -->
|
||||||
<div class="sidebar-section-title mt-6">资源管理</div>
|
<div class="sidebar-section-title mt-6">资源管理</div>
|
||||||
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=model-manage" data-page="model-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-cube w-5 text-center"></i>
|
<i class="fa fa-cube w-5 text-center"></i>
|
||||||
<span class="ml-2">模型管理</span>
|
<span class="ml-2">模型管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=dataset-manage" data-page="dataset-manage" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-file-text w-5 text-center"></i>
|
<i class="fa fa-file-text w-5 text-center"></i>
|
||||||
<span class="ml-2">数据集管理</span>
|
<span class="ml-2">数据集管理</span>
|
||||||
</a>
|
</a>
|
||||||
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=data-generate" data-page="data-generate" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-database w-5 text-center"></i>
|
<i class="fa fa-database w-5 text-center"></i>
|
||||||
<span class="ml-2">其他工具</span>
|
<span class="ml-2">其他工具</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- 第三分区:系统设置 -->
|
<!-- 第三分区:系统设置 -->
|
||||||
<div class="sidebar-section-title mt-6">系统设置</div>
|
<div class="sidebar-section-title mt-6">系统设置</div>
|
||||||
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-sidebarBg/20 transition-colors">
|
<a href="main.html?page=config" data-page="config" class="nav-link flex items-center px-4 py-2.5 hover:bg-[#001529]/20 transition-colors">
|
||||||
<i class="fa fa-bar-chart w-5 text-center"></i>
|
<i class="fa fa-bar-chart w-5 text-center"></i>
|
||||||
<span class="ml-2">平台性能</span>
|
<span class="ml-2">平台性能</span>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<!-- 底部信息区域 -->
|
<!-- 底部信息区域 -->
|
||||||
<div class="p-4 border-t border-sidebarBg/30 text-xs mt-auto">
|
<div class="p-4 border-t border-[#001529]/30 text-xs mt-auto">
|
||||||
<div class="mb-2 text-sidebarText/80">默认业务空间</div>
|
<div class="mb-2 text-[#bfcbd9]/80">默认业务空间</div>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<span class="text-sidebarText">版本 v1.0.0</span>
|
<span class="text-[#bfcbd9]">版本 v1.0.0</span>
|
||||||
<i class="fa fa-question-circle-o text-sidebarText/70"></i>
|
<i class="fa fa-question-circle-o text-[#bfcbd9]/70"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
@@ -108,7 +126,7 @@
|
|||||||
<!-- 主内容区 -->
|
<!-- 主内容区 -->
|
||||||
<div class="flex-1 flex flex-col overflow-hidden">
|
<div class="flex-1 flex flex-col overflow-hidden">
|
||||||
<!-- 顶部导航 -->
|
<!-- 顶部导航 -->
|
||||||
<header class="bg-headerBg border-b border-gray-200 shadow-sm">
|
<header class="bg-white border-b border-gray-200 shadow-sm">
|
||||||
<div class="flex items-center justify-between px-6 h-14">
|
<div class="flex items-center justify-between px-6 h-14">
|
||||||
<div class="flex items-center space-x-4">
|
<div class="flex items-center space-x-4">
|
||||||
<a href="main.html?page=model-manage" class="text-gray-500 hover:text-gray-700 flex items-center">
|
<a href="main.html?page=model-manage" class="text-gray-500 hover:text-gray-700 flex items-center">
|
||||||
|
|||||||
Reference in New Issue
Block a user