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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-11 19:36:41 -07:00
|
|
|
function getTagSortBy() {
|
2021-08-11 20:33:28 -07:00
|
|
|
let tagSortByNumThemes = document.getElementById("tagSortByNumThemes");
|
2021-08-11 19:36:41 -07:00
|
|
|
if (tagSortByNumThemes === null) {
|
2021-08-11 20:33:28 -07:00
|
|
|
return "numThemes";
|
2021-08-11 19:36:41 -07:00
|
|
|
} else {
|
2021-08-11 20:33:28 -07:00
|
|
|
return tagSortByNumThemes.checked ? "numThemes" : "name";
|
2021-08-11 19:36:41 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getFeatureSortBy() {
|
2021-08-11 20:33:28 -07:00
|
|
|
let featureSortByNumThemes = document.getElementById(
|
|
|
|
"featureSortByNumThemes"
|
|
|
|
);
|
2021-08-11 19:36:41 -07:00
|
|
|
if (featureSortByNumThemes === null) {
|
2021-08-11 20:33:28 -07:00
|
|
|
return "numThemes";
|
2021-08-11 19:36:41 -07:00
|
|
|
} else {
|
2021-08-11 20:33:28 -07:00
|
|
|
return featureSortByNumThemes.checked ? "numThemes" : "name";
|
2021-08-11 19:36:41 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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();
|