generated from kevisual/vite-react-template
chore: 更新依赖版本并优化仓库页面移动端布局
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
26
package.json
26
package.json
@@ -20,20 +20,20 @@
|
|||||||
"@ai-sdk/anthropic": "^3.0.58",
|
"@ai-sdk/anthropic": "^3.0.58",
|
||||||
"@ai-sdk/openai": "^3.0.41",
|
"@ai-sdk/openai": "^3.0.41",
|
||||||
"@ai-sdk/openai-compatible": "^2.0.35",
|
"@ai-sdk/openai-compatible": "^2.0.35",
|
||||||
"@base-ui/react": "^1.2.0",
|
"@base-ui/react": "^1.3.0",
|
||||||
"@kevisual/api": "^0.0.62",
|
"@kevisual/api": "^0.0.64",
|
||||||
"@kevisual/cnb": "^0.0.33",
|
"@kevisual/cnb": "^0.0.45",
|
||||||
"@kevisual/cnb-ai": "^0.0.2",
|
"@kevisual/cnb-ai": "^0.0.2",
|
||||||
"@kevisual/context": "^0.0.8",
|
"@kevisual/context": "^0.0.8",
|
||||||
"@kevisual/kv-login": "^0.1.17",
|
"@kevisual/kv-login": "^0.1.17",
|
||||||
"@kevisual/router": "0.0.85",
|
"@kevisual/router": "0.1.1",
|
||||||
"@tanstack/react-router": "^1.166.2",
|
"@tanstack/react-router": "^1.166.7",
|
||||||
"@uiw/react-codemirror": "^4.25.7",
|
"@uiw/react-codemirror": "^4.25.8",
|
||||||
"ai": "^6.0.116",
|
"ai": "^6.0.116",
|
||||||
"class-variance-authority": "^0.7.1",
|
"class-variance-authority": "^0.7.1",
|
||||||
"clsx": "^2.1.1",
|
"clsx": "^2.1.1",
|
||||||
"cmdk": "^1.1.1",
|
"cmdk": "^1.1.1",
|
||||||
"dayjs": "^1.11.19",
|
"dayjs": "^1.11.20",
|
||||||
"es-toolkit": "^1.45.1",
|
"es-toolkit": "^1.45.1",
|
||||||
"fuse.js": "^7.1.0",
|
"fuse.js": "^7.1.0",
|
||||||
"idb-keyval": "^6.2.2",
|
"idb-keyval": "^6.2.2",
|
||||||
@@ -53,21 +53,21 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@codemirror/lang-yaml": "^6.1.2",
|
"@codemirror/lang-yaml": "^6.1.2",
|
||||||
"@kevisual/gitea": "^0.0.6",
|
"@kevisual/gitea": "^0.0.6",
|
||||||
"@kevisual/query": "0.0.52",
|
"@kevisual/query": "0.0.53",
|
||||||
"@kevisual/types": "^0.0.12",
|
"@kevisual/types": "^0.0.12",
|
||||||
"@tailwindcss/vite": "^4.2.1",
|
"@tailwindcss/vite": "^4.2.1",
|
||||||
"@tanstack/react-query": "^5.90.21",
|
"@tanstack/react-query": "^5.90.21",
|
||||||
"@tanstack/react-router-devtools": "^1.166.2",
|
"@tanstack/react-router-devtools": "^1.166.7",
|
||||||
"@tanstack/router-plugin": "^1.166.2",
|
"@tanstack/router-plugin": "^1.166.7",
|
||||||
"@types/node": "^25.3.3",
|
"@types/node": "^25.5.0",
|
||||||
"@types/react": "^19.2.14",
|
"@types/react": "^19.2.14",
|
||||||
"@types/react-dom": "^19.2.3",
|
"@types/react-dom": "^19.2.3",
|
||||||
"@vitejs/plugin-react": "^5.1.4",
|
"@vitejs/plugin-react": "^6.0.0",
|
||||||
"dotenv": "^17.3.1",
|
"dotenv": "^17.3.1",
|
||||||
"tailwind-merge": "^3.5.0",
|
"tailwind-merge": "^3.5.0",
|
||||||
"tailwindcss": "^4.2.1",
|
"tailwindcss": "^4.2.1",
|
||||||
"tw-animate-css": "^1.4.0",
|
"tw-animate-css": "^1.4.0",
|
||||||
"typescript": "^5.9.3",
|
"typescript": "^5.9.3",
|
||||||
"vite": "^8.0.0-beta.14"
|
"vite": "^8.0.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -65,16 +65,18 @@ export const App = () => {
|
|||||||
<div className="min-h-screen bg-neutral-50 flex flex-col">
|
<div className="min-h-screen bg-neutral-50 flex flex-col">
|
||||||
<div className="container mx-auto p-4 md:p-6 max-w-7xl flex-1">
|
<div className="container mx-auto p-4 md:p-6 max-w-7xl flex-1">
|
||||||
<div className="mb-6 md:mb-8 flex flex-col gap-4">
|
<div className="mb-6 md:mb-8 flex flex-col gap-4">
|
||||||
<div className="flex flex-col gap-3">
|
<div className="flex flex-col sm:flex-row sm:justify-between gap-3">
|
||||||
<div className="flex items-center justify-between">
|
<div className=''>
|
||||||
<h1 className="text-2xl md:text-4xl font-bold text-neutral-900 flex gap-2 items-center">
|
<div className="flex items-center justify-between">
|
||||||
<span className="hidden md:inline">仓库列表</span>
|
<h1 className="text-2xl md:text-4xl font-bold text-neutral-900 flex gap-2 items-center">
|
||||||
<span className="md:hidden">仓库</span>
|
<span className="hidden md:inline">仓库列表</span>
|
||||||
<Settings className="inline-block h-5 w-5 text-neutral-400 hover:text-neutral-600 cursor-pointer" onClick={() => navigate({ to: '/config' })} />
|
<span className="md:hidden">仓库</span>
|
||||||
</h1>
|
<Settings className="inline-block h-5 w-5 text-neutral-400 hover:text-neutral-600 cursor-pointer" onClick={() => navigate({ to: '/config' })} />
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<p className="text-neutral-600 text-sm md:text-base">共 {list.length} 个仓库</p>
|
||||||
</div>
|
</div>
|
||||||
<p className="text-neutral-600 text-sm md:text-base">共 {list.length} 个仓库</p>
|
<div className="flex flex-wrap items-center gap-2 md:ml-auto">
|
||||||
<div className="flex flex-wrap items-center gap-2">
|
|
||||||
<Button
|
<Button
|
||||||
onClick={() => refresh()}
|
onClick={() => refresh()}
|
||||||
variant="outline"
|
variant="outline"
|
||||||
|
|||||||
Reference in New Issue
Block a user