agent-ecosystem/src/renderer/utils/dateGrouping.ts

91 lines
2.8 KiB
TypeScript

/**
* Date-based session grouping utility.
* Groups sessions by relative date categories: Today, Yesterday, Previous 7 Days, Older.
*/
import { differenceInDays, isToday, isYesterday } from 'date-fns';
import { DATE_CATEGORY_ORDER } from '../types/tabs';
import type { Session } from '../types/data';
import type { DateCategory, DateGroupedSessions } from '../types/tabs';
/**
* Groups sessions by relative date category.
* Sessions are categorized based on their createdAt timestamp:
* - Today: Sessions created today
* - Yesterday: Sessions created yesterday
* - Previous 7 Days: Sessions created 2-7 days ago
* - Older: Sessions created more than 7 days ago
*
* Within each category, sessions maintain their original sort order.
*
* @param sessions Array of sessions to group
* @returns Object with sessions grouped by date category
*/
export function groupSessionsByDate(sessions: Session[]): DateGroupedSessions {
const now = new Date();
return sessions.reduce<DateGroupedSessions>(
(acc, session) => {
const sessionDate = new Date(session.createdAt);
if (isToday(sessionDate)) {
acc.Today.push(session);
} else if (isYesterday(sessionDate)) {
acc.Yesterday.push(session);
} else if (differenceInDays(now, sessionDate) <= 7) {
acc['Previous 7 Days'].push(session);
} else {
acc.Older.push(session);
}
return acc;
},
{ Today: [], Yesterday: [], 'Previous 7 Days': [], Older: [] }
);
}
/**
* Get non-empty date categories in display order.
* Useful for rendering only categories that have sessions.
*
* @param grouped The grouped sessions object
* @returns Array of non-empty category names in display order
*/
export function getNonEmptyCategories(grouped: DateGroupedSessions): DateCategory[] {
return DATE_CATEGORY_ORDER.filter((category) => grouped[category].length > 0);
}
/**
* Separates sessions into pinned and unpinned groups.
* Pinned sessions are ordered by pin order (from pinnedSessionIds iteration order).
*
* @param sessions All sessions
* @param pinnedSessionIds Ordered array of pinned session IDs (most recently pinned first)
* @returns Object with pinned and unpinned session arrays
*/
export function separatePinnedSessions(
sessions: Session[],
pinnedSessionIds: string[]
): { pinned: Session[]; unpinned: Session[] } {
if (pinnedSessionIds.length === 0) {
return { pinned: [], unpinned: sessions };
}
const pinnedSet = new Set(pinnedSessionIds);
const sessionMap = new Map(sessions.map((s) => [s.id, s]));
// Preserve pin order from pinnedSessionIds
const pinned: Session[] = [];
for (const id of pinnedSessionIds) {
const session = sessionMap.get(id);
if (session) {
pinned.push(session);
}
}
const unpinned = sessions.filter((s) => !pinnedSet.has(s.id));
return { pinned, unpinned };
}