2021-01-10 03:36:05 +00:00
|
|
|
import "./index.css";
|
|
|
|
|
2022-06-03 18:50:51 +00:00
|
|
|
import { PublicAPI } from "ruffle-core";
|
2019-09-05 02:11:01 +00:00
|
|
|
|
2022-06-03 18:50:51 +00:00
|
|
|
window.RufflePlayer = PublicAPI.negotiate(window.RufflePlayer, "local");
|
2021-03-26 15:17:00 +00:00
|
|
|
const ruffle = window.RufflePlayer.newest();
|
2019-04-25 17:52:22 +00:00
|
|
|
|
2020-03-29 09:23:17 +00:00
|
|
|
let player;
|
2019-04-25 17:52:22 +00:00
|
|
|
|
2021-02-20 01:40:43 +00:00
|
|
|
const main = document.getElementById("main");
|
2021-01-22 02:16:39 +00:00
|
|
|
const overlay = document.getElementById("overlay");
|
2021-01-10 03:36:05 +00:00
|
|
|
const authorContainer = document.getElementById("author-container");
|
|
|
|
const author = document.getElementById("author");
|
|
|
|
const sampleFileInputContainer = document.getElementById(
|
|
|
|
"sample-swfs-container"
|
|
|
|
);
|
|
|
|
const localFileInput = document.getElementById("local-file");
|
2021-03-26 15:17:00 +00:00
|
|
|
const sampleFileInput = document.getElementById("sample-swfs");
|
2022-05-06 14:04:16 +00:00
|
|
|
const localFileName = document.getElementById("local-file-name");
|
2022-08-16 19:44:53 +00:00
|
|
|
const closeModal = document.getElementById("close-modal");
|
|
|
|
const openModal = document.getElementById("open-modal");
|
|
|
|
const metadataModal = document.getElementById("metadata-modal");
|
2021-07-09 08:40:02 +00:00
|
|
|
// prettier-ignore
|
|
|
|
const optionGroups = {
|
|
|
|
"Animation": document.getElementById("anim-optgroup"),
|
|
|
|
"Game": document.getElementById("games-optgroup"),
|
|
|
|
};
|
2020-03-29 09:23:17 +00:00
|
|
|
|
2021-01-06 07:32:18 +00:00
|
|
|
// Default config used by the player.
|
2022-07-12 17:40:08 +00:00
|
|
|
const defaultConfig = {
|
2021-01-06 07:32:18 +00:00
|
|
|
letterbox: "on",
|
2021-01-20 02:10:35 +00:00
|
|
|
logLevel: "warn",
|
2021-01-06 07:32:18 +00:00
|
|
|
};
|
|
|
|
|
2022-07-27 21:02:17 +00:00
|
|
|
const swfToFlashVersion = {
|
2022-08-01 16:09:06 +00:00
|
|
|
1: "1",
|
|
|
|
2: "2",
|
|
|
|
3: "3",
|
|
|
|
4: "4",
|
|
|
|
5: "5",
|
|
|
|
6: "6",
|
|
|
|
7: "7",
|
|
|
|
8: "8",
|
|
|
|
9: "9.0",
|
|
|
|
10: "10.0/10.1",
|
|
|
|
11: "10.2",
|
|
|
|
12: "10.3",
|
|
|
|
13: "11.0",
|
|
|
|
14: "11.1",
|
|
|
|
15: "11.2",
|
|
|
|
16: "11.3",
|
|
|
|
17: "11.4",
|
|
|
|
18: "11.5",
|
|
|
|
19: "11.6",
|
|
|
|
20: "11.7",
|
|
|
|
21: "11.8",
|
|
|
|
22: "11.9",
|
|
|
|
23: "12",
|
|
|
|
24: "13",
|
|
|
|
25: "14",
|
|
|
|
26: "15",
|
|
|
|
27: "16",
|
|
|
|
28: "17",
|
|
|
|
29: "18",
|
|
|
|
30: "19",
|
|
|
|
31: "20",
|
|
|
|
32: "21",
|
|
|
|
33: "22",
|
|
|
|
34: "23",
|
|
|
|
35: "24",
|
|
|
|
36: "25",
|
|
|
|
37: "26",
|
|
|
|
38: "27",
|
|
|
|
39: "28",
|
|
|
|
40: "29",
|
|
|
|
41: "30",
|
|
|
|
42: "31",
|
|
|
|
43: "32",
|
|
|
|
};
|
2022-07-27 21:02:17 +00:00
|
|
|
|
2021-03-26 15:17:00 +00:00
|
|
|
function unload() {
|
2021-02-20 01:40:43 +00:00
|
|
|
if (player) {
|
|
|
|
player.remove();
|
2022-08-01 16:09:06 +00:00
|
|
|
document.querySelectorAll("span.metadata").forEach((el) => {
|
|
|
|
el.textContent = "Loading";
|
|
|
|
});
|
|
|
|
document.getElementById("backgroundColor").value = "#FFFFFF";
|
2021-02-20 01:40:43 +00:00
|
|
|
}
|
2021-03-26 15:17:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function load(options) {
|
|
|
|
unload();
|
2021-02-18 11:02:05 +00:00
|
|
|
player = ruffle.createPlayer();
|
|
|
|
player.id = "player";
|
2021-02-20 01:40:43 +00:00
|
|
|
main.append(player);
|
2021-03-26 15:17:00 +00:00
|
|
|
player.load(options);
|
2022-08-01 16:09:06 +00:00
|
|
|
player.addEventListener("loadedmetadata", function () {
|
2022-07-27 21:02:17 +00:00
|
|
|
if (this.metadata) {
|
2022-08-03 16:17:21 +00:00
|
|
|
for (const [key, value] of Object.entries(this.metadata)) {
|
|
|
|
const metadataElement = document.getElementById(key);
|
2022-08-01 16:09:06 +00:00
|
|
|
if (metadataElement) {
|
2022-08-03 17:47:55 +00:00
|
|
|
switch (key) {
|
|
|
|
case "backgroundColor":
|
|
|
|
metadataElement.value = value ?? "#FFFFFF";
|
|
|
|
break;
|
|
|
|
case "uncompressedLength":
|
|
|
|
metadataElement.textContent = `${value >> 10}Kb`;
|
|
|
|
break;
|
|
|
|
case "swfVersion":
|
2022-08-01 16:09:06 +00:00
|
|
|
document.getElementById(
|
|
|
|
"flashVersion"
|
2022-08-03 16:17:21 +00:00
|
|
|
).textContent = swfToFlashVersion[value];
|
2022-08-03 17:47:55 +00:00
|
|
|
// falls through and executes the default case as well
|
|
|
|
default:
|
2022-08-03 16:17:21 +00:00
|
|
|
metadataElement.textContent = value;
|
2022-08-03 17:47:55 +00:00
|
|
|
break;
|
2022-08-01 16:09:06 +00:00
|
|
|
}
|
|
|
|
}
|
2022-08-03 16:17:21 +00:00
|
|
|
}
|
2022-07-27 21:02:17 +00:00
|
|
|
}
|
|
|
|
});
|
2021-03-26 15:17:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function showSample(swfData) {
|
|
|
|
authorContainer.classList.remove("hidden");
|
|
|
|
author.textContent = swfData.author;
|
|
|
|
author.href = swfData.authorLink;
|
|
|
|
localFileInput.value = null;
|
|
|
|
}
|
2021-02-20 01:40:43 +00:00
|
|
|
|
2021-03-26 15:17:00 +00:00
|
|
|
function hideSample() {
|
2022-07-12 17:40:08 +00:00
|
|
|
sampleFileInput.selectedIndex = -1;
|
2021-03-26 15:17:00 +00:00
|
|
|
authorContainer.classList.add("hidden");
|
2021-02-20 01:40:43 +00:00
|
|
|
author.textContent = "";
|
|
|
|
author.href = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
async function loadFile(file) {
|
|
|
|
if (!file) {
|
|
|
|
return;
|
|
|
|
}
|
2022-05-06 14:04:16 +00:00
|
|
|
if (file.name) {
|
|
|
|
localFileName.textContent = file.name;
|
|
|
|
}
|
2021-03-26 15:17:00 +00:00
|
|
|
hideSample();
|
2021-07-09 08:40:02 +00:00
|
|
|
const data = await new Response(file).arrayBuffer();
|
2023-01-22 09:48:14 +00:00
|
|
|
load({ data: data, swfFileName: file.name, ...defaultConfig });
|
2021-02-20 01:40:43 +00:00
|
|
|
}
|
|
|
|
|
2021-02-21 20:52:04 +00:00
|
|
|
function loadSample() {
|
2021-02-20 01:40:43 +00:00
|
|
|
const swfData = sampleFileInput[sampleFileInput.selectedIndex].swfData;
|
2022-05-06 14:04:16 +00:00
|
|
|
localFileName.textContent = "No file selected.";
|
2021-02-20 01:40:43 +00:00
|
|
|
if (swfData) {
|
2021-03-26 15:17:00 +00:00
|
|
|
showSample(swfData);
|
2022-07-12 17:40:08 +00:00
|
|
|
const config = swfData.config || defaultConfig;
|
2021-03-26 15:17:00 +00:00
|
|
|
load({ url: swfData.location, ...config });
|
2021-02-20 01:40:43 +00:00
|
|
|
} else {
|
2021-03-26 15:17:00 +00:00
|
|
|
hideSample();
|
|
|
|
unload();
|
2021-02-20 01:40:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
localFileInput.addEventListener("change", (event) => {
|
|
|
|
loadFile(event.target.files[0]);
|
|
|
|
});
|
|
|
|
|
2021-02-21 20:52:04 +00:00
|
|
|
sampleFileInput.addEventListener("change", () => loadSample());
|
2021-02-20 01:40:43 +00:00
|
|
|
|
2021-03-26 15:17:00 +00:00
|
|
|
main.addEventListener("dragenter", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
2021-02-20 01:40:43 +00:00
|
|
|
});
|
2021-03-26 15:17:00 +00:00
|
|
|
main.addEventListener("dragleave", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
2021-02-20 01:40:43 +00:00
|
|
|
overlay.classList.remove("drag");
|
|
|
|
});
|
|
|
|
main.addEventListener("dragover", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
2021-03-26 15:17:00 +00:00
|
|
|
overlay.classList.add("drag");
|
2021-02-20 01:40:43 +00:00
|
|
|
});
|
|
|
|
main.addEventListener("drop", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
|
|
|
overlay.classList.remove("drag");
|
2021-09-14 13:39:15 +00:00
|
|
|
localFileInput.files = event.dataTransfer.files;
|
2021-02-20 01:40:43 +00:00
|
|
|
loadFile(event.dataTransfer.files[0]);
|
|
|
|
});
|
2021-09-23 15:31:23 +00:00
|
|
|
localFileInput.addEventListener("dragleave", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
|
|
|
overlay.classList.remove("drag");
|
|
|
|
});
|
|
|
|
localFileInput.addEventListener("dragover", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
|
|
|
overlay.classList.add("drag");
|
|
|
|
});
|
|
|
|
localFileInput.addEventListener("drop", (event) => {
|
|
|
|
event.stopPropagation();
|
|
|
|
event.preventDefault();
|
|
|
|
overlay.classList.remove("drag");
|
|
|
|
localFileInput.files = event.dataTransfer.files;
|
|
|
|
loadFile(event.dataTransfer.files[0]);
|
|
|
|
});
|
2021-02-20 01:40:43 +00:00
|
|
|
|
2022-08-01 16:09:06 +00:00
|
|
|
closeModal.addEventListener("click", () => {
|
|
|
|
metadataModal.style.display = "none";
|
|
|
|
});
|
|
|
|
|
|
|
|
openModal.addEventListener("click", () => {
|
|
|
|
metadataModal.style.display = "block";
|
|
|
|
});
|
|
|
|
|
2021-02-20 01:40:43 +00:00
|
|
|
window.addEventListener("load", () => {
|
2021-08-08 13:54:11 +00:00
|
|
|
if (
|
|
|
|
navigator.userAgent.match(/iPad/i) ||
|
|
|
|
navigator.userAgent.match(/iPhone/i)
|
|
|
|
) {
|
|
|
|
localFileInput.removeAttribute("accept");
|
|
|
|
}
|
2021-03-26 15:17:00 +00:00
|
|
|
overlay.classList.remove("hidden");
|
2021-02-20 01:40:43 +00:00
|
|
|
});
|
|
|
|
|
2022-08-01 16:09:06 +00:00
|
|
|
window.onclick = (event) => {
|
|
|
|
if (event.target === metadataModal) {
|
|
|
|
metadataModal.style.display = "none";
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-03-26 15:17:00 +00:00
|
|
|
(async () => {
|
2021-01-10 03:36:05 +00:00
|
|
|
const response = await fetch("swfs.json");
|
2020-11-24 16:54:03 +00:00
|
|
|
|
2022-04-27 03:46:39 +00:00
|
|
|
if (response.ok) {
|
|
|
|
const data = await response.json();
|
|
|
|
for (const swfData of data.swfs) {
|
|
|
|
const option = document.createElement("option");
|
|
|
|
option.textContent = swfData.title;
|
|
|
|
option.value = swfData.location;
|
|
|
|
option.swfData = swfData;
|
2022-07-12 17:40:08 +00:00
|
|
|
if (swfData.type) {
|
|
|
|
optionGroups[swfData.type].append(option);
|
|
|
|
} else {
|
2022-07-12 20:21:32 +00:00
|
|
|
sampleFileInput.insertBefore(
|
|
|
|
option,
|
|
|
|
sampleFileInput.firstChild
|
|
|
|
);
|
2022-07-12 17:40:08 +00:00
|
|
|
}
|
2022-04-27 03:46:39 +00:00
|
|
|
}
|
|
|
|
sampleFileInputContainer.classList.remove("hidden");
|
2021-01-10 03:36:05 +00:00
|
|
|
}
|
2020-03-29 09:23:17 +00:00
|
|
|
|
2022-07-12 17:40:08 +00:00
|
|
|
sampleFileInput.selectedIndex = 0;
|
2021-02-21 20:52:04 +00:00
|
|
|
const initialFile = new URL(window.location).searchParams.get("file");
|
2021-01-10 03:36:05 +00:00
|
|
|
if (initialFile) {
|
|
|
|
const options = Array.from(sampleFileInput.options);
|
|
|
|
sampleFileInput.selectedIndex = Math.max(
|
|
|
|
options.findIndex((swfData) => swfData.value.endsWith(initialFile)),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
}
|
2022-07-12 17:40:08 +00:00
|
|
|
loadSample();
|
2021-03-26 15:17:00 +00:00
|
|
|
})();
|