Skip to content

Commit

Permalink
Make commits count as default for preview (#255)
Browse files Browse the repository at this point in the history
We execute the sort by commits when the page is loaded, to achieve that we use `useEffect` hook that runs a specified effect immediately after rendering the page.

---------

Co-authored-by: Ahmed Basem <[email protected]>
  • Loading branch information
unkcpz and AhmedBasem20 committed Aug 17, 2023
1 parent d36148d commit c8c1c88
Showing 1 changed file with 20 additions and 11 deletions.
31 changes: 20 additions & 11 deletions aiida-registry-app/src/Components/MainIndex.jsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useState } from 'react';
import { useState, useEffect } from 'react';
import { Link, Route, Routes } from 'react-router-dom';
import jsonData from '../plugins_metadata.json'
import base64Icon from '../base64Icon';
Expand All @@ -16,9 +16,24 @@ const length = Object.keys(plugins).length;
const currentPath = import.meta.env.VITE_PR_PREVIEW_PATH || "/aiida-registry/";

function MainIndex() {
const [sortOption, setSortOption] = useState('alpha');
const [sortOption, setSortOption] = useState('commits');
const [sortedData, setSortedData] = useState(plugins);
document.documentElement.style.scrollBehavior = 'auto';

useEffect(() => {
document.documentElement.style.scrollBehavior = 'auto';
setSortedData(sortByCommits(plugins));
setupScrollBehavior();
}, [plugins, setSortedData]);

function sortByCommits(plugins) {
const pluginsArray = Object.entries(plugins);

// Sort the array based on the commit_count value
pluginsArray.sort(([, pluginA], [, pluginB]) => pluginB.commits_count - pluginA.commits_count);

// Return a new object with the sorted entries
return Object.fromEntries(pluginsArray);
}

function setupScrollBehavior() {
var prevScrollpos = window.scrollY;
Expand All @@ -42,13 +57,7 @@ function MainIndex() {

let sortedPlugins;
if (option === 'commits') {
const pluginsArray = Object.entries(plugins);

// Sort the array based on the commit_count value
pluginsArray.sort(([, pluginA], [, pluginB]) => pluginB.commits_count - pluginA.commits_count);

// Create a new object with the sorted entries
sortedPlugins = Object.fromEntries(pluginsArray);
sortedPlugins = sortByCommits(plugins);
}
else if (option == 'alpha') {
sortedPlugins = plugins;
Expand Down Expand Up @@ -89,8 +98,8 @@ function MainIndex() {
<Select
value={sortOption} label = "Sort" onChange={(e) => handleSort(e.target.value)}
>
<MenuItem value= 'alpha'>Alphabetical</MenuItem>
<MenuItem value='commits'>Commits Count</MenuItem>
<MenuItem value= 'alpha'>Alphabetical</MenuItem>
</Select>
</FormControl>
</Box>
Expand Down

0 comments on commit c8c1c88

Please sign in to comment.