Skip to content

Commit

Permalink
Merge pull request #42 from Ewalwi/main
Browse files Browse the repository at this point in the history
Add a last-checked-chart memory function
  • Loading branch information
Truiteseche authored Nov 11, 2024
2 parents 0517db9 + ed21b1a commit 3b81516
Show file tree
Hide file tree
Showing 4 changed files with 69 additions and 55 deletions.
28 changes: 15 additions & 13 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
"react-content-loader": "^6.2.1",
"react-router-dom": "^6.16.0",
"uuid": "^9.0.1",
"vite": "^4.4.9"
"vite": "^4.5.5"
},
"scripts": {
"dev": "vite",
Expand Down
11 changes: 8 additions & 3 deletions src/App.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,8 @@ const defaultSettings = {
shareSettings: true,
negativeBadges: false,
allowAnonymousReports: true,
isDevChannel: false
isDevChannel: false,
selectedChart: 0
}

const browserExtensionDownloadLink = {
Expand Down Expand Up @@ -168,6 +169,10 @@ function initSettings(accountList) {
value: getSetting("displayMode", i),
values: ["quality", "balanced", "performance"]
},
selectedChart: {
value: getSetting("selectedChart", i),
values: [0, 1, 2]
},
isSepiaEnabled: {
value: getSetting("isSepiaEnabled", i),
},
Expand Down Expand Up @@ -391,7 +396,7 @@ export default function App({ edpFetch }) {
> Value of displayTheme of current user
You can pass the setting you wan in arguments of useUserSettings
You can pass the setting you want in arguments of useUserSettings
EX :
userDisplayTheme = useUserSettings("displayTheme")
Expand Down Expand Up @@ -2760,4 +2765,4 @@ export default function App({ edpFetch }) {
</Suspense>
</AppContext.Provider>
);
}
}
83 changes: 45 additions & 38 deletions src/components/app/Grades/Charts.jsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@

import { useState, useEffect, useRef, useContext } from "react";
// import { Chart } from 'chart.js';
import { applyZoom, getZoomedBoudingClientRect } from "../../../utils/zoom";


import "./Charts.css";
import DropDownMenu from "../../generic/UserInputs/DropDownMenu";


import { AppContext } from "../../../App";

export default function Charts({ selectedPeriod }) {
Expand All @@ -18,8 +15,12 @@ export default function Charts({ selectedPeriod }) {
* 2: Subjects average | radar
*/

// States
const [chartType, setChartType] = useState(0);
// States

const { useUserSettings } = useContext(AppContext);

const settings = useUserSettings()
const [selectedChart, setSelectedChart] = useState(settings.get("selectedChart"));

const chartContainerRef = useRef(null);
const canvasContainerRef = useRef(null);
Expand All @@ -40,7 +41,6 @@ export default function Charts({ selectedPeriod }) {
}

useEffect(() => {

window.addEventListener("resize", resizeChart);
resizeChart();

Expand All @@ -49,16 +49,15 @@ export default function Charts({ selectedPeriod }) {
}
}, [])


function getChartData() {
/**
* return the appropriate dataset according to the chartType
* return the appropriate dataset according to the selectedChart
*/
const userData = useUserData();
const minMaxEnabled = userData.get("gradesEnabledFeatures")?.moyenneMin && userData.get("gradesEnabledFeatures")?.moyenneMax;


switch (chartType) {
switch (selectedChart) {
case 0:
// General average + streak history | line
chartOptions.current = {
Expand All @@ -71,17 +70,17 @@ export default function Charts({ selectedPeriod }) {
suggestedMax: 20
},
// y1: {
// type: 'linear',
// display: true,
// position: 'right',
// suggestedMax: 20
// type: 'linear',
// display: true,
// position: 'right',
// suggestedMax: 20
// }
// xAxes: [{
// type: 'time',
// ticks: {
// autoSkip: true,
// maxTicksLimit: 20
// }
// type: 'time',
// ticks: {
// autoSkip: true,
// maxTicksLimit: 20
// }
// }]
},
interaction: {
Expand Down Expand Up @@ -179,24 +178,24 @@ export default function Charts({ selectedPeriod }) {
order: 1,
},
// {
// type: "line",
// label: "Moyennes max classe",
// data: subjectsComparativeInformation[selectedPeriod].map((subject) => subject.maxAverage),
// borderColor: 'rgb(53, 162, 235)',
// backgroundColor: 'rgba(53, 162, 235, 0.5)',
// tension: 0.2,
// // yAxisID: "y1"
// order: 2,
// type: "line",
// label: "Moyennes max classe",
// data: subjectsComparativeInformation[selectedPeriod].map((subject) => subject.maxAverage),
// borderColor: 'rgb(53, 162, 235)',
// backgroundColor: 'rgba(53, 162, 235, 0.5)',
// tension: 0.2,
// // yAxisID: "y1"
// order: 2,
// },
// {
// type: "line",
// label: "Moyennes min classe",
// data: subjectsComparativeInformation[selectedPeriod].map((subject) => subject.minAverage),
// borderColor: 'rgb(53, 162, 235)',
// backgroundColor: 'rgba(53, 162, 235, 0.5)',
// tension: 0.2,
// // yAxisID: "y1"
// order: 3,
// type: "line",
// label: "Moyennes min classe",
// data: subjectsComparativeInformation[selectedPeriod].map((subject) => subject.minAverage),
// borderColor: 'rgb(53, 162, 235)',
// backgroundColor: 'rgba(53, 162, 235, 0.5)',
// tension: 0.2,
// // yAxisID: "y1"
// order: 3,
// },
],
};
Expand All @@ -214,7 +213,7 @@ export default function Charts({ selectedPeriod }) {
beginAtZero: true,
suggestedMax: 20,
grid: {
color: actualDisplayTheme == "dark" ? "rgba(180, 180, 240, .4)" : "rgba(76, 76, 184, .4)"
color: actualDisplayTheme == "dark" ? "rgba(180, 180, 240, .4)" : "rgba(76, 76, 184, .4)"
}
}
},
Expand Down Expand Up @@ -308,9 +307,9 @@ export default function Charts({ selectedPeriod }) {
}

useEffect(() => {
console.log(chartType);
refreshChart();
}, [chartType, activeAccount, selectedPeriod]);
useUserSettings("selectedChart").set(selectedChart);
}, [selectedChart, activeAccount, selectedPeriod]);

useEffect(() => {
const script = document.createElement("script");
Expand All @@ -330,7 +329,15 @@ export default function Charts({ selectedPeriod }) {
return (
<div id="charts">
<div className="top-container">
<DropDownMenu name="chart-type" options={[0, 1, 2]} displayedOptions={["Moyenne générale Courbe", "Moyennes par matière Barres", "Moyennes par matière Radar"]} selected={chartType} onChange={(value) => setChartType(parseInt(value))} />
<DropDownMenu
name="chart-type"
options={[0, 1, 2]}
displayedOptions={["Moyenne générale Courbe", "Moyennes par matière Barres", "Moyennes par matière Radar"]}
selected={selectedChart}
onChange={(value) => {
setSelectedChart(parseInt(value));
}}
/>
<h3>Graphiques</h3>
<div className="artificial-horizontal-center"></div>
</div>
Expand Down

0 comments on commit 3b81516

Please sign in to comment.