mirror of
https://github.com/TrentSPalmer/hugo_themes_report.git
synced 2025-07-12 05:23:15 -07:00
another major rewrite
This commit is contained in:
84
templates/js/buildPage.js
Normal file
84
templates/js/buildPage.js
Normal file
@ -0,0 +1,84 @@
|
||||
function getSortBy() {
|
||||
let sortByLastCommitInput = document.getElementById('sortByDate');
|
||||
if (sortByLastCommitInput === null) {
|
||||
return 'date';
|
||||
} else {
|
||||
return sortByLastCommitInput.checked ? 'date' : 'stars';
|
||||
}
|
||||
}
|
||||
|
||||
function getSortedThemes(themeList, sortedBy) {
|
||||
if (sortedBy === 'date') {
|
||||
return themeList.sort((a, b) => b.date_in_seconds - a.date_in_seconds);
|
||||
} else {
|
||||
return themeList.sort((a, b) => b.num_stars - a.num_stars);
|
||||
}
|
||||
}
|
||||
|
||||
function getSelectedTags() {
|
||||
let tagSelectionInputs = document.getElementsByClassName('tagSelectionInput');
|
||||
if (tagSelectionInputs.length > 0) {
|
||||
return [...tagSelectionInputs].filter((x) => x.checked).map((y) => y.value);
|
||||
} else {
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
function getSelectedFeatures() {
|
||||
let featureSelectionInputs = document.getElementsByClassName('featureSelectionInput');
|
||||
if (featureSelectionInputs.length > 0) {
|
||||
return [...featureSelectionInputs].filter((x) => x.checked).map((y) => y.value);
|
||||
} else {
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
function getFilteredThemes(selectedTags, selectedFeatures) {
|
||||
if ((selectedTags.length === 0) && selectedFeatures.length === 0) {
|
||||
return themes;
|
||||
} else {
|
||||
return themes
|
||||
.filter((x) => selectedTags.every((y) => x.tags.includes(y)) )
|
||||
.filter((z) => selectedFeatures.every((w) => z.features.includes(w)) );
|
||||
}
|
||||
}
|
||||
|
||||
function buildResults() {
|
||||
let resultsDiv = document.getElementById('results');
|
||||
resultsDiv.innerHTML = '';
|
||||
let resultsTable = document.createElement("table");
|
||||
resultsTable.id = 'resultsTable';
|
||||
resultsTable.style.border = '1px solid black';
|
||||
resultsTable.style.fontSize = '.9rem';
|
||||
|
||||
let resultsTableHeadRow = document.createElement("tr");
|
||||
resultsDiv.appendChild(resultsTable);
|
||||
resultsTable.appendChild(resultsTableHeadRow);
|
||||
|
||||
let themeTH = document.createElement("th");
|
||||
themeTH.innerHTML = "theme";
|
||||
resultsTableHeadRow.appendChild(themeTH);
|
||||
|
||||
let dateTH = document.createElement("th");
|
||||
dateTH.innerHTML = "date";
|
||||
resultsTableHeadRow.appendChild(dateTH);
|
||||
|
||||
let starsTH = document.createElement("th");
|
||||
starsTH.innerHTML = "stars";
|
||||
resultsTableHeadRow.appendChild(starsTH);
|
||||
|
||||
let commitTH = document.createElement("th");
|
||||
commitTH.innerHTML = "commit";
|
||||
resultsTableHeadRow.appendChild(commitTH);
|
||||
|
||||
let selectedTags = getSelectedTags();
|
||||
let selectedFeatures = getSelectedFeatures();
|
||||
let sortedBy = getSortBy();
|
||||
let filtered_themes = getFilteredThemes(selectedTags, selectedFeatures);
|
||||
let sorted_themes = getSortedThemes(filtered_themes, sortedBy);
|
||||
sorted_themes.forEach(theme => addThemeTableRow(theme));
|
||||
|
||||
buildSelectionMenu(sorted_themes, sortedBy, selectedTags, selectedFeatures);
|
||||
};
|
||||
|
||||
buildResults();
|
Reference in New Issue
Block a user