Update Pixel Magic Tool

Reducing the size of HTML/CSS/Javascript
This commit is contained in:
Alerson Jorge 2023-10-24 12:52:06 -03:00
parent 789e34702b
commit a1f28caa8e
2 changed files with 695 additions and 780 deletions

View File

@ -162,13 +162,42 @@
padding-bottom: 20px; padding-bottom: 20px;
} }
.header .brand { .header {
width: 100%; display: flex;
max-width: 200px; flex-direction: column;
height: 100%; align-items: start;
display: block; padding-bottom: 20px;
outline: none; }
border: 0;
.header .title {
font-size: 36px;
font-weight: 600;
color: var(--gray-light);
}
.header .subtitle {
font-size: 12px;
color: var(--text);
}
.header .rainbow {
background: linear-gradient(
to right,
#ef5350,
#f48fb1,
#7e57c2,
#2196f3,
#26c6da,
#43a047,
#eeff41,
#f9a825,
#ff5722
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-size: 200% 200%;
animation: rainbow 5s linear infinite;
transition: background-position 0.5s ease;
} }
label { label {
@ -554,6 +583,15 @@
transform: translateY(0); transform: translateY(0);
} }
} }
@keyframes rainbow {
0% {
background-position: 0% 0;
}
100% {
background-position: 200% 0;
}
}
</style> </style>
</head> </head>
<body> <body>
@ -561,8 +599,14 @@
<div class="content"> <div class="content">
<form id="formGenerate" novalidate> <form id="formGenerate" novalidate>
<div class="header"> <div class="header">
<img alt="Pixel Magic Tool" width="200" height="130" src="" /> <span class="title"
<!--img width="200" height="130" src="" alt="Pixel Magic Tool" class="brand" /--> >PIXEL <span class="rainbow">MAGIC</span> TOOL</span
>
<span class="subtitle"
>It is a tool that converts any image into code in
<strong>JSON WLED</strong> format for
<strong>2D Matrix</strong> panels</span
>
</div> </div>
<div class="row"> <div class="row">
<div class="column" validate> <div class="column" validate>
@ -774,7 +818,7 @@
type="file" type="file"
name="source" name="source"
id="source" id="source"
accept="image/jpg,image/jpeg,image/png,image/gif" accept="image/*"
style="display: none" /> style="display: none" />
</div> </div>
<div class="row"> <div class="row">
@ -837,7 +881,7 @@
let WLED_URL = `${protocol}//${host}`; let WLED_URL = `${protocol}//${host}`;
const hostname = element("hostname"); const hostname = gId("hostname");
hostname.value = host; hostname.value = host;
hostname.addEventListener("blur", async () => { hostname.addEventListener("blur", async () => {
@ -859,19 +903,19 @@
hostnameLabel(); hostnameLabel();
})(); })();
function element(id) { function gId(id) {
return d.getElementById(id); return d.getElementById(id);
} }
function hostnameLabel() { function hostnameLabel() {
const link = element("wledEdit"); const link = gId("wledEdit");
link.href = WLED_URL + "/edit"; link.href = WLED_URL + "/edit";
} }
async function playlist() { async function playlist() {
const { value: duration } = element("duration"); const { value: duration } = gId("duration");
const { value: transition } = element("transition"); const { value: transition } = gId("transition");
const { value: name } = element("name"); const { value: name } = gId("name");
const urlPreset = `${WLED_URL}/presets.json`; const urlPreset = `${WLED_URL}/presets.json`;
const url = `${WLED_URL}/json`; const url = `${WLED_URL}/json`;
@ -1004,7 +1048,7 @@
async function images() { async function images() {
const url = `${WLED_URL}/edit?list=/`; const url = `${WLED_URL}/edit?list=/`;
const select = element("images"); const select = gId("images");
show(); show();
@ -1050,9 +1094,9 @@
} }
async function segments() { async function segments() {
const select = element("segments"); const select = gId("segments");
const width = element("width"); const width = gId("width");
const height = element("height"); const height = gId("height");
show(); show();
@ -1099,8 +1143,8 @@
} }
} }
const dropzone = element("dropzone"); const dropzone = gId("dropzone");
const source = element("source"); const source = gId("source");
dropzone.addEventListener("dragover", (e) => { dropzone.addEventListener("dragover", (e) => {
e.preventDefault(); e.preventDefault();
@ -1109,12 +1153,10 @@
dropzone.addEventListener("drop", (e) => { dropzone.addEventListener("drop", (e) => {
e.preventDefault(); e.preventDefault();
const dropzoneLabel = element("dropzoneLabel");
source.files = e.dataTransfer.files; source.files = e.dataTransfer.files;
const { name } = source.files[0]; const { name } = source.files[0];
dropzoneLabel.textContent = `Image ${name} selected!`; gId("dropzoneLabel").textContent = `Image ${name} selected!`;
validate(e); validate(e);
}); });
@ -1124,7 +1166,7 @@
}); });
source.addEventListener("change", (e) => { source.addEventListener("change", (e) => {
const dropzoneLabel = element("dropzoneLabel"); const dropzoneLabel = gId("dropzoneLabel");
const { value } = e.target; const { value } = e.target;
if (value) { if (value) {
@ -1138,7 +1180,7 @@
validate(e); validate(e);
}); });
element("btnSimulatePreset").addEventListener("click", async () => { gId("btnSimulatePreset").addEventListener("click", async () => {
const url = `${WLED_URL}/json/state`; const url = `${WLED_URL}/json/state`;
const options = { const options = {
@ -1162,9 +1204,9 @@
} }
}); });
element("btnSave").addEventListener("click", async () => { gId("btnSave").addEventListener("click", async () => {
const { checked } = element("animation"); const { checked } = gId("animation");
const { value: name } = element("name"); const { value: name } = gId("name");
if (checked) { if (checked) {
await insert(jsonSaveWLED, true); await insert(jsonSaveWLED, true);
@ -1179,8 +1221,8 @@
} }
}); });
element("btnCopyToClipboard").addEventListener("click", async () => { gId("btnCopyToClipboard").addEventListener("click", async () => {
const response = element("response"); const response = gId("response");
response.select(); response.select();
@ -1197,9 +1239,9 @@
} }
}); });
element("btnDownloadPreset").addEventListener("click", () => { gId("btnDownloadPreset").addEventListener("click", () => {
const { value: response } = element("response"); const { value: response } = gId("response");
const { value: output } = element("output"); const { value: output } = gId("output");
const timestamp = new Date().getTime(); const timestamp = new Date().getTime();
const filename = `WLED_${timestamp}`; const filename = `WLED_${timestamp}`;
@ -1207,55 +1249,42 @@
downloadFile(response, filename, output); downloadFile(response, filename, output);
}); });
element("segments").addEventListener("change", (e) => { gId("segments").addEventListener("change", (e) => {
const width = element("width"); const { width, height } = e.target.selectedOptions[0].dataset;
const height = element("height");
const { width: w, height: h } = e.target.selectedOptions[0].dataset; gId("width").value = w;
gId("height").value = h;
width.value = w;
height.value = h;
}); });
element("output").addEventListener("change", (e) => { gId("output").addEventListener("change", (e) => {
const output = d.getElementsByClassName("output");
const { value } = e.target.selectedOptions[0]; const { value } = e.target.selectedOptions[0];
Array.from(output).forEach(function (element) { d.querySelector(".output").style.display =
if (value === "ha") { value === "ha" ? "flex" : "none";
element.style.display = "flex";
} else {
element.style.display = "none";
}
});
}); });
element("brightnessValue").addEventListener("input", (e) => { gId("brightnessValue").addEventListener("input", (e) => {
const brightness = element("brightness");
const { value } = e.target; const { value } = e.target;
let bri = value <= 255 ? value : 255; let bri = value <= 255 ? value : 255;
brightness.value = bri; gId("brightness").value = bri;
e.target.value = bri; e.target.value = bri;
}); });
element("brightness").addEventListener("input", (e) => { gId("brightness").addEventListener("input", (e) => {
const brightnessValue = element("brightnessValue");
const { value } = e.target; const { value } = e.target;
brightnessValue.value = value; gId("brightnessValue").value = value;
}); });
element("images").addEventListener("change", (e) => { gId("images").addEventListener("change", (e) => {
const dropzone = element("dropzone"); const dropzone = gId("dropzone");
const { value } = e.target.selectedOptions[0]; const { value } = e.target.selectedOptions[0];
if (!value) { if (!value) {
const dropzoneLabel = element("dropzoneLabel"); const source = gId("source");
const source = element("source");
dropzoneLabel.textContent = gId("dropzoneLabel").textContent =
"Drag and drop a file here or click to select a local file"; "Drag and drop a file here or click to select a local file";
source.value = ""; source.value = "";
@ -1265,31 +1294,25 @@
} }
}); });
element("transparentImage").addEventListener("change", (e) => { gId("transparentImage").addEventListener("change", (e) => {
const transparentImage = d.getElementsByClassName("transparentImage")[0];
const { checked } = e.target; const { checked } = e.target;
if (checked) { d.querySelector(".transparentImage").style.display = checked
transparentImage.style.display = "flex"; ? "flex"
} else { : "none";
transparentImage.style.display = "none";
}
}); });
element("resizeImage").addEventListener("change", (e) => { gId("resizeImage").addEventListener("change", (e) => {
const resizeImage = d.getElementsByClassName("resizeImage")[0];
const { checked } = e.target; const { checked } = e.target;
if (checked) { d.querySelector(".resizeImage").style.display = checked
resizeImage.style.display = "flex"; ? "flex"
} else { : "none";
resizeImage.style.display = "none";
}
}); });
element("animation").addEventListener("change", (e) => { gId("animation").addEventListener("change", (e) => {
const animation = d.getElementsByClassName("animation")[0]; const animation = d.querySelector(".animation");
const source = element("source"); const source = gId("source");
const { checked } = e.target; const { checked } = e.target;
@ -1305,24 +1328,23 @@
} else { } else {
source.setAttribute( source.setAttribute(
"accept", "accept",
"image/jpg,image/jpeg,image/png,image/gif" "image/*"
); );
animation.style.display = "none"; animation.style.display = "none";
} }
}); });
element("btnGenerate").addEventListener("click", async (event) => { gId("btnGenerate").addEventListener("click", async (event) => {
const { checked } = element("animation"); const { checked } = gId("animation");
const preview = element("preview");
const recreatedImage = element("recreatedImage");
const simulate = element("simulate");
if (validate(event)) { if (validate(event)) {
jsonSaveWLED.splice(0);
preview.style.display = "block"; jsonSaveWLED.splice(0);
recreatedImage.innerHTML = "";
gId("preview").style.display = "block";
gId("recreatedImage").innerHTML = "";
const simulate = gId("simulate");
if (checked) { if (checked) {
simulate.style.display = "none"; simulate.style.display = "none";
@ -1351,16 +1373,16 @@
} }
async function generate() { async function generate() {
const file = element("source").files[0]; const file = gId("source").files[0];
const { value: images } = element("images"); const { value: images } = gId("images");
const { value: output } = element("output"); const { value: output } = gId("output");
show(); show();
try { try {
const response = element("response"); const response = gId("response");
const recreatedImage = element("recreatedImage"); const recreatedImage = gId("recreatedImage");
const urlImage = !images ? URL.createObjectURL(file) : images; const urlImage = !images ? URL.createObjectURL(file) : images;
@ -1393,14 +1415,14 @@
} }
async function generateAnimation() { async function generateAnimation() {
const file = element("source").files[0]; const file = gId("source").files[0];
const images = element("images"); const images = gId("images");
const response = element("response"); const response = gId("response");
const { value: presetName } = element("name"); const { value: presetName } = gId("name");
const { value: amount } = element("frames"); const { value: amount } = gId("frames");
const { value: output } = element("output"); const { value: output } = gId("output");
const { value: duration } = element("duration"); const { value: duration } = gId("duration");
const { text: imageName, value: imageValue } = images.selectedOptions[0]; const { text: imageName, value: imageValue } = images.selectedOptions[0];
@ -1480,18 +1502,18 @@
} }
function recreate(image) { function recreate(image) {
const { value: pattern } = element("pattern"); const { value: pattern } = gId("pattern");
const { value: segmentId } = element("segments"); const { value: segmentId } = gId("segments");
const { value: brightness } = element("brightness"); const { value: brightness } = gId("brightness");
const { value: inputWidth } = element("width"); const { value: inputWidth } = gId("width");
const { value: inputHeight } = element("height"); const { value: inputHeight } = gId("height");
const { checked: resizeImage } = element("resizeImage"); const { checked: resizeImage } = gId("resizeImage");
const resizeWidth = parseInt(inputWidth); const resizeWidth = parseInt(inputWidth);
const resizeHeight = parseInt(inputHeight); const resizeHeight = parseInt(inputHeight);
const { width: dataWidth, height: dataHeight } = const { width: dataWidth, height: dataHeight } =
element("segments").selectedOptions[0].dataset; gId("segments").selectedOptions[0].dataset;
const segmentWidth = parseInt(dataWidth); const segmentWidth = parseInt(dataWidth);
const segmentHeight = parseInt(dataHeight); const segmentHeight = parseInt(dataHeight);
@ -1635,8 +1657,8 @@
} }
function pixelColor(r, g, b, a) { function pixelColor(r, g, b, a) {
const { checked } = element("transparentImage"); const { checked } = gId("transparentImage");
const { value } = element("color"); const { value } = gId("color");
if (a === 0) { if (a === 0) {
if (checked) { if (checked) {
@ -1732,10 +1754,10 @@
} }
function yaml(jsonData) { function yaml(jsonData) {
const { value: device } = element("device"); const { value: device } = gId("device");
const { value: friendly_name } = element("friendlyName"); const { value: friendly_name } = gId("friendlyName");
const { value: unique_id } = element("uniqueId"); const { value: unique_id } = gId("uniqueId");
const { value: hostname } = element("hostname"); const { value: hostname } = gId("hostname");
if (device) { if (device) {
const yamlData = { const yamlData = {
@ -1754,7 +1776,7 @@
} }
function curl(jsonData) { function curl(jsonData) {
const { value: hostname } = element("hostname"); const { value: hostname } = gId("hostname");
return `curl -X POST "http://${hostname}/json/state" -d '${jsonData}' -H "Content-Type: application/json"`; return `curl -X POST "http://${hostname}/json/state" -d '${jsonData}' -H "Content-Type: application/json"`;
} }
@ -1792,7 +1814,7 @@
duration = 2000, duration = 2000,
hideElement = "preview" hideElement = "preview"
) { ) {
const hide = element(hideElement); const hide = gId(hideElement);
const toast = d.createElement("div"); const toast = d.createElement("div");
const wait = 100; const wait = 100;
@ -1818,7 +1840,7 @@
toast.appendChild(progress); toast.appendChild(progress);
element("toast-container").appendChild(toast); gId("toast-container").appendChild(toast);
setTimeout(() => { setTimeout(() => {
toast.style.opacity = 0; toast.style.opacity = 0;
@ -1846,7 +1868,7 @@
} }
}); });
const container = element(id); const container = gId(id);
container.innerHTML = ""; container.innerHTML = "";
container.appendChild(carousel); container.appendChild(carousel);
@ -1894,7 +1916,7 @@
} }
function show() { function show() {
const overlay = element("overlay"); const overlay = gId("overlay");
overlay.classList.add("loading"); overlay.classList.add("loading");
overlay.style.display = "block"; overlay.style.display = "block";
overlay.style.cursor = "not-allowed"; overlay.style.cursor = "not-allowed";
@ -1903,7 +1925,7 @@
} }
function hide() { function hide() {
const overlay = element("overlay"); const overlay = gId("overlay");
overlay.classList.remove("loading"); overlay.classList.remove("loading");
overlay.style.display = "none"; overlay.style.display = "none";
overlay.style.cursor = "default"; overlay.style.cursor = "default";
@ -1914,7 +1936,7 @@
function validate(event) { function validate(event) {
event.preventDefault(); event.preventDefault();
const form = element("formGenerate"); const form = gId("formGenerate");
const inputs = form.querySelectorAll("input, select, textarea"); const inputs = form.querySelectorAll("input, select, textarea");
let isValid = true; let isValid = true;

File diff suppressed because it is too large Load Diff