From a5d25a7b04198e102dd5de10901348cdf78b7a12 Mon Sep 17 00:00:00 2001 From: Ethan Phelps <60406674+felpsey@users.noreply.github.com> Date: Thu, 2 Jan 2025 22:06:10 +0000 Subject: [PATCH] Modified module encoding logic to support change to Programme domain --- index.html | 6 +++- src/App.tsx | 73 +++++++++++++++++++---------------------- src/domain/Programme.ts | 2 -- 3 files changed, 39 insertions(+), 42 deletions(-) diff --git a/index.html b/index.html index e055199..0c09ce9 100644 --- a/index.html +++ b/index.html @@ -2,8 +2,12 @@ - + + + + + OU Degree Estimator diff --git a/src/App.tsx b/src/App.tsx index 8dfc600..0c70a2e 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -17,39 +17,37 @@ function App() { const [isModalOpen, setIsModalOpen] = useState(false); const [programme, setProgramme] = useState(new Programme("Example programme")); - // Decode search params when the component is mounted useEffect(() => { - // decodeSearchParams(); - }, []); + if(!programme.modules.current && (programme.modules.length != 0)) { + let encodedModuleData = encodeModuleData(programme.modules); - // Update encoded search params when modules state is changed - useEffect(() => { - if (programme.modules.length !== 0) { - // updateSearchParams() + updateSearchParams(encodedModuleData); } - }, [programme]); + }), [programme]; - // function decodeSearchParams(): void { - // let currentUrl: URL = new URL(document.location.href); - // let data: string|null = currentUrl.searchParams.get('data'); + function decodeSearchParams(): void { + let currentUrl: URL = new URL(document.location.href); + let data: string|null = currentUrl.searchParams.get('data'); - // if (data) { - // importUnstructuredModuleData(JSON.parse(atob(data))); - // } - // } + if (data) { + importModuleData(JSON.parse(atob(data))); + } + } - // function importUnstructuredModuleData(unstructuredModuleData: []): void { - // let structuredModuleData = unstructuredModuleData.map((module: any) => { - // return new Module(module._code, module._credits, module._stage, module._grade); - // }); + function importModuleData(unstructuredModuleData: []): void { + let modules = unstructuredModuleData.map((module: any) => { + return new Module(module._code, module._credits, module._stage, module._grade); + }); - // setProgramme(programme.modules.structuredModuleData); - // } + modules.forEach(module => { + addModuleData(module) + }); + } - // function encodeModuleData(): string { - // // Convert modules array to JSON then base64 encode - // return btoa(JSON.stringify(programme)); - // } + function encodeModuleData(modules): string { + // Convert modules array to JSON then base64 encode + return btoa(JSON.stringify(modules)); + } function newModuleEntry(): void { setIsModalOpen(true); @@ -63,23 +61,20 @@ function App() { // Return a new Programme instance with updated modules return new Programme(currentProgramme.title, updatedModules); }); + } - console.log(programme); -} - - // function updateSearchParams(): void { - // // Encode module data in memory - // let data = encodeModuleData(); - - // // Fetch the currentl URL, this will change each time this method is called - // let currentUrl = new URL(document.location.href); + function updateSearchParams(data): void { + // Fetch the currentl URL, this will change each time this method is called + let currentUrl = new URL(document.location.href); - // // Set encoded data on URL object on 'data' property - // currentUrl.searchParams.set('data', data); + // Set encoded data on URL object on 'data' property + currentUrl.searchParams.set('data', data); - // // Append encoded params to URI without reloading page - // history.replaceState({}, "", currentUrl.toString()); - // } + // Append encoded params to URI without reloading page + history.replaceState({}, "", currentUrl.toString()); + } + + decodeSearchParams(); return (
diff --git a/src/domain/Programme.ts b/src/domain/Programme.ts index 75c7dcf..640f273 100644 --- a/src/domain/Programme.ts +++ b/src/domain/Programme.ts @@ -40,8 +40,6 @@ export class Programme { get totalCredits() { this._totalCredits = this.calculateTotalCredits(); - console.log(this._totalCredits); - return this._totalCredits; }