2024-05-20 16:02:19 +03:00
|
|
|
import { endOfHourOrCurrentTime } from "./dateUtil";
|
2024-09-04 16:46:49 +03:00
|
|
|
import { TimeRange } from "@/types/timeline";
|
2024-02-23 03:03:34 +03:00
|
|
|
|
2024-03-30 21:44:12 +03:00
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @param timeRange
|
|
|
|
|
* @returns timeRange chunked into individual hours
|
|
|
|
|
*/
|
|
|
|
|
export function getChunkedTimeDay(timeRange: TimeRange): TimeRange[] {
|
|
|
|
|
const endOfThisHour = new Date(timeRange.before * 1000);
|
|
|
|
|
endOfThisHour.setSeconds(0, 0);
|
2024-03-27 00:03:58 +03:00
|
|
|
const data: TimeRange[] = [];
|
2024-03-30 21:44:12 +03:00
|
|
|
const startDay = new Date(timeRange.after * 1000);
|
2024-05-28 17:09:17 +03:00
|
|
|
startDay.setUTCMinutes(0, 0, 0);
|
2024-02-23 03:03:34 +03:00
|
|
|
let start = startDay.getTime() / 1000;
|
|
|
|
|
let end = 0;
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < 24; i++) {
|
2024-05-28 17:09:17 +03:00
|
|
|
startDay.setHours(startDay.getHours() + 1);
|
2024-02-23 03:03:34 +03:00
|
|
|
|
|
|
|
|
if (startDay > endOfThisHour) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
end = endOfHourOrCurrentTime(startDay.getTime() / 1000);
|
|
|
|
|
data.push({
|
2024-03-27 00:03:58 +03:00
|
|
|
after: start,
|
|
|
|
|
before: end,
|
2024-02-23 03:03:34 +03:00
|
|
|
});
|
|
|
|
|
start = startDay.getTime() / 1000;
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-30 21:44:12 +03:00
|
|
|
data.push({
|
|
|
|
|
after: start,
|
|
|
|
|
before: Math.floor(timeRange.before),
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
return data;
|
2024-02-23 03:03:34 +03:00
|
|
|
}
|
2024-03-04 07:21:30 +03:00
|
|
|
|
2026-05-01 20:25:26 +03:00
|
|
|
/**
|
|
|
|
|
* Find the chunk index that contains the given timestamp.
|
|
|
|
|
* Uses half-open intervals [after, before) for all chunks except the last,
|
|
|
|
|
* which uses a closed interval [after, before] so the terminal boundary
|
|
|
|
|
* is always reachable.
|
|
|
|
|
*/
|
|
|
|
|
export function findChunkIndex(chunks: TimeRange[], timestamp: number): number {
|
|
|
|
|
return chunks.findIndex((chunk, i) => {
|
|
|
|
|
const isLast = i === chunks.length - 1;
|
|
|
|
|
return (
|
|
|
|
|
chunk.after <= timestamp &&
|
|
|
|
|
(isLast ? chunk.before >= timestamp : chunk.before > timestamp)
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-04 07:21:30 +03:00
|
|
|
export function getChunkedTimeRange(
|
|
|
|
|
startTimestamp: number,
|
|
|
|
|
endTimestamp: number,
|
|
|
|
|
) {
|
|
|
|
|
const endOfThisHour = new Date();
|
|
|
|
|
endOfThisHour.setHours(endOfThisHour.getHours() + 1, 0, 0, 0);
|
2024-03-27 00:03:58 +03:00
|
|
|
const data: TimeRange[] = [];
|
2024-03-04 07:21:30 +03:00
|
|
|
const startDay = new Date(startTimestamp * 1000);
|
2025-07-17 17:17:58 +03:00
|
|
|
startDay.setUTCMinutes(0, 0, 0);
|
2024-03-04 07:21:30 +03:00
|
|
|
let start = startDay.getTime() / 1000;
|
|
|
|
|
let end = 0;
|
|
|
|
|
|
|
|
|
|
while (end < endTimestamp) {
|
|
|
|
|
startDay.setHours(startDay.getHours() + 1);
|
|
|
|
|
|
2024-03-12 02:31:05 +03:00
|
|
|
if (startDay > endOfThisHour) {
|
2024-03-04 07:21:30 +03:00
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
end = endOfHourOrCurrentTime(startDay.getTime() / 1000);
|
|
|
|
|
data.push({
|
2024-03-27 00:03:58 +03:00
|
|
|
after: start,
|
|
|
|
|
before: end,
|
2024-03-04 07:21:30 +03:00
|
|
|
});
|
|
|
|
|
start = startDay.getTime() / 1000;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return { start: startTimestamp, end: endTimestamp, ranges: data };
|
|
|
|
|
}
|