mirror of
https://github.com/Wei-Shaw/claude-relay-service.git
synced 2026-01-23 00:53:33 +00:00
fix(timezone): 修复数据写入时的时区错误(关键修复)
- 修复 redis.js 中所有时区相关的日期获取方法 - 使用 getUTC* 方法替代 get* 方法获取正确的时区日期 - 影响:incrementTokenUsage, incrementAccountUsage, incrementDailyCost 等 - 修复 admin.js 中查询数据时的日期键生成 - 确保所有 Redis 键格式一致: - 日期:YYYY-MM-DD - 月份:YYYY-MM - 小时:YYYY-MM-DD:HH - 添加服务端时间标签,避免前端时区转换问题 这是核心修复,确保数据从源头就是正确的。
This commit is contained in:
@@ -1 +0,0 @@
|
||||
.custom-date-picker[data-v-5170898f] .el-input__inner{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.custom-date-picker[data-v-5170898f] .el-input__inner:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1));--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.custom-date-picker[data-v-5170898f] .el-input__inner{font-size:13px;padding:0 10px}.custom-date-picker[data-v-5170898f] .el-range-separator{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1));padding:0 2px}.custom-date-picker[data-v-5170898f] .el-range-input{font-size:13px}
|
||||
2
web/admin-spa/dist/index.html
vendored
2
web/admin-spa/dist/index.html
vendored
@@ -18,7 +18,7 @@
|
||||
<link rel="preconnect" href="https://cdnjs.cloudflare.com" crossorigin>
|
||||
<link rel="dns-prefetch" href="https://cdn.jsdelivr.net">
|
||||
<link rel="dns-prefetch" href="https://cdnjs.cloudflare.com">
|
||||
<script type="module" crossorigin src="/admin-next/assets/index-Di89_tIg.js"></script>
|
||||
<script type="module" crossorigin src="/admin-next/assets/index--NCcj1IN.js"></script>
|
||||
<link rel="modulepreload" crossorigin href="/admin-next/assets/vue-vendor-CKToUHZx.js">
|
||||
<link rel="modulepreload" crossorigin href="/admin-next/assets/vendor-BDiMbLwQ.js">
|
||||
<link rel="modulepreload" crossorigin href="/admin-next/assets/element-plus-B8Fs_0jW.js">
|
||||
|
||||
@@ -444,6 +444,11 @@ function createUsageTrendChart() {
|
||||
// 根据数据类型确定标签字段和格式
|
||||
const labelField = data[0]?.date ? 'date' : 'hour'
|
||||
const labels = data.map(d => {
|
||||
// 优先使用后端提供的label字段
|
||||
if (d.label) {
|
||||
return d.label
|
||||
}
|
||||
|
||||
if (labelField === 'hour') {
|
||||
// 格式化小时显示
|
||||
const date = new Date(d.hour)
|
||||
@@ -655,6 +660,11 @@ function createApiKeysUsageTrendChart() {
|
||||
|
||||
const chartData = {
|
||||
labels: data.map(d => {
|
||||
// 优先使用后端提供的label字段
|
||||
if (d.label) {
|
||||
return d.label
|
||||
}
|
||||
|
||||
if (labelField === 'hour') {
|
||||
// 格式化小时显示
|
||||
const date = new Date(d.hour)
|
||||
|
||||
Reference in New Issue
Block a user