Add support for penalising overtime to the heatmap
All checks were successful
Build and Publish Docker Container / build (push) Successful in 3m44s
All checks were successful
Build and Publish Docker Container / build (push) Successful in 3m44s
This commit is contained in:
parent
65e8899426
commit
f350018eb2
@ -1,5 +1,6 @@
|
||||
import React from "react";
|
||||
import * as dFns from "date-fns";
|
||||
import * as R from 'ramda';
|
||||
|
||||
interface DateValue {
|
||||
date: Date;
|
||||
@ -12,6 +13,7 @@ interface Props {
|
||||
data: DateValue[];
|
||||
className?: string;
|
||||
goal: number;
|
||||
penaliseOvertime?: boolean;
|
||||
}
|
||||
|
||||
function GitHubCalendarHeatmap({
|
||||
@ -19,7 +21,8 @@ function GitHubCalendarHeatmap({
|
||||
endDate,
|
||||
data,
|
||||
className,
|
||||
goal
|
||||
goal,
|
||||
penaliseOvertime = false,
|
||||
}: Props) {
|
||||
const numDays = dFns.differenceInDays(endDate, startDate);
|
||||
|
||||
@ -38,22 +41,47 @@ function GitHubCalendarHeatmap({
|
||||
const weekGoalTime = 5 * dayGoalTime;
|
||||
|
||||
const getColorForValue = (value: number, goalTime: number): string => {
|
||||
const values = [
|
||||
"#eeeeee",
|
||||
"#d6e685",
|
||||
"#8cc665",
|
||||
"#44a340",
|
||||
"#1e6823",
|
||||
]
|
||||
const buckets = [
|
||||
{
|
||||
min: -Infinity,
|
||||
max: 0,
|
||||
color: '#eeeeee'
|
||||
},
|
||||
{
|
||||
min: 0,
|
||||
max: 0.40,
|
||||
color: '#d6e685'
|
||||
},
|
||||
{
|
||||
min: 0.40,
|
||||
max: 0.50,
|
||||
color: '#8cc665'
|
||||
},
|
||||
{
|
||||
min: 0.50,
|
||||
max: 0.90,
|
||||
color: '#44a340'
|
||||
},
|
||||
{
|
||||
min: 0.90,
|
||||
// If penalising overtime, the max is 1.125, otherwise it's infinity (ie this is the last bucket)
|
||||
max: penaliseOvertime ? 1.125 : Infinity,
|
||||
color: '#1e6823'
|
||||
},
|
||||
{
|
||||
min: 1.125,
|
||||
max: 1.25,
|
||||
color: '#f59e0b'
|
||||
},
|
||||
{
|
||||
min: 1.25,
|
||||
max: Infinity,
|
||||
color: '#ef4444'
|
||||
},
|
||||
];
|
||||
|
||||
const linearValue = Math.round((value / goalTime) * 4);
|
||||
|
||||
// If we did something, but not enough to reach the first level, return 1
|
||||
if (linearValue == 0 && value > 0) return values[1];
|
||||
|
||||
// Clamp to the granularity
|
||||
if (linearValue > 4) return values[4];
|
||||
return values[linearValue];
|
||||
const linearValue = value / goalTime;
|
||||
return R.find(minMax => minMax.min < linearValue && linearValue <= minMax.max, buckets)!.color;
|
||||
};
|
||||
|
||||
const getWeekTotal = (weekIndex: number): number => {
|
||||
|
||||
@ -47,6 +47,7 @@ export default function OverviewPage({
|
||||
<CalendarOverviewCard
|
||||
data={data}
|
||||
goal={config.goalHours}
|
||||
penaliseOvertime={config.penaliseOvertime}
|
||||
startTime={config.timePeriod.start}
|
||||
endTime={config.timePeriod.end}
|
||||
/>
|
||||
|
||||
@ -38,11 +38,13 @@ function useCalendarData(data: Data, initialDate: Date, endDate: Date) {
|
||||
export function CalendarOverviewCard({
|
||||
data,
|
||||
goal,
|
||||
penaliseOvertime,
|
||||
startTime,
|
||||
endTime,
|
||||
}: {
|
||||
data: Data,
|
||||
goal: number,
|
||||
penaliseOvertime?: boolean,
|
||||
startTime: string,
|
||||
endTime: string,
|
||||
}) {
|
||||
@ -54,7 +56,7 @@ export function CalendarOverviewCard({
|
||||
<Tooltip id="calendar-tooltip"/>
|
||||
<Title>Semester Overview</Title>
|
||||
<div className="m-2">
|
||||
<HeatMap startDate={initialDate} endDate={endDate} data={calendarData} goal={goal}/>
|
||||
<HeatMap startDate={initialDate} endDate={endDate} data={calendarData} goal={goal} penaliseOvertime={penaliseOvertime}/>
|
||||
</div>
|
||||
</Card>
|
||||
}
|
||||
|
||||
@ -30,6 +30,7 @@ export interface OverviewConfig {
|
||||
}[],
|
||||
|
||||
goalHours: number,
|
||||
penaliseOvertime?: boolean,
|
||||
|
||||
timePeriod: {
|
||||
start: string,
|
||||
|
||||
@ -29,7 +29,8 @@ export const semester1Revision: OverviewConfig = {
|
||||
export const semester2: OverviewConfig = {
|
||||
title: 'Semester 2',
|
||||
periodKey: 'y5-s2',
|
||||
goalHours: 7.5,
|
||||
goalHours: 6,
|
||||
penaliseOvertime: true,
|
||||
subjects: [
|
||||
{
|
||||
projectId: 195754611,
|
||||
|
||||
Loading…
Reference in New Issue
Block a user