An unsatisfying solution to the problem
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build and Publish Docker Container / build (push) Failing after 2m57s
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build and Publish Docker Container / build (push) Failing after 2m57s
				
			This commit is contained in:
		
							parent
							
								
									3d0c09bba9
								
							
						
					
					
						commit
						9752ede109
					
				| @ -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 | ||||
|  | ||||
| @ -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
									
									
									
								
							
							
						
						
									
										21
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @ -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
									
								
							
							
						
						
									
										78
									
								
								src/app/api/route.ts
									
									
									
									
									
										Normal 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) | ||||
| } | ||||
| @ -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}/> | ||||
| } | ||||
|  | ||||
| @ -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}/> | ||||
| } | ||||
|  | ||||
| @ -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"> | ||||
|  | ||||
							
								
								
									
										11
									
								
								src/components/PageWrapper.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/components/PageWrapper.tsx
									
									
									
									
									
										Normal 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}/>; | ||||
| } | ||||
| @ -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') | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user