fix: wrong record loss duration
This commit is contained in:
@@ -99,16 +99,25 @@ const formatTime = (timeStr: string) => {
|
|||||||
const formatDuration = (startTime: string, endTime: string) => {
|
const formatDuration = (startTime: string, endTime: string) => {
|
||||||
const start = dayjs(startTime);
|
const start = dayjs(startTime);
|
||||||
const end = dayjs(endTime);
|
const end = dayjs(endTime);
|
||||||
const diff = end.diff(start);
|
const diffMs = end.diff(start);
|
||||||
const dur = dayjs.duration(diff);
|
|
||||||
|
|
||||||
if (dur.asHours() >= 1) {
|
const isNegative = diffMs < 0;
|
||||||
return `${Math.floor(dur.asHours())}小时${dur.minutes()}分钟`;
|
const durAbs = dayjs.duration(Math.abs(diffMs));
|
||||||
} else if (dur.asMinutes() >= 1) {
|
|
||||||
return `${dur.minutes()}分钟${dur.seconds()}秒`;
|
const hours = Math.floor(durAbs.asHours());
|
||||||
|
const minutes = durAbs.minutes();
|
||||||
|
const seconds = durAbs.seconds();
|
||||||
|
|
||||||
|
let result: string;
|
||||||
|
if (hours > 0) {
|
||||||
|
result = `${hours}小时${minutes}分${seconds}秒`;
|
||||||
|
} else if (minutes > 0) {
|
||||||
|
result = `${minutes}分${seconds}秒`;
|
||||||
} else {
|
} else {
|
||||||
return `${dur.seconds()}秒`;
|
result = `${seconds}秒`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return isNegative ? `-${result}` : result;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user