hugo_themes_report/templates/js/buildPage.js

109 lines
3.1 KiB
JavaScript
Raw Normal View History

2021-08-11 11:58:10 -07:00
function getSortBy() {
2021-08-11 20:33:28 -07:00
let sortByLastCommitInput = document.getElementById("sortByDate");
2021-08-11 11:58:10 -07:00
if (sortByLastCommitInput === null) {
2021-08-11 20:33:28 -07:00
return "date";
2021-08-11 11:58:10 -07:00
} else {
2021-08-11 20:33:28 -07:00
return sortByLastCommitInput.checked ? "date" : "stars";
2021-08-11 11:58:10 -07:00
}
}
function getTagSortBy() {
2021-08-11 20:33:28 -07:00
let tagSortByNumThemes = document.getElementById("tagSortByNumThemes");
if (tagSortByNumThemes === null) {
2021-08-11 20:33:28 -07:00
return "numThemes";
} else {
2021-08-11 20:33:28 -07:00
return tagSortByNumThemes.checked ? "numThemes" : "name";
}
}
function getFeatureSortBy() {
2021-08-11 20:33:28 -07:00
let featureSortByNumThemes = document.getElementById(
"featureSortByNumThemes"
);
if (featureSortByNumThemes === null) {
2021-08-11 20:33:28 -07:00
return "numThemes";
} else {
2021-08-11 20:33:28 -07:00
return featureSortByNumThemes.checked ? "numThemes" : "name";
}
}
2021-08-11 11:58:10 -07:00
function getSortedThemes(themeList, sortedBy) {
2021-08-11 20:33:28 -07:00
if (sortedBy === "date") {
2021-08-11 11:58:10 -07:00
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() {
2021-08-11 20:33:28 -07:00
let tagSelectionInputs = document.getElementsByClassName("tagSelectionInput");
2021-08-11 11:58:10 -07:00
if (tagSelectionInputs.length > 0) {
return [...tagSelectionInputs].filter((x) => x.checked).map((y) => y.value);
} else {
return [];
}
}
function getSelectedFeatures() {
2021-08-11 20:33:28 -07:00
let featureSelectionInputs = document.getElementsByClassName(
"featureSelectionInput"
);
2021-08-11 11:58:10 -07:00
if (featureSelectionInputs.length > 0) {
2021-08-11 20:33:28 -07:00
return [...featureSelectionInputs]
.filter((x) => x.checked)
.map((y) => y.value);
2021-08-11 11:58:10 -07:00
} else {
return [];
}
}
function getFilteredThemes(selectedTags, selectedFeatures) {
2021-08-11 20:33:28 -07:00
if (selectedTags.length === 0 && selectedFeatures.length === 0) {
2021-08-11 11:58:10 -07:00
return themes;
} else {
return themes
2021-08-11 20:33:28 -07:00
.filter((x) => selectedTags.every((y) => x.tags.includes(y)))
.filter((z) => selectedFeatures.every((w) => z.features.includes(w)));
2021-08-11 11:58:10 -07:00
}
}
function buildResults() {
2021-08-11 20:33:28 -07:00
let resultsDiv = document.getElementById("results");
resultsDiv.innerHTML = "";
2021-08-11 11:58:10 -07:00
let resultsTable = document.createElement("table");
2021-08-11 20:33:28 -07:00
resultsTable.id = "resultsTable";
resultsTable.style.border = "1px solid black";
resultsTable.style.fontSize = ".9rem";
2021-08-11 11:58:10 -07:00
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);
2021-08-11 20:33:28 -07:00
sorted_themes.forEach((theme) => addThemeTableRow(theme));
2021-08-11 11:58:10 -07:00
buildSelectionMenu(sorted_themes, sortedBy, selectedTags, selectedFeatures);
2021-08-11 20:33:28 -07:00
}
2021-08-11 11:58:10 -07:00
buildResults();