From 73a4694ab268e74c2f398c703d133e1391375439 Mon Sep 17 00:00:00 2001 From: ian Date: Sat, 28 Dec 2024 00:17:09 +0100 Subject: [PATCH 1/5] Prepare a system stats global state for future "new version banner" --- www/src/Pages/HomePage.jsx | 130 -------------------------------- www/src/Pages/HomePage.tsx | 95 +++++++++++++++++++++++ www/src/Store/useSystemStats.ts | 107 ++++++++++++++++++++++++++ 3 files changed, 202 insertions(+), 130 deletions(-) delete mode 100644 www/src/Pages/HomePage.jsx create mode 100644 www/src/Pages/HomePage.tsx create mode 100644 www/src/Store/useSystemStats.ts diff --git a/www/src/Pages/HomePage.jsx b/www/src/Pages/HomePage.jsx deleted file mode 100644 index 240274c19..000000000 --- a/www/src/Pages/HomePage.jsx +++ /dev/null @@ -1,130 +0,0 @@ -import React, { useEffect, useState, useContext } from 'react'; -import { AppContext } from '../Contexts/AppContext'; -import Http from '../Services/Http'; -import { useTranslation } from 'react-i18next'; - -import Section from '../Components/Section'; - -import WebApi from '../Services/WebApi'; - -const percentage = (x, y) => ((x / y) * 100).toFixed(2); -const toKB = (x) => parseFloat((x / 1024).toFixed(2)); - -export default function HomePage() { - const [latestVersion, setLatestVersion] = useState(''); - const [latestDownloadUrl, setLatestDownloadUrl] = useState(''); - const [currentVersion, setCurrentVersion] = useState(''); - const [boardConfigProperties, setBoardConfigProperties] = useState({}); - const [memoryReport, setMemoryReport] = useState(null); - - const { t } = useTranslation(''); - - const { setLoading } = useContext(AppContext); - - useEffect(() => { - WebApi.getFirmwareVersion(setLoading) - .then( - ({ version, boardConfigLabel, boardConfigFileName, boardConfig }) => { - setCurrentVersion(version); - setBoardConfigProperties({ - label: boardConfigLabel, - fileName: boardConfigFileName, - }); - Http.get( - 'https://api.github.com/repos/OpenStickCommunity/GP2040-CE/releases/latest', - ) - .then((response) => { - const latestTag = response.data.tag_name; - setLatestVersion(latestTag); - setLatestDownloadUrl( - response.data?.assets?.find(({ name }) => { - return ( - name - ?.substring(name.lastIndexOf('_') + 1) - ?.replace('.uf2', '') - ?.toLowerCase() === boardConfig.toLowerCase() - ); - })?.browser_download_url || - `https://github.com/OpenStickCommunity/GP2040-CE/releases/tag/${latestTag}`, - ); - }) - .catch(console.error); - }, - ) - .catch(console.error); - - WebApi.getMemoryReport(setLoading) - .then((response) => { - const { - totalFlash, - usedFlash, - physicalFlash, - staticAllocs, - totalHeap, - usedHeap, - } = response; - setMemoryReport({ - totalFlash: toKB(totalFlash), - usedFlash: toKB(usedFlash), - physicalFlash: toKB(physicalFlash), - staticAllocs: toKB(staticAllocs), - totalHeap: toKB(totalHeap), - usedHeap: toKB(usedHeap), - percentageFlash: percentage(usedFlash, totalFlash), - percentageHeap: percentage(usedHeap, totalHeap), - }); - }) - .catch(console.error); - }, []); - - return ( -
-

{t('HomePage:header-text')}

-

{t('HomePage:sub-header-text')}

-
-
-
- {t('HomePage:version-text')} -
-
{`${boardConfigProperties.label} (${boardConfigProperties.fileName}.uf2)`}
-
{t('HomePage:current-text', { version: currentVersion })}
-
{t('HomePage:latest-text', { version: latestVersion })}
- {latestVersion && - currentVersion?.split('-').length == 1 && - currentVersion !== latestVersion && ( -
- - {t('HomePage:get-update-text')} - -
- )} - {memoryReport && ( -
- {t('HomePage:memory-header-text')} -
- {t('HomePage:memory-flash-text')}: {memoryReport.usedFlash} /{' '} - {memoryReport.totalFlash} ({memoryReport.percentageFlash}%) -
-
- {t('HomePage:memory-heap-text')}: {memoryReport.usedHeap} /{' '} - {memoryReport.totalHeap} ({memoryReport.percentageHeap}%) -
-
- {t('HomePage:memory-static-allocations-text')}:{' '} - {memoryReport.staticAllocs} -
-
- {t('HomePage:memory-board-text')}: {memoryReport.physicalFlash} -
-
- )} -
-
-
- ); -} diff --git a/www/src/Pages/HomePage.tsx b/www/src/Pages/HomePage.tsx new file mode 100644 index 000000000..738d608fa --- /dev/null +++ b/www/src/Pages/HomePage.tsx @@ -0,0 +1,95 @@ +import React, { useEffect } from 'react'; +import { useTranslation } from 'react-i18next'; +import { ProgressBar } from 'react-bootstrap'; + +import useSystemStats from '../Store/useSystemStats'; +import Section from '../Components/Section'; + +export default function HomePage() { + const { t } = useTranslation(''); + const { + latestVersion, + latestDownloadUrl, + currentVersion, + boardConfigProperties, + memoryReport, + getSystemStats, + loading, + } = useSystemStats(); + + useEffect(() => { + getSystemStats(); + }, []); + + if (loading) { + return ( +
+
+ {t('Common:loading-text')} +
+
+ ); + } + + return ( +
+

{t('HomePage:header-text')}

+

{t('HomePage:sub-header-text')}

+
+
+ {t('HomePage:version-text')} +
{`${boardConfigProperties.label} (${boardConfigProperties.fileName}.uf2)`}
+
+ {t('HomePage:current-text', { version: currentVersion })} +
+
+ {t('HomePage:latest-text', { version: latestVersion })} +
+ {currentVersion !== latestVersion && ( +
+ + {t('HomePage:get-update-text')} + +
+ )} + + + {t('HomePage:memory-header-text')} + +
+ {t('HomePage:memory-flash-text')}: {memoryReport.usedFlash} /{' '} + {memoryReport.totalFlash} ({memoryReport.percentageFlash}%) +
+
+ {t('HomePage:memory-heap-text')}: {memoryReport.usedHeap} /{' '} + {memoryReport.totalHeap} ({memoryReport.percentageHeap}%) +
+
+ {t('HomePage:memory-static-allocations-text')}:{' '} + {memoryReport.staticAllocs} +
+ + + +
+
+
+ ); +} diff --git a/www/src/Store/useSystemStats.ts b/www/src/Store/useSystemStats.ts new file mode 100644 index 000000000..639abf5b3 --- /dev/null +++ b/www/src/Store/useSystemStats.ts @@ -0,0 +1,107 @@ +import { create } from 'zustand'; +import { baseUrl } from '../Services/WebApi'; + +const percentage = (x, y) => parseFloat(((x / y) * 100).toFixed(2)); +const toKB = (x) => parseFloat((x / 1024).toFixed(2)); + +type State = { + latestVersion: string; + latestDownloadUrl: string; + currentVersion: string; + boardConfigProperties: { + label: string; + fileName: string; + }; + memoryReport: { + totalFlash: number; + usedFlash: number; + staticAllocs: number; + totalHeap: number; + usedHeap: number; + percentageFlash: number; + percentageHeap: number; + }; + loading: boolean; + error: boolean; +}; + +type Actions = { + getSystemStats: () => void; +}; + +const INITIAL_STATE: State = { + latestVersion: '', + latestDownloadUrl: '', + currentVersion: '', + boardConfigProperties: { + label: '', + fileName: '', + }, + memoryReport: { + totalFlash: 0, + usedFlash: 0, + staticAllocs: 0, + totalHeap: 0, + usedHeap: 0, + percentageFlash: 0, + percentageHeap: 0, + }, + loading: false, + error: false, +}; + +const useSystemStats = create()((set) => ({ + ...INITIAL_STATE, + getSystemStats: async () => { + set({ loading: true }); + + try { + const [firmwareVersion, memoryReport, latestRelease] = await Promise.all([ + fetch(`${baseUrl}/api/getFirmwareVersion`).then((res) => res.json()), + fetch(`${baseUrl}/api/getMemoryReport`).then((res) => res.json()), + fetch( + 'https://api.github.com/repos/OpenStickCommunity/GP2040-CE/releases/latest', + ).then((res) => res.json()), + ]); + const latestDownloadUrl = + latestRelease.assets?.find( + ({ name }) => + name + ?.substring(name.lastIndexOf('_') + 1) + ?.replace('.uf2', '') + ?.toLowerCase() === firmwareVersion.boardConfig.toLowerCase(), + )?.browser_download_url || + `https://github.com/OpenStickCommunity/GP2040-CE/releases/tag/${latestRelease.data.tag_name}`; + + set({ + currentVersion: firmwareVersion.version, + latestVersion: latestRelease.tag_name, + latestDownloadUrl, + boardConfigProperties: { + label: firmwareVersion.boardConfigLabel, + fileName: firmwareVersion.boardConfigFileName, + }, + memoryReport: { + totalFlash: toKB(memoryReport.totalFlash), + usedFlash: toKB(memoryReport.usedFlash), + staticAllocs: toKB(memoryReport.staticAllocs), + totalHeap: toKB(memoryReport.totalHeap), + usedHeap: toKB(memoryReport.usedHeap), + percentageFlash: percentage( + memoryReport.usedFlash, + memoryReport.totalFlash, + ), + percentageHeap: percentage( + memoryReport.usedHeap, + memoryReport.totalHeap, + ), + }, + loading: false, + }); + } catch (error) { + set({ error: true, loading: false }); + } + }, +})); + +export default useSystemStats; From 45e8fb57e0851c2de87dd16d63cdde483b0e319a Mon Sep 17 00:00:00 2001 From: ian Date: Sat, 28 Dec 2024 00:23:58 +0100 Subject: [PATCH 2/5] Remove now redundant fetching functions --- www/src/Services/WebApi.js | 32 ++------------------------------ 1 file changed, 2 insertions(+), 30 deletions(-) diff --git a/www/src/Services/WebApi.js b/www/src/Services/WebApi.js index 02d650ee6..d7f3a71cf 100644 --- a/www/src/Services/WebApi.js +++ b/www/src/Services/WebApi.js @@ -461,7 +461,8 @@ async function getAddonsOptions(setLoading) { const data = response.data; setLoading(false); - response.data.turboLedColor = rgbIntToHex(response.data.turboLedColor) || '#ffffff'; + response.data.turboLedColor = + rgbIntToHex(response.data.turboLedColor) || '#ffffff'; // Merge saved keyMappings with defaults const keyboardHostMap = Object.entries(data.keyboardHostMap).reduce( @@ -614,33 +615,6 @@ async function setPeripheralOptions(mappings) { }); } -async function getFirmwareVersion(setLoading) { - setLoading(true); - - try { - const response = await Http.get(`${baseUrl}/api/getFirmwareVersion`); - console.log('got firmware version:', response.data); - setLoading(false); - return response.data; - } catch (error) { - setLoading(false); - console.error(error); - } -} - -async function getMemoryReport(setLoading) { - setLoading(true); - - try { - const response = await Http.get(`${baseUrl}/api/getMemoryReport`); - setLoading(false); - return response.data; - } catch (error) { - setLoading(false); - console.error(error); - } -} - async function getUsedPins(setLoading) { setLoading(true); @@ -734,8 +708,6 @@ export default { getButtonLayoutDefs, getSplashImage, setSplashImage, - getFirmwareVersion, - getMemoryReport, getUsedPins, getHeldPins, abortGetHeldPins, From cad1c2442656587fc3e871ecdec852060b404971 Mon Sep 17 00:00:00 2001 From: ian Date: Sat, 28 Dec 2024 00:34:30 +0100 Subject: [PATCH 3/5] Make sure latest version check is the same as before, will improve when making the banner --- www/src/Pages/HomePage.tsx | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/www/src/Pages/HomePage.tsx b/www/src/Pages/HomePage.tsx index 738d608fa..d90e64b93 100644 --- a/www/src/Pages/HomePage.tsx +++ b/www/src/Pages/HomePage.tsx @@ -30,7 +30,6 @@ export default function HomePage() { ); } - return (

{t('HomePage:header-text')}

@@ -45,18 +44,20 @@ export default function HomePage() {
{t('HomePage:latest-text', { version: latestVersion })}
- {currentVersion !== latestVersion && ( - - )} + {latestVersion && + currentVersion?.split('-').length == 1 && + currentVersion !== latestVersion && ( + + )} {t('HomePage:memory-header-text')} From 3a93a482ab7dba078730cf2acfd229fa5232761e Mon Sep 17 00:00:00 2001 From: ian Date: Thu, 2 Jan 2025 23:31:03 +0100 Subject: [PATCH 4/5] Re-add physical flash --- www/src/Pages/HomePage.tsx | 3 +++ www/src/Store/useSystemStats.ts | 14 ++++++++------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/www/src/Pages/HomePage.tsx b/www/src/Pages/HomePage.tsx index d90e64b93..43ae46638 100644 --- a/www/src/Pages/HomePage.tsx +++ b/www/src/Pages/HomePage.tsx @@ -74,6 +74,9 @@ export default function HomePage() { {t('HomePage:memory-static-allocations-text')}:{' '} {memoryReport.staticAllocs}
+
+ {t('HomePage:memory-board-text')}: {memoryReport.physicalFlash} +
()((set) => ({ fileName: firmwareVersion.boardConfigFileName, }, memoryReport: { - totalFlash: toKB(memoryReport.totalFlash), - usedFlash: toKB(memoryReport.usedFlash), + physicalFlash: toKB(memoryReport.physicalFlash), staticAllocs: toKB(memoryReport.staticAllocs), + totalFlash: toKB(memoryReport.totalFlash), totalHeap: toKB(memoryReport.totalHeap), + usedFlash: toKB(memoryReport.usedFlash), usedHeap: toKB(memoryReport.usedHeap), percentageFlash: percentage( memoryReport.usedFlash, From 57e33a0e2d3ddb8e620dfbf1701dadf784906526 Mon Sep 17 00:00:00 2001 From: ian Date: Thu, 2 Jan 2025 23:35:04 +0100 Subject: [PATCH 5/5] Don't forget default state --- www/src/Store/useSystemStats.ts | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/www/src/Store/useSystemStats.ts b/www/src/Store/useSystemStats.ts index f798c5fdb..fd6a2e9e4 100644 --- a/www/src/Store/useSystemStats.ts +++ b/www/src/Store/useSystemStats.ts @@ -39,13 +39,14 @@ const INITIAL_STATE: State = { fileName: '', }, memoryReport: { - totalFlash: 0, - usedFlash: 0, + percentageFlash: 0, + percentageHeap: 0, + physicalFlash: 0, staticAllocs: 0, + totalFlash: 0, totalHeap: 0, + usedFlash: 0, usedHeap: 0, - percentageFlash: 0, - percentageHeap: 0, }, loading: false, error: false,