An unsatisfying solution to the problem
Some checks failed
Build and Publish Docker Container / build (push) Failing after 2m57s

This commit is contained in:
Joshua Coles 2024-02-13 22:06:58 +00:00
parent 3d0c09bba9
commit 9752ede109
9 changed files with 162 additions and 80 deletions

View File

@ -1,12 +1,6 @@
/** @type {import('next').NextConfig} */
const nextConfig = {
output: 'standalone',
rewrites: async () => [
{
source: '/api/:path*',
destination: 'https://revision.joshuacoles.me/api/:path*',
},
],
}
module.exports = nextConfig

View File

@ -25,6 +25,7 @@
"react-dom": "^18.2.0",
"react-tooltip": "^5.26.1",
"reaviz": "^15.7.0",
"swr": "^2.2.4",
"zod": "^3.22.4"
},
"devDependencies": {

21
pnpm-lock.yaml generated
View File

@ -50,6 +50,9 @@ dependencies:
reaviz:
specifier: ^15.7.0
version: 15.7.0(@types/react@18.2.55)(prop-types@15.8.1)(react-dom@18.2.0)(react@18.2.0)
swr:
specifier: ^2.2.4
version: 2.2.4(react@18.2.0)
zod:
specifier: ^3.22.4
version: 3.22.4
@ -5808,6 +5811,16 @@ packages:
resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==}
engines: {node: '>= 0.4'}
/swr@2.2.4(react@18.2.0):
resolution: {integrity: sha512-njiZ/4RiIhoOlAaLYDqwz5qH/KZXVilRLvomrx83HjzCWTfa+InyfAjv05PSFxnmLzZkNO9ZfvgoqzAaEI4sGQ==}
peerDependencies:
react: ^16.11.0 || ^17.0.0 || ^18.0.0
dependencies:
client-only: 0.0.1
react: 18.2.0
use-sync-external-store: 1.2.0(react@18.2.0)
dev: false
/symbol-tree@3.2.4:
resolution: {integrity: sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==}
dev: true
@ -6161,6 +6174,14 @@ packages:
use-isomorphic-layout-effect: 1.1.2(@types/react@18.2.55)(react@18.2.0)
dev: false
/use-sync-external-store@1.2.0(react@18.2.0):
resolution: {integrity: sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==}
peerDependencies:
react: ^16.8.0 || ^17.0.0 || ^18.0.0
dependencies:
react: 18.2.0
dev: false
/util-deprecate@1.0.2:
resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==}

78
src/app/api/route.ts Normal file
View File

@ -0,0 +1,78 @@
import {NextRequest} from "next/server";
import {getData, OverviewConfig} from "@/data/fetchWithSQL";
export const semester1Revision: OverviewConfig = {
title: 'Semester 1 Revision',
periodKey: 'y5-s1-revision',
goalHours: 4,
subjects: [
{
projectId: 195482340,
},
{
title: 'Measure Theory',
projectId: 195519024,
},
{
title: 'Quantum Mechanics',
projectId: 195518593,
},
{
projectId: 195754611,
}
],
timePeriod: {
start: "2023-12-15T00:00:00.000Z",
end: "2024-01-25T00:00:00.000Z"
}
}
export const semester2: OverviewConfig = {
title: 'Semester 2',
periodKey: 'y5-s2',
goalHours: 7.5,
subjects: [
{
projectId: 195754611,
},
{
projectId: 199383703,
},
{
projectId: 199383691,
},
{
projectId: 198859760,
},
{
projectId: 199383698,
},
],
timePeriod: {
start: "2024-02-03T00:00:00.000Z",
end: "2024-05-10T00:00:00.000Z"
}
}
export type PeriodKey = keyof typeof periodMap;
const periodMap = {
'y5-s1-revision': semester1Revision,
'y5-s2': semester2,
}
export async function GET(request: NextRequest): Promise<Response> {
const period = request.nextUrl.searchParams.get('period');
if (period == null) {
return new Response('No period provided', {status: 400});
}
if (!periodMap.hasOwnProperty(period)) {
return new Response('Invalid period', {status: 400});
}
const config = periodMap[period as keyof typeof periodMap];
const data = await getData(config);
return Response.json(data)
}

View File

@ -1,30 +1,6 @@
import OverviewPage, {OverviewConfig} from "@/components/OverviewPage";
const semester1Revision: OverviewConfig = {
title: 'Semester 1 Revision',
goalHours: 4,
subjects: [
{
projectId: 195482340,
},
{
title: 'Measure Theory',
projectId: 195519024,
},
{
title: 'Quantum Mechanics',
projectId: 195518593,
},
{
projectId: 195754611,
}
],
timePeriod: {
start: "2023-12-15T00:00:00.000Z",
end: "2024-01-25T00:00:00.000Z"
}
}
import {semester1Revision} from "@/app/api/route";
import OverviewPageWrapper from "@/components/PageWrapper";
export default function Home() {
return <OverviewPage config={semester1Revision}/>
return <OverviewPageWrapper config={semester1Revision}/>
}

View File

@ -1,31 +1,6 @@
import OverviewPage, {OverviewConfig} from "@/components/OverviewPage";
const semester2: OverviewConfig = {
title: 'Semester 2',
goalHours: 7.5,
subjects: [
{
projectId: 195754611,
},
{
projectId: 199383703,
},
{
projectId: 199383691,
},
{
projectId: 198859760,
},
{
projectId: 199383698,
},
],
timePeriod: {
start: "2024-02-03T00:00:00.000Z",
end: "2024-05-10T00:00:00.000Z"
}
}
import {semester2} from "@/app/api/route";
import OverviewPageWrapper from "@/components/PageWrapper";
export default function Home() {
return <OverviewPage config={semester2}/>
return <OverviewPageWrapper config={semester2}/>
}

View File

@ -1,28 +1,35 @@
"use client";
import {SubjectComparisonCard} from "@/components/cards/subjectComparisonCard";
import {CalendarOverviewCard} from "@/components/cards/calendarOverviewCard";
import {SubjectOverviewCard} from "@/components/cards/subjectOverviewCard";
import {getDataSQL} from "@/data/fetchWithSQL";
import {PeriodKey} from "@/app/api/route";
import useSWR from "swr";
import {Data} from "@/data/fetchData";
import {OverviewConfig} from "@/data/fetchWithSQL";
export interface OverviewConfig {
title: string,
function useData(periodKey: PeriodKey, initialData: Data = {
projects: [],
timeEntries: [],
}): Data {
const {data} = useSWR(periodKey, async () => {
const res = await fetch(`/api?period=${periodKey}`);
const json = await res.json();
return json as Data;
});
subjects: {
title?: string,
projectId: number,
}[],
goalHours: number,
timePeriod: {
start: string,
end: string
},
return data ?? initialData;
}
export default async function OverviewPage({config}: {
config: OverviewConfig
export default function OverviewPage({
config,
initialData
}: {
config: OverviewConfig,
initialData?: Data,
}) {
const data = await getDataSQL(config);
const data = useData(config.periodKey, initialData);
return (
<main className="m-6">

View File

@ -0,0 +1,11 @@
"use server";
import {getData, OverviewConfig} from "@/data/fetchWithSQL";
import OverviewPage from "@/components/OverviewPage";
export default async function OverviewPageWrapper({config}: {
config: OverviewConfig
}) {
const data = await getData(config);
return <OverviewPage config={config} initialData={data}/>;
}

View File

@ -1,9 +1,26 @@
import {OverviewConfig} from "@/components/OverviewPage";
import {Data} from "@/data/fetchData";
import {db} from "@/data/database";
import * as dFns from "date-fns";
import {PeriodKey} from "@/app/api/route";
export async function getDataSQL(config: OverviewConfig): Promise<Data> {
export interface OverviewConfig {
title: string,
periodKey: PeriodKey,
subjects: {
title?: string,
projectId: number,
}[],
goalHours: number,
timePeriod: {
start: string,
end: string
},
}
export async function getData(config: OverviewConfig): Promise<Data> {
// If we're in build-time, we don't have access to the database
if (!db) {
return {
@ -12,6 +29,8 @@ export async function getDataSQL(config: OverviewConfig): Promise<Data> {
}
}
console.log('fetching data from SQL')
let projectIds = config.subjects.map((subject) => subject.projectId.toString());
const projects = await db.selectFrom('project')