|
1 | 1 | import classNames from "classnames";
|
2 | 2 | import { SessionOverview, SessionSummary } from "./data";
|
3 | 3 | import { navigate } from "raviger";
|
| 4 | +import groupBy from "just-group-by"; |
| 5 | + |
4 | 6 |
|
5 | 7 | export interface Props {
|
6 | 8 | sessionOverview: SessionOverview;
|
7 | 9 | selectedSessionId: string | null;
|
8 | 10 | }
|
9 | 11 |
|
10 | 12 | export function SessionOverviewList({sessionOverview, selectedSessionId}: Props): JSX.Element {
|
11 |
| - const sessionSummaries = [...sessionOverview.sessionSummaries]; |
| 13 | + const groups = groupBy(sessionOverview.sessionSummaries, (summary: SessionSummary): string => { |
| 14 | + return summary.creationTimestamp.substring(0, 10); |
| 15 | + }); |
| 16 | + console.log(groups); |
| 17 | + |
| 18 | + const groupNames = Object.getOwnPropertyNames(groups); |
| 19 | + groupNames.sort().reverse(); |
| 20 | + return <> |
| 21 | + { |
| 22 | + groupNames.map((name) => formatGroup(groups[name], selectedSessionId)) |
| 23 | + } |
| 24 | + </>; |
| 25 | +} |
| 26 | + |
| 27 | +function formatGroup(sessionSummaries: SessionSummary[], selectedSessionId: string | null): JSX.Element { |
| 28 | + const sortedSessionSummaries = [...sessionSummaries]; |
12 | 29 | const cmp = (a: SessionSummary, b: SessionSummary) => {
|
13 |
| - if (a.creationTimestamp < b.creationTimestamp) { |
| 30 | + if (a.creationTimestamp > b.creationTimestamp) { |
14 | 31 | return -1;
|
15 | 32 | }
|
16 | 33 | return a.creationTimestamp === b.creationTimestamp ? 0 : 1;
|
17 | 34 | }
|
18 |
| - sessionSummaries.sort(cmp); |
| 35 | + sortedSessionSummaries.sort(cmp); |
| 36 | + |
| 37 | + const dateFormat = new Intl.DateTimeFormat("default", { dateStyle: "medium" }); |
| 38 | + |
| 39 | + const now = new Date(); |
| 40 | + const groupDay = new Date(Date.parse(sortedSessionSummaries[0].creationTimestamp)); |
| 41 | + const isToday = (now.getDay() === groupDay.getDay() && |
| 42 | + now.getMonth() === groupDay.getMonth() && |
| 43 | + now.getFullYear() === groupDay.getFullYear()); |
19 | 44 |
|
20 |
| - return <ul className="tabs"> |
| 45 | + return <> |
21 | 46 | {
|
22 |
| - sessionSummaries.map(s => { |
23 |
| - const onClick = () => { |
24 |
| - navigate(`/session/${s.id}`); |
25 |
| - }; |
26 |
| - return <li |
27 |
| - key={s.id} |
28 |
| - className={classNames({"tab": true, active: s.id === selectedSessionId})} |
29 |
| - onClick={onClick} |
30 |
| - > |
31 |
| - {s.title} |
32 |
| - </li>; |
33 |
| - }) |
| 47 | + !isToday && <p className="minor"> |
| 48 | + { |
| 49 | + dateFormat.format(Date.parse(sortedSessionSummaries[0].creationTimestamp)) |
| 50 | + } |
| 51 | + </p> |
34 | 52 | }
|
35 |
| - </ul>; |
| 53 | + <ul className="tabs"> |
| 54 | + { |
| 55 | + sortedSessionSummaries.map(s => { |
| 56 | + const onClick = () => { |
| 57 | + navigate(`/session/${s.id}`); |
| 58 | + }; |
| 59 | + return <li |
| 60 | + key={s.id} |
| 61 | + className={classNames({"tab": true, active: s.id === selectedSessionId})} |
| 62 | + onClick={onClick} |
| 63 | + > |
| 64 | + {s.title} |
| 65 | + </li>; |
| 66 | + }) |
| 67 | + } |
| 68 | + </ul> |
| 69 | + </>; |
36 | 70 | }
|
0 commit comments