1571 lines
48 KiB
JavaScript
Executable File
1571 lines
48 KiB
JavaScript
Executable File
var availableFeatures = document.querySelectorAll("#available-features li");
|
|
var availableFeatures2 = document.querySelectorAll("#available-features-2 li");
|
|
|
|
var displayFormat = document.querySelector("#display-format");
|
|
var displayFormat2 = document.querySelector("#display-format-2");
|
|
|
|
var featureToDisplay = document.querySelector("#feature-to-display");
|
|
var featureToDisplay2 = document.querySelector("#feature-to-display-2");
|
|
|
|
var displayToFeature = document.querySelector("#display-to-feature");
|
|
var displayToFeature2 = document.querySelector("#display-to-feature-2");
|
|
|
|
var displayToFormat = document.querySelectorAll("#display-format li");
|
|
var displayToFormat2 = document.querySelectorAll("#display-format-2 li");
|
|
|
|
var availableToDisplay = document.querySelector("#available-features");
|
|
var availableToDisplay2 = document.querySelector("#available-features-2");
|
|
|
|
var displayincreaseBtn = document.getElementById("display-increase-btn");
|
|
var displayincreaseBtn2 = document.getElementById("display-increase-btn-2");
|
|
|
|
var displayDecreaseBtn = document.getElementById("display-decrease-btn");
|
|
var displayDecreaseBtn2 = document.getElementById("display-decrease-btn-2");
|
|
|
|
var secondRow = document.getElementById("second-row");
|
|
|
|
// features lists
|
|
var stocksFeatures = document.querySelectorAll("#stocks-features li");
|
|
var cryptoFeatures = document.querySelectorAll("#crypto-features li");
|
|
var forexFeatures = document.querySelectorAll("#forex-features li");
|
|
var currentWeatherFeatures = document.querySelectorAll(
|
|
"#current-weather-features li"
|
|
);
|
|
var dailyForecastFeatures = document.querySelectorAll(
|
|
"#daily-forecast-features li"
|
|
);
|
|
var newsFeatures = document.querySelectorAll("#news-features li");
|
|
var upcomingGamesFeatures = document.querySelectorAll(
|
|
"#upcoming-games-features li"
|
|
);
|
|
var pastGamesFeatures = document.querySelectorAll("#past-games-features li");
|
|
var liveGamesFeatures = document.querySelectorAll("#live-games-features li");
|
|
var teamStatsFeatures = document.querySelectorAll("#team-stats-features li");
|
|
var imagesFeatures = document.querySelectorAll("#images-features li");
|
|
var gifsFeatures = document.querySelectorAll("#gifs-features li");
|
|
var messagesFeatures = document.querySelectorAll("#messages-features li");
|
|
|
|
var allFeaturesList = [
|
|
stocksFeatures,
|
|
cryptoFeatures,
|
|
forexFeatures,
|
|
currentWeatherFeatures,
|
|
dailyForecastFeatures,
|
|
newsFeatures,
|
|
upcomingGamesFeatures,
|
|
pastGamesFeatures,
|
|
liveGamesFeatures,
|
|
teamStatsFeatures,
|
|
imagesFeatures,
|
|
gifsFeatures,
|
|
messagesFeatures,
|
|
];
|
|
|
|
// features remove buttons
|
|
var stocksRemoveBtn = document.getElementById("stocks-remove-btn");
|
|
var cryptoRemoveBtn = document.getElementById("crypto-remove-btn");
|
|
var forexRemoveBtn = document.getElementById("forex-remove-btn");
|
|
var currentWeatherRemoveBtn = document.getElementById(
|
|
"current-weather-remove-btn"
|
|
);
|
|
var dailyForecastRemoveBtn = document.getElementById(
|
|
"daily-forecast-remove-btn"
|
|
);
|
|
var newsRemoveBtn = document.getElementById("news-remove-btn");
|
|
var upcomingGamesRemoveBtn = document.getElementById(
|
|
"upcoming-games-remove-btn"
|
|
);
|
|
var pastGamesRemoveBtn = document.getElementById("past-games-remove-btn");
|
|
var liveGamesRemoveBtn = document.getElementById("live-games-remove-btn");
|
|
var teamStatsRemoveBtn = document.getElementById("team-stats-remove-btn");
|
|
var imagesRemoveBtn = document.getElementById("images-remove-btn");
|
|
var gifsRemoveBtn = document.getElementById("gifs-remove-btn");
|
|
var messagesRemoveBtn = document.getElementById("messages-remove-btn");
|
|
|
|
var allFeaturesRemoveBtns = [
|
|
stocksRemoveBtn,
|
|
cryptoRemoveBtn,
|
|
forexRemoveBtn,
|
|
currentWeatherRemoveBtn,
|
|
dailyForecastRemoveBtn,
|
|
newsRemoveBtn,
|
|
upcomingGamesRemoveBtn,
|
|
pastGamesRemoveBtn,
|
|
liveGamesRemoveBtn,
|
|
teamStatsRemoveBtn,
|
|
imagesRemoveBtn,
|
|
gifsRemoveBtn,
|
|
messagesRemoveBtn,
|
|
];
|
|
// features increase buttons
|
|
var stocksincreaseBtn = document.getElementById("stocks-increase-btn");
|
|
var cryptoincreaseBtn = document.getElementById("crypto-increase-btn");
|
|
var forexincreaseBtn = document.getElementById("forex-increase-btn");
|
|
var currentWeatherincreaseBtn = document.getElementById(
|
|
"current-weather-increase-btn"
|
|
);
|
|
var dailyForecastincreaseBtn = document.getElementById(
|
|
"daily-forecast-increase-btn"
|
|
);
|
|
var newsincreaseBtn = document.getElementById("news-increase-btn");
|
|
var upcomingGamesincreaseBtn = document.getElementById(
|
|
"upcoming-games-increase-btn"
|
|
);
|
|
var pastGamesincreaseBtn = document.getElementById("past-games-increase-btn");
|
|
var liveGamesincreaseBtn = document.getElementById("live-games-increase-btn");
|
|
var teamStatsincreaseBtn = document.getElementById("team-stats-increase-btn");
|
|
var imagesincreaseBtn = document.getElementById("images-increase-btn");
|
|
var gifsincreaseBtn = document.getElementById("gifs-increase-btn");
|
|
var messagesincreaseBtn = document.getElementById("messages-increase-btn");
|
|
|
|
var allFeaturesIncreaseBtns = [
|
|
stocksincreaseBtn,
|
|
cryptoincreaseBtn,
|
|
forexincreaseBtn,
|
|
currentWeatherincreaseBtn,
|
|
dailyForecastincreaseBtn,
|
|
newsincreaseBtn,
|
|
upcomingGamesincreaseBtn,
|
|
pastGamesincreaseBtn,
|
|
liveGamesincreaseBtn,
|
|
teamStatsincreaseBtn,
|
|
imagesincreaseBtn,
|
|
gifsincreaseBtn,
|
|
messagesincreaseBtn,
|
|
];
|
|
|
|
// features decrease buttons
|
|
var stocksDecreaseBtn = document.getElementById("stocks-decrease-btn");
|
|
var cryptoDecreaseBtn = document.getElementById("crypto-decrease-btn");
|
|
var forexDecreaseBtn = document.getElementById("forex-decrease-btn");
|
|
var currentWeatherDecreaseBtn = document.getElementById(
|
|
"current-weather-decrease-btn"
|
|
);
|
|
var dailyForecastDecreaseBtn = document.getElementById(
|
|
"daily-forecast-decrease-btn"
|
|
);
|
|
var newsDecreaseBtn = document.getElementById("news-decrease-btn");
|
|
var upcomingGamesDecreaseBtn = document.getElementById(
|
|
"upcoming-games-decrease-btn"
|
|
);
|
|
var pastGamesDecreaseBtn = document.getElementById("past-games-decrease-btn");
|
|
var liveGamesDecreaseBtn = document.getElementById("live-games-decrease-btn");
|
|
var teamStatsDecreaseBtn = document.getElementById("team-stats-decrease-btn");
|
|
var imagesDecreaseBtn = document.getElementById("images-decrease-btn");
|
|
var gifsDecreaseBtn = document.getElementById("gifs-decrease-btn");
|
|
var messagesDecreaseBtn = document.getElementById("messages-decrease-btn");
|
|
|
|
var allFeaturesDecreaseBtns = [
|
|
stocksDecreaseBtn,
|
|
cryptoDecreaseBtn,
|
|
forexDecreaseBtn,
|
|
currentWeatherDecreaseBtn,
|
|
dailyForecastDecreaseBtn,
|
|
newsDecreaseBtn,
|
|
upcomingGamesDecreaseBtn,
|
|
pastGamesDecreaseBtn,
|
|
liveGamesDecreaseBtn,
|
|
teamStatsDecreaseBtn,
|
|
imagesDecreaseBtn,
|
|
gifsDecreaseBtn,
|
|
messagesDecreaseBtn,
|
|
];
|
|
|
|
const changeVarValue = () => {
|
|
stocksFeatures = document.querySelectorAll("#stocks-features li");
|
|
cryptoFeatures = document.querySelectorAll("#crypto-features li");
|
|
forexFeatures = document.querySelectorAll("#forex-features li");
|
|
currentWeatherFeatures = document.querySelectorAll(
|
|
"#current-weather-features li"
|
|
);
|
|
dailyForecastFeatures = document.querySelectorAll(
|
|
"#daily-forecast-features li"
|
|
);
|
|
newsFeatures = document.querySelectorAll("#news-features li");
|
|
upcomingGamesFeatures = document.querySelectorAll(
|
|
"#upcoming-games-features li"
|
|
);
|
|
pastGamesFeatures = document.querySelectorAll("#past-games-features li");
|
|
liveGamesFeatures = document.querySelectorAll("#live-games-features li");
|
|
teamStatsFeatures = document.querySelectorAll("#team-stats-features li");
|
|
imagesFeatures = document.querySelectorAll("#images-features li");
|
|
gifsFeatures = document.querySelectorAll("#gifs-features li");
|
|
messagesFeatures = document.querySelectorAll("#messages-features li");
|
|
|
|
allFeaturesList = [
|
|
stocksFeatures,
|
|
cryptoFeatures,
|
|
forexFeatures,
|
|
currentWeatherFeatures,
|
|
dailyForecastFeatures,
|
|
newsFeatures,
|
|
upcomingGamesFeatures,
|
|
pastGamesFeatures,
|
|
liveGamesFeatures,
|
|
teamStatsFeatures,
|
|
imagesFeatures,
|
|
gifsFeatures,
|
|
messagesFeatures,
|
|
];
|
|
};
|
|
|
|
const addEventOnList = () => {
|
|
// for available feature
|
|
for (let i = 0; i < availableFeatures.length; i++) {
|
|
const availableFeature = availableFeatures[i];
|
|
availableFeature.addEventListener("click", () => {
|
|
for (let i = 0; i < availableFeatures.length; i++) {
|
|
availableFeatures[i].setAttribute("class", "");
|
|
}
|
|
if (availableFeature.getAttribute("class") == "active") {
|
|
availableFeature.setAttribute("class", "");
|
|
} else {
|
|
availableFeature.setAttribute("class", "active");
|
|
}
|
|
});
|
|
}
|
|
// for available feature 2
|
|
for (let i = 0; i < availableFeatures2.length; i++) {
|
|
const availableFeature = availableFeatures2[i];
|
|
availableFeature.addEventListener("click", () => {
|
|
for (let i = 0; i < availableFeatures2.length; i++) {
|
|
availableFeatures2[i].setAttribute("class", "");
|
|
}
|
|
if (availableFeature.getAttribute("class") == "active") {
|
|
availableFeature.setAttribute("class", "");
|
|
} else {
|
|
availableFeature.setAttribute("class", "active");
|
|
}
|
|
});
|
|
}
|
|
// for display format
|
|
for (let i = 0; i < displayToFormat.length; i++) {
|
|
const display_format = displayToFormat[i];
|
|
display_format.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat.length; i++) {
|
|
displayToFormat[i].setAttribute("class", "");
|
|
}
|
|
if (display_format.getAttribute("class") == "active") {
|
|
display_format.setAttribute("class", "");
|
|
} else {
|
|
display_format.setAttribute("class", "active");
|
|
}
|
|
});
|
|
}
|
|
// for display format 2
|
|
for (let i = 0; i < displayToFormat2.length; i++) {
|
|
const display_format = displayToFormat2[i];
|
|
display_format.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat2.length; i++) {
|
|
displayToFormat2[i].setAttribute("class", "");
|
|
}
|
|
if (display_format.getAttribute("class") == "active") {
|
|
display_format.setAttribute("class", "");
|
|
} else {
|
|
display_format.setAttribute("class", "active");
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
const addEventonBtns = () => {
|
|
featureToDisplay.addEventListener("click", () => {
|
|
for (let i = 0; i < availableFeatures.length; i++) {
|
|
const availableFeature = availableFeatures[i];
|
|
if (availableFeature.getAttribute("class") == "active") {
|
|
availableFeature.remove();
|
|
availableFeature.setAttribute("class", "");
|
|
displayFormat.appendChild(availableFeature);
|
|
availableFeatures = document.querySelectorAll("#available-features li");
|
|
displayToFormat = document.querySelectorAll("#display-format li");
|
|
addEventOnList();
|
|
}
|
|
}
|
|
});
|
|
|
|
displayToFeature.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat.length; i++) {
|
|
const availableFormat = displayToFormat[i];
|
|
if (availableFormat.getAttribute("class") == "active") {
|
|
availableFormat.remove();
|
|
availableFormat.setAttribute("class", "");
|
|
availableToDisplay.appendChild(availableFormat);
|
|
availableFeatures = document.querySelectorAll("#available-features li");
|
|
displayToFormat = document.querySelectorAll("#display-format li");
|
|
addEventOnList();
|
|
}
|
|
}
|
|
});
|
|
|
|
featureToDisplay2.addEventListener("click", () => {
|
|
for (let i = 0; i < availableFeatures2.length; i++) {
|
|
const availableFeature = availableFeatures2[i];
|
|
if (availableFeature.getAttribute("class") == "active") {
|
|
availableFeature.remove();
|
|
availableFeature.setAttribute("class", "");
|
|
displayFormat2.appendChild(availableFeature);
|
|
availableFeatures2 = document.querySelectorAll(
|
|
"#available-features-2 li"
|
|
);
|
|
displayToFormat2 = document.querySelectorAll("#display-format-2 li");
|
|
addEventOnList();
|
|
}
|
|
}
|
|
});
|
|
|
|
displayToFeature2.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat2.length; i++) {
|
|
const availableFormat = displayToFormat2[i];
|
|
if (availableFormat.getAttribute("class") == "active") {
|
|
availableFormat.remove();
|
|
availableFormat.setAttribute("class", "");
|
|
availableToDisplay2.appendChild(availableFormat);
|
|
availableFeatures2 = document.querySelectorAll(
|
|
"#available-features-2 li"
|
|
);
|
|
displayToFormat2 = document.querySelectorAll("#display-format-2 li");
|
|
addEventOnList();
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
addEventOnList();
|
|
addEventonBtns();
|
|
|
|
const addEventOnFeaturesList = () => {
|
|
allFeaturesList.map((value) => {
|
|
for (let i = 0; i < value.length; i++) {
|
|
const availableFeature = value[i];
|
|
availableFeature.addEventListener("click", () => {
|
|
for (let i = 0; i < value.length; i++) {
|
|
value[i].setAttribute("class", "");
|
|
}
|
|
if (availableFeature.getAttribute("class") == "active") {
|
|
availableFeature.setAttribute("class", "");
|
|
} else {
|
|
availableFeature.setAttribute("class", "active");
|
|
let getCustomImages = JSON.parse(
|
|
localStorage.getItem("customImages")
|
|
);
|
|
let getCustomGifs = JSON.parse(localStorage.getItem("customGifs"));
|
|
let getCustomMsg = JSON.parse(localStorage.getItem("customMsg"));
|
|
|
|
getCustomImages.map((value) => {
|
|
let scrollSpeed1 = document.getElementById("inputScrollSpeed11");
|
|
let scrollSpeed2 = document.getElementById("inputScrollSpeedRow11");
|
|
let inputTransition = document.getElementById("inputTransition11");
|
|
let inputText12 = document.getElementById("inputText12");
|
|
let displayCheck = document.getElementById("flexCheckChecked25");
|
|
|
|
if (value.fileName == availableFeature.innerText) {
|
|
scrollSpeed1.value = value.scrollSpeed;
|
|
scrollSpeed2.value = value.scrollSpeed2;
|
|
inputTransition.value = value.transition;
|
|
inputText12.value = value.pauseScreen;
|
|
displayCheck.checked = value.displayCheck;
|
|
}
|
|
});
|
|
getCustomGifs.map((value) => {
|
|
let scrollSpeed1 = document.getElementById("inputScrollSpeed12");
|
|
let scrollSpeed2 = document.getElementById("inputScrollSpeedRow12");
|
|
let inputTransition = document.getElementById("inputTransition12");
|
|
let inputText12 = document.getElementById("inputText112");
|
|
let displayCheck = document.getElementById("flexCheckChecked28");
|
|
|
|
if (value.fileName == availableFeature.innerText) {
|
|
scrollSpeed1.value = value.scrollSpeed;
|
|
scrollSpeed2.value = value.scrollSpeed2;
|
|
inputTransition.value = value.transition;
|
|
inputText12.value = value.pauseScreen;
|
|
displayCheck.checked = value.displayCheck;
|
|
}
|
|
});
|
|
|
|
getCustomMsg.map((value) => {
|
|
let scrollSpeed1 = document.getElementById("inputScrollSpeed13");
|
|
let scrollSpeed2 = document.getElementById("inputScrollSpeedRow13");
|
|
let inputTransition = document.getElementById("inputTransition13");
|
|
let inputMsg = document.getElementById("inputText14");
|
|
let inputColor = document.getElementById("inputScrollSpeed16");
|
|
let inputSize = document.getElementById("inputScrollSpeed17");
|
|
let inputBg = document.getElementById("inputScrollSpeed19");
|
|
let displayCheck = document.getElementById("flexCheckChecked29");
|
|
|
|
if (value.messageName == availableFeature.innerText) {
|
|
scrollSpeed1.value = value.scrollSpeed1;
|
|
scrollSpeed2.value = value.scrollSpeed2;
|
|
inputTransition.value = value.transition;
|
|
inputMsg.value = value.messageInput;
|
|
inputColor.value = value.colorInput;
|
|
inputSize.value = value.sizeInput;
|
|
inputBg.value = value.backgroundInput;
|
|
displayCheck.checked = value.displayCheck;
|
|
}
|
|
});
|
|
}
|
|
});
|
|
}
|
|
});
|
|
};
|
|
addEventOnFeaturesList();
|
|
|
|
// display increase function
|
|
displayincreaseBtn.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat.length; i++) {
|
|
var displayItem = displayToFormat[i];
|
|
|
|
if (displayItem.getAttribute("class") == "active") {
|
|
var prevElement = displayItem.previousElementSibling;
|
|
var currentText = displayItem.innerText;
|
|
|
|
displayItem.innerText = prevElement.innerText;
|
|
prevElement.innerText = currentText;
|
|
prevElement.setAttribute("class", "active");
|
|
displayItem.setAttribute("class", "");
|
|
}
|
|
}
|
|
});
|
|
|
|
// display increase 2 function
|
|
displayincreaseBtn2.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat2.length; i++) {
|
|
var displayItem = displayToFormat2[i];
|
|
|
|
if (displayItem.getAttribute("class") == "active") {
|
|
var prevElement = displayItem.previousElementSibling;
|
|
var currentText = displayItem.innerText;
|
|
|
|
displayItem.innerText = prevElement.innerText;
|
|
prevElement.innerText = currentText;
|
|
prevElement.setAttribute("class", "active");
|
|
displayItem.setAttribute("class", "");
|
|
}
|
|
}
|
|
});
|
|
|
|
// display decrease function
|
|
displayDecreaseBtn.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat.length; i++) {
|
|
var displayItem = displayToFormat[i];
|
|
|
|
if (displayItem.getAttribute("class") == "active") {
|
|
var nextElement = displayItem.nextElementSibling;
|
|
var currentText = displayItem.innerText;
|
|
|
|
displayItem.innerText = nextElement.innerText;
|
|
nextElement.innerText = currentText;
|
|
nextElement.setAttribute("class", "active");
|
|
displayItem.setAttribute("class", "");
|
|
break;
|
|
}
|
|
}
|
|
});
|
|
|
|
// display decrease 2 function
|
|
displayDecreaseBtn2.addEventListener("click", () => {
|
|
for (let i = 0; i < displayToFormat2.length; i++) {
|
|
var displayItem = displayToFormat2[i];
|
|
|
|
if (displayItem.getAttribute("class") == "active") {
|
|
var nextElement = displayItem.nextElementSibling;
|
|
var currentText = displayItem.innerText;
|
|
displayItem.innerText = nextElement.innerText;
|
|
nextElement.innerText = currentText;
|
|
nextElement.setAttribute("class", "active");
|
|
displayItem.setAttribute("class", "");
|
|
break;
|
|
}
|
|
}
|
|
});
|
|
|
|
// feature remove function
|
|
allFeaturesRemoveBtns.map((value, index) => {
|
|
value.addEventListener("click", () => {
|
|
for (let i = 0; i < allFeaturesList[index].length; i++) {
|
|
var item = allFeaturesList[index][i];
|
|
console.log(item);
|
|
if (item.getAttribute("class") == "active") {
|
|
/*
|
|
if (item.parentElement.getAttribute("id") == "images-features") {
|
|
let getImages = JSON.parse(localStorage.getItem("customImages"));
|
|
|
|
let filter = getImages.filter(
|
|
(value) => value.fileName !== item.innerText
|
|
);
|
|
localStorage.setItem("customImages", JSON.stringify(filter));
|
|
} else if (item.parentElement.getAttribute("id") == "gifs-features") {
|
|
let getGifs = JSON.parse(localStorage.getItem("customGifs"));
|
|
|
|
let filter = getGifs.filter(
|
|
(value) => value.fileName !== item.innerText
|
|
);
|
|
localStorage.setItem("customGifs", JSON.stringify(filter));
|
|
} else if (
|
|
item.parentElement.getAttribute("id") == "messages-features"
|
|
) {
|
|
let getMsgs = JSON.parse(localStorage.getItem("customMsg"));
|
|
|
|
let filter = getMsgs.filter(
|
|
(value) => value.messageName !== item.innerText
|
|
);
|
|
localStorage.setItem("customMsg", JSON.stringify(filter));
|
|
}
|
|
else {
|
|
*/
|
|
item.remove();
|
|
//}
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
// feature increase function
|
|
allFeaturesIncreaseBtns.map((value, index) => {
|
|
value.addEventListener("click", () => {
|
|
for (let i = 0; i < allFeaturesList[index].length; i++) {
|
|
var item = allFeaturesList[index][i];
|
|
|
|
if (item.getAttribute("class") == "active") {
|
|
var prevElement = item.previousElementSibling;
|
|
var currentText = item.innerText;
|
|
item.innerText = prevElement.innerText;
|
|
prevElement.innerText = currentText;
|
|
prevElement.setAttribute("class", "active");
|
|
item.setAttribute("class", "");
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
// feature decrease function
|
|
allFeaturesDecreaseBtns.map((value, index) => {
|
|
value.addEventListener("click", () => {
|
|
for (let i = 0; i < allFeaturesList[index].length; i++) {
|
|
var item = allFeaturesList[index][i];
|
|
|
|
if (item.getAttribute("class") == "active") {
|
|
var nextElement = item.nextElementSibling;
|
|
var currentText = item.innerText;
|
|
|
|
item.innerText = nextElement.innerText;
|
|
nextElement.innerText = currentText;
|
|
nextElement.setAttribute("class", "active");
|
|
item.setAttribute("class", "");
|
|
break;
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
// all features
|
|
var stocks = document.getElementById("stocks-features");
|
|
var crypto1 = document.getElementById("crypto-features");
|
|
var forex = document.getElementById("forex-features");
|
|
var currentWeather = document.getElementById("current-weather-features");
|
|
var dailyForecast = document.getElementById("daily-forecast-features");
|
|
var news = document.getElementById("news-features");
|
|
var upcomingGames = document.getElementById("upcoming-games-features");
|
|
var pastGames = document.getElementById("past-games-features");
|
|
var liveGames = document.getElementById("live-games-features");
|
|
var teamStats = document.getElementById("team-stats-features");
|
|
var images = document.getElementById("images-features");
|
|
var gifs = document.getElementById("gifs-features");
|
|
var messages = document.getElementById("messages-features");
|
|
|
|
var allFeatures = [
|
|
stocks,
|
|
crypto1,
|
|
forex,
|
|
currentWeather,
|
|
dailyForecast,
|
|
news,
|
|
upcomingGames,
|
|
pastGames,
|
|
liveGames,
|
|
teamStats,
|
|
images,
|
|
gifs,
|
|
messages,
|
|
];
|
|
|
|
// features select box
|
|
var newsSelect = document.getElementById("inputTransition63");
|
|
var upcomingGamesSelect = document.getElementById("inputTransition73");
|
|
var pastGamesSelect = document.getElementById("inputTransition83");
|
|
var liveGamesSelect = document.getElementById("inputTransition93");
|
|
var teamStatsSelect = document.getElementById("inputTransition103");
|
|
var allFeaturesSelectBox = [
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
newsSelect,
|
|
upcomingGamesSelect,
|
|
pastGamesSelect,
|
|
liveGamesSelect,
|
|
teamStatsSelect,
|
|
null,
|
|
null,
|
|
null,
|
|
];
|
|
|
|
// features select add buttons
|
|
var newsAddBtn = document.getElementById("inputTransitionBtn63");
|
|
var upcomingGamesAddBtn = document.getElementById("inputTransitionBtn73");
|
|
var pastGamesAddBtn = document.getElementById("inputTransitionBtn83");
|
|
var liveGamesAddBtn = document.getElementById("inputTransitionBtn93");
|
|
var teamStatsAddBtn = document.getElementById("inputTransitionBtn103");
|
|
var allFeaturesSelectAddBtn = [
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
newsAddBtn,
|
|
upcomingGamesAddBtn,
|
|
pastGamesAddBtn,
|
|
liveGamesAddBtn,
|
|
teamStatsAddBtn,
|
|
null,
|
|
null,
|
|
null,
|
|
];
|
|
|
|
allFeaturesSelectAddBtn.map((value, index) => {
|
|
if (value != null) {
|
|
value.addEventListener("click", () => {
|
|
var tag = document.createElement("li");
|
|
tag.innerHTML = allFeaturesSelectBox[index].value;
|
|
allFeatures[index].appendChild(tag);
|
|
changeVarValue();
|
|
addEventOnFeaturesList();
|
|
});
|
|
}
|
|
});
|
|
|
|
// features input file
|
|
var imagesFile = document.getElementById("inputText11");
|
|
var gifsFile = document.getElementById("inputText1112");
|
|
|
|
var allFeaturesFile = [
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
imagesFile,
|
|
gifsFile,
|
|
null,
|
|
];
|
|
// features file add button
|
|
var imagesFileAddBtn = document.getElementById("inputTextBtn11");
|
|
var gifsFileAddBtn = document.getElementById("inputTextBtn1112");
|
|
|
|
var allFeaturesFileAddBtn = [
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
imagesFileAddBtn,
|
|
gifsFileAddBtn,
|
|
null,
|
|
];
|
|
|
|
// features input text
|
|
var stocksText = document.getElementById("inputText3");
|
|
var cryptoText = document.getElementById("inputText4");
|
|
var forexText = document.getElementById("inputText5");
|
|
var currentWeatherText = document.getElementById("inputText6");
|
|
var dailyForecastText = document.getElementById("inputText7");
|
|
var messagesText = document.getElementById("inputText13");
|
|
|
|
var allFeaturesText = [
|
|
stocksText,
|
|
cryptoText,
|
|
forexText,
|
|
currentWeatherText,
|
|
dailyForecastText,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
messagesText,
|
|
];
|
|
|
|
// features text add button
|
|
var stocksTextAddBtn = document.getElementById("inputTextBtn3");
|
|
var cryptoTextAddBtn = document.getElementById("inputTextBtn4");
|
|
var forexTextAddBtn = document.getElementById("inputTextBtn5");
|
|
var currentWeatherTextAddBtn = document.getElementById("inputTextBtn6");
|
|
var dailyForecastTextAddBtn = document.getElementById("inputTextBtn7");
|
|
var messagesTextAddBtn = document.getElementById("inputTextBtn13");
|
|
|
|
var allFeaturesTextAddBtn = [
|
|
stocksTextAddBtn,
|
|
cryptoTextAddBtn,
|
|
forexTextAddBtn,
|
|
currentWeatherTextAddBtn,
|
|
dailyForecastTextAddBtn,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
messagesTextAddBtn,
|
|
];
|
|
|
|
|
|
var allFeaturesLimit = [
|
|
200,
|
|
100,
|
|
100,
|
|
20,
|
|
20,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
null,
|
|
20,
|
|
20,
|
|
20,
|
|
];
|
|
|
|
|
|
|
|
|
|
allFeaturesTextAddBtn.map((value, index) => {
|
|
if (value !== null) {
|
|
value.addEventListener("click", () => {
|
|
if (value == messagesTextAddBtn) {
|
|
// custom message
|
|
let messageName = document.getElementById("inputText13").value;
|
|
let scrollSpeed1 = document.getElementById("inputScrollSpeed13").value;
|
|
let scrollSpeed2 = document.getElementById(
|
|
"inputScrollSpeedRow13"
|
|
).value;
|
|
let transition = document.getElementById("inputTransition13").value;
|
|
let messageInput = document.getElementById("inputText14").value;
|
|
let colorInput = document.getElementById("inputScrollSpeed16").value;
|
|
let sizeInput = document.getElementById("inputScrollSpeed17").value;
|
|
let backgroundInput =
|
|
document.getElementById("inputScrollSpeed19").value;
|
|
let displayCheck =
|
|
document.getElementById("flexCheckChecked29").checked;
|
|
let messagesWrapper = document.getElementById("messages-features");
|
|
|
|
let fileFound = false;
|
|
|
|
for (let i = 0; i < messagesWrapper.children.length; i++) {
|
|
fileFound =
|
|
messagesWrapper.children[i]?.innerText == messageName && true;
|
|
}
|
|
if (!fileFound) {
|
|
let values = {
|
|
messageName,
|
|
scrollSpeed1,
|
|
scrollSpeed2,
|
|
transition,
|
|
messageInput,
|
|
colorInput,
|
|
sizeInput,
|
|
backgroundInput,
|
|
displayCheck,
|
|
};
|
|
|
|
let getCustomMsg = localStorage.getItem("customMsg");
|
|
|
|
let newValues = getCustomMsg && JSON.parse(getCustomMsg);
|
|
getCustomMsg && newValues.push(values);
|
|
|
|
// getCustomMsg
|
|
// ? localStorage.setItem("customMsg", JSON.stringify(newValues))
|
|
// : localStorage.setItem("customMsg", JSON.stringify([values]));
|
|
var tag = document.createElement("li");
|
|
var msg = "You've reached the maximum limit of items to add for this feature";
|
|
|
|
// if the list length exceeds the limit
|
|
if (allFeatures[index].getElementsByTagName("li").length == allFeaturesLimit[index]){
|
|
document.getElementById("limit-msg").innerHTML = msg;
|
|
}
|
|
|
|
else{
|
|
tag.innerHTML = allFeaturesText[index].value;
|
|
allFeatures[index].appendChild(tag);
|
|
changeVarValue();
|
|
addEventOnFeaturesList();
|
|
}
|
|
}
|
|
} else {
|
|
var msg = "You've reached the maximum limit of items to add for this feature";
|
|
|
|
// if the list length exceeds the limit
|
|
if (allFeatures[index].getElementsByTagName("li").length > allFeaturesLimit[index]){
|
|
document.getElementById("limit-msg").innerHTML = msg;
|
|
}
|
|
|
|
else{
|
|
var tag = document.createElement("li");
|
|
tag.innerHTML = allFeaturesText[index].value;
|
|
allFeatures[index].appendChild(tag);
|
|
changeVarValue();
|
|
addEventOnFeaturesList();
|
|
}
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
var startButton = document.getElementById("start-btn");
|
|
// start the display
|
|
startButton.addEventListener("click", () => {
|
|
fetch("/start", {
|
|
method: "PUT",
|
|
});
|
|
});
|
|
|
|
var brightnessButton = document.getElementById("brightness-btn");
|
|
// start the display
|
|
brightnessButton.addEventListener("click", () => {
|
|
let brightness = document.querySelectorAll(".brightness-text")[0].value;
|
|
fetch("/brightness", {
|
|
method: "PUT",
|
|
body: JSON.stringify({ brightness: brightness }),
|
|
});
|
|
});
|
|
|
|
var shutdownButton = document.getElementById("shutdown-btn");
|
|
|
|
shutdownButton.addEventListener("click", () => {
|
|
fetch("/shutdown", {
|
|
method: "GET",
|
|
});
|
|
});
|
|
|
|
|
|
var restartButton = document.getElementById("restart-btn");
|
|
|
|
restartButton.addEventListener("click", () => {
|
|
fetch("/restart", {
|
|
method: "GET",
|
|
});
|
|
});
|
|
|
|
var resetButton = document.getElementById("reset-btn");
|
|
|
|
resetButton.addEventListener("click", () => {
|
|
fetch("/reset", {
|
|
method: "GET",
|
|
});
|
|
});
|
|
|
|
|
|
var stopButton = document.getElementById("stop-btn");
|
|
stopButton.addEventListener("click", () => {
|
|
fetch("/stop", {
|
|
method: "GET",
|
|
});
|
|
});
|
|
|
|
|
|
|
|
var screensaverButton = document.getElementById("screensaver-btn");
|
|
screensaverButton.addEventListener("click", () => {
|
|
let anim = localStorage.getItem("inputAnimation");
|
|
|
|
|
|
fetch("/screensaver", {
|
|
method: "POST",
|
|
body: anim,
|
|
});
|
|
});
|
|
|
|
var updateButton = document.getElementById("update-btn");
|
|
updateButton.addEventListener("click", () => {
|
|
|
|
fetch("/update", {
|
|
method: "POST",
|
|
});
|
|
});
|
|
|
|
|
|
|
|
var dispFormatButton = document.getElementById("dispformat-btn");
|
|
|
|
var displayFormats = document.getElementById("inputDisplayFormat");
|
|
|
|
// gets selected functions to display
|
|
function getSelected(selector) {
|
|
var opt;
|
|
for (var i = 0, len = selector.options.length; i < len; i++) {
|
|
opt = selector.options[i];
|
|
|
|
if (opt.selected === true) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
return opt.innerHTML;
|
|
}
|
|
|
|
function getListItems(list_el) {
|
|
let symbols = list_el.getElementsByTagName("li");
|
|
|
|
let items = [];
|
|
for (var i = 0; i < symbols.length; ++i) {
|
|
items.push(symbols[i].innerText);
|
|
}
|
|
return items;
|
|
}
|
|
|
|
|
|
|
|
|
|
// gets which features are to be displayed
|
|
function getDisplaying(){
|
|
let opt = getSelected(displayFormats);
|
|
|
|
if (opt.includes("Standard")) {
|
|
var list_el = document.getElementById("display-format");
|
|
|
|
let features = getListItems(list_el);
|
|
|
|
return [features];
|
|
} else if (opt.includes("Professional")) {
|
|
|
|
var top_list_el = document.getElementById("display-format");
|
|
|
|
let top_features = getListItems(top_list_el);
|
|
|
|
|
|
var bot_list_el = document.getElementById("display-format-2");
|
|
|
|
let bot_features = getListItems(bot_list_el);
|
|
|
|
|
|
let features = [top_features, bot_features];
|
|
|
|
|
|
return features;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// gets feature specific settings
|
|
function getFeatureSettings() {
|
|
|
|
let featureSelector = document.getElementById("drop");
|
|
feature = getSelected(featureSelector);
|
|
let features = [
|
|
"Stocks",
|
|
"Crypto",
|
|
"Forex",
|
|
"Current Weather",
|
|
"Daily Forecast",
|
|
"News",
|
|
"Sports (Upcoming Games)",
|
|
"Sports (Past Games)",
|
|
"Sports (Live Games)",
|
|
"Sports (Team Stats)",
|
|
"Custom Images",
|
|
"Custom GIFs",
|
|
"Custom Messages",
|
|
];
|
|
let pageNum = features.indexOf(feature) + 1;
|
|
let pageSelector = "Page" + pageNum.toString();
|
|
|
|
let page = document.getElementById(pageSelector);
|
|
|
|
// these common to all settings
|
|
let speed = getSelected(page.querySelectorAll(".speed-select")[0]);
|
|
let animation = getSelected(page.querySelectorAll(".animation-select")[0]);
|
|
|
|
var settings = { feature: feature, speed: speed, animation: animation }; // general settings
|
|
|
|
var s;
|
|
//function specific settings
|
|
switch (pageNum) {
|
|
case 1:
|
|
case 2:
|
|
case 3:
|
|
s = getTradingSettings(page);
|
|
break;
|
|
case 4:
|
|
case 5:
|
|
s = getWeatherSettings(page);
|
|
break;
|
|
case 6:
|
|
s = getNewsSettings(page);
|
|
break;
|
|
case 7:
|
|
case 8:
|
|
case 9:
|
|
case 10:
|
|
s = getSportsSettings(page);
|
|
break;
|
|
case 11:
|
|
case 12:
|
|
s = getImageSettings(page);
|
|
break;
|
|
case 13:
|
|
s = getMessageSettings(page);
|
|
break;
|
|
}
|
|
|
|
settings = { ...settings, ...s }; // merge both sets of settings
|
|
|
|
|
|
|
|
return settings;
|
|
}
|
|
|
|
function getFiles() {
|
|
var data = new FormData();
|
|
|
|
for (var i = 0; i < uploaded_images.length; i++) {
|
|
data.append(uploaded_images[i].name, uploaded_images[i]);
|
|
console.log(uploaded_images[i].name);
|
|
}
|
|
for (var i = 0; i < uploaded_GIFs.length; i++) {
|
|
data.append(uploaded_GIFs[i].name, uploaded_GIFs[i]);
|
|
}
|
|
|
|
|
|
//return data;
|
|
|
|
fetch("/upload", {
|
|
method: "POST",
|
|
body: data,
|
|
});
|
|
}
|
|
|
|
function saveSettings() {
|
|
|
|
let displaying = getDisplaying();
|
|
let feature_settings = getFeatureSettings();
|
|
let files = getFiles();
|
|
|
|
|
|
|
|
console.log(JSON.stringify({'displaying': displaying, 'feature_settings': feature_settings, 'files':files}));
|
|
|
|
|
|
|
|
fetch("/save", {
|
|
method: "POST",
|
|
body: JSON.stringify({'displaying': displaying, 'feature_settings': feature_settings}),
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
let saveSettingsButtons = document.querySelectorAll(".save-btn").forEach((button) => button.addEventListener("click", saveSettings));
|
|
|
|
// gets the stock, crypto or forex specific settings
|
|
function getTradingSettings(page) {
|
|
// get all the tick boxes
|
|
let percent = page.querySelectorAll(".percent-select")[0].checked;
|
|
let point = page.querySelectorAll(".point-select")[0].checked;
|
|
let no_logos = page.querySelectorAll(".logo-select")[0].checked;
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
|
|
let symbols_el = page.querySelectorAll(".symbol-list")[0];
|
|
let symbols = getListItems(symbols_el);
|
|
|
|
let settings = {
|
|
percent: percent,
|
|
point: point,
|
|
logos: no_logos,
|
|
title: title,
|
|
symbols: symbols,
|
|
};
|
|
|
|
return settings;
|
|
}
|
|
|
|
// gets the current wether and forecast settings
|
|
function getWeatherSettings(page) {
|
|
let temp = getSelected(page.querySelectorAll(".temp-select")[0]);
|
|
let speed = getSelected(page.querySelectorAll(".wind-speed-select")[0]);
|
|
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
let api_key = page.querySelectorAll(".api-key")[0];
|
|
|
|
let
|
|
settings = {
|
|
temp: temp,
|
|
wind_speed: speed,
|
|
title: title,
|
|
api_key:api_key
|
|
};
|
|
|
|
//only for daily weather
|
|
try {
|
|
current_weather = page.querySelectorAll(".current-weather-select")[0]
|
|
.checked;
|
|
settings["current_weather"] = current_weather;
|
|
} catch {}
|
|
|
|
let locations_el = page.querySelectorAll(".location-list")[0];
|
|
let locations = getListItems(locations_el);
|
|
settings["locations"] = locations;
|
|
console.log(settings);
|
|
return settings;
|
|
}
|
|
|
|
function saveWeatherAPIKey(){
|
|
let featureSelector = document.getElementById("drop");
|
|
feature = getSelected(featureSelector);
|
|
let features = [
|
|
"Stocks",
|
|
"Crypto",
|
|
"Forex",
|
|
"Current Weather",
|
|
"Daily Forecast",
|
|
"News",
|
|
"Sports (Upcoming Games)",
|
|
"Sports (Past Games)",
|
|
"Sports (Live Games)",
|
|
"Sports (Team Stats)",
|
|
"Custom Images",
|
|
"Custom GIFs",
|
|
"Custom Messages",
|
|
];
|
|
let pageNum = features.indexOf(feature) + 1;
|
|
let pageSelector = "Page" + pageNum.toString();
|
|
|
|
let page = document.getElementById(pageSelector);
|
|
|
|
let api_key = page.querySelectorAll(".api-key")[0].value;
|
|
let settings = {
|
|
api_key:api_key
|
|
};
|
|
|
|
console.log(settings);
|
|
|
|
fetch("/saveWeatherAPIKey", {
|
|
method: "POST",
|
|
body: JSON.stringify(settings),
|
|
});
|
|
}
|
|
|
|
|
|
|
|
|
|
var weatherAPIbtn = document.getElementById("weather-api-btn");
|
|
weatherAPIbtn.addEventListener("click", saveWeatherAPIKey);
|
|
|
|
function getNewsSettings(page) {
|
|
|
|
let country = getSelected(page.querySelectorAll(".country-select")[0]);
|
|
let category = getSelected(page.querySelectorAll(".category-select")[0]);
|
|
let country_check = page.querySelectorAll(".country-check")[0].checked;
|
|
let category_check = page.querySelectorAll(".category-check")[0].checked;
|
|
|
|
let num_headlines = page.querySelectorAll(".headline-num")[0].value
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
|
|
settings = {
|
|
country: country,
|
|
category: category,
|
|
use_country: country_check,
|
|
use_category: category_check,
|
|
num_headlines: num_headlines,
|
|
title: title,
|
|
};
|
|
|
|
console.log(settings);
|
|
return settings;
|
|
}
|
|
|
|
function getSportsSettings(page) {
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
let leagues_el = page.querySelectorAll(".league-list")[0];
|
|
leagues = getListItems(leagues_el);
|
|
|
|
|
|
settings = { title: title, leagues: leagues };
|
|
return settings;
|
|
}
|
|
|
|
var uploaded_images = [];
|
|
var uploaded_GIFs = [];
|
|
|
|
allFeaturesFileAddBtn.map((value, index) => {
|
|
if (value !== null) {
|
|
value.addEventListener("click", () => {
|
|
var tag = document.createElement("li");
|
|
tag.innerHTML = allFeaturesFile[index].files[0].name;
|
|
if (index == 10) {
|
|
let getCustomImg = localStorage.getItem("customImages");
|
|
let fileName = imagesFile.files[0].name;
|
|
let scrollSpeed = document.getElementById("inputScrollSpeed11").value;
|
|
let scrollSpeed2 = document.getElementById(
|
|
"inputScrollSpeedRow11"
|
|
).value;
|
|
let transition = document.getElementById("inputTransition11").value;
|
|
let pauseScreen = document.getElementById("inputText12").value;
|
|
let displayCheck =
|
|
document.getElementById("flexCheckChecked25").checked;
|
|
|
|
let fileFound = false;
|
|
|
|
for (let i = 0; i < allFeatures[index].children.length; i++) {
|
|
fileFound =
|
|
allFeatures[index].children[i]?.innerText == fileName && true;
|
|
}
|
|
if (!fileFound) {
|
|
let values = {
|
|
fileName,
|
|
scrollSpeed,
|
|
scrollSpeed2,
|
|
transition,
|
|
pauseScreen,
|
|
displayCheck,
|
|
};
|
|
|
|
let newValues = getCustomImg && JSON.parse(getCustomImg);
|
|
getCustomImg && newValues.push(values);
|
|
|
|
// getCustomImg
|
|
// ? localStorage.setItem("customImages", JSON.stringify(newValues))
|
|
// : localStorage.setItem("customImages", JSON.stringify([values]));
|
|
|
|
uploaded_images.push(allFeaturesFile[index].files[0]);
|
|
allFeatures[index].appendChild(tag);
|
|
}
|
|
} else if (index == 11) {
|
|
let getCustomGifs = localStorage.getItem("customGifs");
|
|
let fileName = allFeaturesFile[index].files[0].name;
|
|
let scrollSpeed = document.getElementById("inputScrollSpeed12").value;
|
|
let scrollSpeed2 = document.getElementById(
|
|
"inputScrollSpeedRow12"
|
|
).value;
|
|
let transition = document.getElementById("inputTransition12").value;
|
|
let pauseScreen = document.getElementById("inputText112").value;
|
|
let displayCheck =
|
|
document.getElementById("flexCheckChecked28").checked;
|
|
|
|
let fileFound = false;
|
|
|
|
for (let i = 0; i < allFeatures[index].children.length; i++) {
|
|
fileFound =
|
|
allFeatures[index].children[i]?.innerText == fileName && true;
|
|
}
|
|
if (!fileFound) {
|
|
let values = {
|
|
fileName,
|
|
scrollSpeed,
|
|
scrollSpeed2,
|
|
transition,
|
|
pauseScreen,
|
|
displayCheck,
|
|
};
|
|
|
|
let newValues = getCustomGifs && JSON.parse(getCustomGifs);
|
|
getCustomGifs && newValues.push(values);
|
|
|
|
// getCustomGifs
|
|
// ? localStorage.setItem("customGifs", JSON.stringify(newValues))
|
|
// : localStorage.setItem("customGifs", JSON.stringify([values]));
|
|
|
|
uploaded_GIFs.push(allFeaturesFile[index].files[0]);
|
|
allFeatures[index].appendChild(tag);
|
|
}
|
|
}
|
|
imagesFile.value = "";
|
|
changeVarValue();
|
|
addEventOnFeaturesList();
|
|
});
|
|
}
|
|
});
|
|
|
|
//images and GIFs
|
|
function getImageSettings(page) {
|
|
let pause = page.querySelectorAll(".pause-select")[0].value;
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
|
|
let images_el = page.querySelectorAll(".image-list")[0];
|
|
images = getListItems(images_el);
|
|
|
|
settings = { title: title, pause: pause, images: images };
|
|
return settings;
|
|
}
|
|
|
|
var messages = [];
|
|
|
|
messagesTextAddBtn.addEventListener("click", () => {
|
|
let pageSelector = "Page13";
|
|
|
|
let page = document.getElementById(pageSelector);
|
|
|
|
let msg_name = messagesText.value;
|
|
//let speed = getSelected(page.querySelectorAll(".speed-select")[0]);
|
|
//let animation = getSelected(page.querySelectorAll(".animation-select")[0]);
|
|
|
|
let message_text = page.querySelectorAll(".message-input")[0].value;
|
|
let text_colour = getSelected(page.querySelectorAll(".text-colour")[0]);
|
|
let text_size = getSelected(page.querySelectorAll(".text-size")[0]);
|
|
let background_colour = getSelected(page.querySelectorAll(".back-colour")[0]);
|
|
|
|
let message = {
|
|
name: msg_name,
|
|
text: message_text,
|
|
text_colour: text_colour,
|
|
size: text_size,
|
|
background_colour: background_colour,
|
|
};
|
|
messages.push(message);
|
|
});
|
|
|
|
function getMessageSettings(page) {
|
|
let messages_el = page.querySelectorAll(".message-list")[0];
|
|
let message_names = getListItems(messages_el);
|
|
|
|
//remove any messages that arent in the list
|
|
let new_messages = [];
|
|
let new_names = [];
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < message_names.length; i++) {
|
|
|
|
for (let j = 0; j < messages.length; j++) {
|
|
|
|
if (message_names[i] == messages[j]["name"]) {
|
|
new_messages.push(messages[j]);
|
|
new_names.push(messages[j]["name"]);
|
|
}
|
|
}
|
|
|
|
|
|
if ( !(new_names.includes(message_names[i]))) {
|
|
new_messages.push({name: message_names[i]});
|
|
}
|
|
|
|
}
|
|
|
|
let title = page.querySelectorAll(".title-select")[0].checked;
|
|
return { title: title, messages: new_messages };
|
|
}
|
|
|
|
// Join Network
|
|
|
|
let wifiSsidInput = document.getElementById("wifi-ssid-input");
|
|
let wifiPassInput = document.getElementById("wifi-pass-input");
|
|
let countryCodeInput = document.getElementById("country-code-input");
|
|
|
|
let joinNetworkBtn = document.querySelector("#join-network-btn");
|
|
let connectedText = document.querySelector("#connected-text");
|
|
|
|
// joinNetworkBtn.addEventListener("click", () => {
|
|
// localStorage.setItem("wifiSsid", wifiSsidInput.value);
|
|
// localStorage.setItem("wifiPass", wifiPassInput.value);
|
|
// localStorage.setItem("countryCode", countryCodeInput.value);
|
|
|
|
// connectedText.style.display = "block";
|
|
// setTimeout(() => {
|
|
// connectedText.style.display = "none";
|
|
// }, 2000);
|
|
|
|
// data = {country:countryCodeInput.value, ssid:wifiSsidInput.value, pwd:wifiPassInput.value}
|
|
|
|
// fetch("/wifi", {
|
|
// method: "POST",
|
|
// body: JSON.stringify(data),
|
|
// });
|
|
// });
|
|
|
|
// change display format
|
|
let displayFormatDropDown = document.querySelector("#inputDisplayFormat");
|
|
let displayFormatBtn = document.querySelector("#dispformat-btn");
|
|
let selectedDisplayText = document.querySelector("#selected-display-text");
|
|
let topRowText = document.querySelector("#top-row-text");
|
|
let bottomRowText = document.querySelector("#bottom-row-text");
|
|
|
|
displayFormatBtn.addEventListener("click", () => {
|
|
selectedDisplayText.innerText = displayFormatDropDown.value;
|
|
localStorage.setItem("displayFormat", displayFormatDropDown.value);
|
|
if (selectedDisplayText.innerText === "Professional two rows") {
|
|
topRowText.style.display = "inline";
|
|
bottomRowText.style.display = "inline";
|
|
secondRow.style.display = "flex";
|
|
inputScrollSpeedRow.forEach((value) => {
|
|
value.parentElement.parentElement.style.display = "flex";
|
|
});
|
|
} else {
|
|
topRowText.style.display = "none";
|
|
bottomRowText.style.display = "none";
|
|
secondRow.style.display = "none";
|
|
inputScrollSpeedRow.forEach((value) => {
|
|
value.parentElement.parentElement.style.display = "none";
|
|
});
|
|
}
|
|
});
|
|
|
|
// if selected display text = Professional two rows
|
|
|
|
if (selectedDisplayText.innerText === "Professional two rows") {
|
|
topRowText.style.display = "inline";
|
|
}
|
|
|
|
// change host name
|
|
|
|
let hostNameInput = document.getElementById("host-name-input");
|
|
let hostNameBtn = document.getElementById("host-name-btn");
|
|
let hostNameText = document.getElementById("host-name");
|
|
|
|
hostNameBtn.addEventListener("click", () => {
|
|
hostNameText.innerText = hostNameInput.value;
|
|
// localStorage.setItem("hostName", hostNameText.innerText);
|
|
|
|
data = {hostname:hostNameText.innerText}
|
|
|
|
fetch("/hostname", {
|
|
method: "POST",
|
|
body: JSON.stringify(data),
|
|
});
|
|
});
|
|
|
|
// Add Weather API Key
|
|
|
|
// let weatherKeyInput = document.getElementById("api-key");
|
|
// let weatherKeyBtn = document.getElementById("weather-api-button");
|
|
// let inputTextWeather = document.getElementById("inputText-weather");
|
|
|
|
// weatherKeyBtn.addEventListener("click", () => {
|
|
// inputTextWeather.innerText = weatherKeyInput.value;
|
|
// data = {api-key:inputTextWeather.innerText}
|
|
|
|
// fetch("/weatherAPI", {
|
|
// method: "POST",
|
|
// body: JSON.stringify(data),
|
|
// });
|
|
// });
|
|
|
|
|
|
// change brightness
|
|
|
|
let brightnessInput = document.getElementById("brightness-input");
|
|
let brightnessBtn = document.getElementById("brightness-btn");
|
|
|
|
brightnessBtn.addEventListener("click", () => {
|
|
// localStorage.setItem("brightness", brightnessInput.value);
|
|
});
|
|
|
|
// change input animation
|
|
let inputAnimation = document.getElementById("inputAnimation");
|
|
let inputAnimationBtn = document.getElementById("input-animation-btn");
|
|
|
|
inputAnimationBtn.addEventListener("click", () => {
|
|
localStorage.setItem("inputAnimation", inputAnimation.value);
|
|
|
|
});
|
|
|
|
// scroll speed row two
|
|
let inputScrollSpeedRow = [];
|
|
|
|
for (let i = 1; i <= 13; i++) {
|
|
inputScrollSpeedRow.push(
|
|
document.getElementById(
|
|
i === 1 ? "inputScrollSpeedRow" : `inputScrollSpeedRow${i}`
|
|
)
|
|
);
|
|
}
|
|
|
|
window.onload = () => {
|
|
// let getHostName = localStorage.getItem("hostName");
|
|
// let getBrightness = localStorage.getItem("brightness");
|
|
// let getWifiSsid = localStorage.getItem("wifiSsid");
|
|
// let getWifiPass = localStorage.getItem("wifiPass");
|
|
// let getCountryCode = localStorage.getItem("countryCode");
|
|
// let getInputAnimation = localStorage.getItem("inputAnimation");
|
|
|
|
// getHostName &&
|
|
// (hostNameText.innerText = getHostName) &&
|
|
// (hostNameInput.value = getHostName);
|
|
|
|
//getBrightness && (brightnessInput.value = getBrightness);
|
|
//getWifiSsid && (wifiSsidInput.value = getWifiSsid);
|
|
//getWifiPass && (wifiPassInput.value = getWifiPass);
|
|
//getCountryCode && (countryCodeInput.value = getCountryCode);
|
|
|
|
let getDispayFormat = localStorage.getItem("displayFormat");
|
|
getDispayFormat && (displayFormatDropDown.value = getDispayFormat);
|
|
selectedDisplayText.innerText = displayFormatDropDown.value;
|
|
|
|
// getInputAnimation && (inputAnimation.value = getInputAnimation);
|
|
|
|
if (selectedDisplayText.innerText === "Professional two rows") {
|
|
topRowText.style.display = "inline";
|
|
bottomRowText.style.display = "inline";
|
|
secondRow.style.display = "flex";
|
|
inputScrollSpeedRow.forEach((value) => {
|
|
value.parentElement.parentElement.style.display = "flex";
|
|
});
|
|
} else {
|
|
topRowText.style.display = "none";
|
|
bottomRowText.style.display = "none";
|
|
secondRow.style.display = "none";
|
|
inputScrollSpeedRow.forEach((value) => {
|
|
value.parentElement.parentElement.style.display = "none";
|
|
});
|
|
}
|
|
|
|
// custom images
|
|
|
|
/*
|
|
let localCustomImages = JSON.parse(localStorage.getItem("customImages"));
|
|
localCustomImages?.map((value) => {
|
|
let tag = document.createElement("li");
|
|
tag.innerText = value.fileName;
|
|
images.appendChild(tag);
|
|
});
|
|
// custom gifs
|
|
let localCustomGifs = JSON.parse(localStorage.getItem("customGifs"));
|
|
localCustomGifs?.map((value) => {
|
|
let tag = document.createElement("li");
|
|
tag.innerText = value.fileName;
|
|
gifs.appendChild(tag);
|
|
});
|
|
// custom messages
|
|
let localCustomMsg = JSON.parse(localStorage.getItem("customMsg"));
|
|
localCustomMsg?.map((value) => {
|
|
let tag = document.createElement("li");
|
|
tag.innerText = value.messageName;
|
|
var messagesWrapper = document.getElementById("messages-features");
|
|
|
|
messagesWrapper.appendChild(tag);
|
|
});
|
|
* */
|
|
addEventOnList();
|
|
addEventonBtns();
|
|
changeVarValue();
|
|
addEventOnFeaturesList();
|
|
};
|