bolt.new/packages/bolt/app/components/sidebar/date-binning.ts

60 lines
1.2 KiB
TypeScript
Raw Normal View History

import { format, isAfter, isThisWeek, isThisYear, isToday, isYesterday, subDays } from 'date-fns';
import type { ChatHistoryItem } from '~/lib/persistence';
2024-07-31 21:21:40 +00:00
type Bin = { category: string; items: ChatHistoryItem[] };
2024-07-31 21:21:40 +00:00
export function binDates(_list: ChatHistoryItem[]) {
2024-07-31 21:21:40 +00:00
const list = _list.toSorted((a, b) => Date.parse(b.timestamp) - Date.parse(a.timestamp));
const binLookup: Record<string, Bin> = {};
const bins: Array<Bin> = [];
list.forEach((item) => {
const category = dateCategory(new Date(item.timestamp));
if (!(category in binLookup)) {
const bin = {
category,
items: [item],
};
binLookup[category] = bin;
2024-07-31 21:21:40 +00:00
bins.push(bin);
} else {
binLookup[category].items.push(item);
}
});
return bins;
}
function dateCategory(date: Date) {
if (isToday(date)) {
return 'Today';
}
if (isYesterday(date)) {
return 'Yesterday';
}
if (isThisWeek(date)) {
// e.g., "Monday"
return format(date, 'eeee');
2024-07-31 21:21:40 +00:00
}
const thirtyDaysAgo = subDays(new Date(), 30);
if (isAfter(date, thirtyDaysAgo)) {
return 'Last 30 Days';
}
if (isThisYear(date)) {
// e.g., "July"
return format(date, 'MMMM');
2024-07-31 21:21:40 +00:00
}
// e.g., "July 2023"
return format(date, 'MMMM yyyy');
2024-07-31 21:21:40 +00:00
}