import GlobalEvents from "/app/js/common/EventCaller.js"; import Utils from "/app/js/common/Utils.js"; import JSONSchema from "/app/js/common/JSONSchema.js"; import NESBank from "/app/js/models/NESBank.js"; import NESPalette from "/app/js/models/NESPalette.js"; import CTRLPalettesStore from "/app/js/ctrls/CTRLPalettesStore.js"; import CTRLBanksStore from "/app/js/ctrls/CTRLBanksStore.js"; const SUPPORTED_PROJECT_VERSIONS=[ "0.1" ]; JSONSchema.add({ "$schema": "http://json-schema.org/draft-07/schema#", "$id": "NESPainterProject.json", "type":"object", "properties":{ "id":{ "type":"string", "enum":["NESPProj"] }, "version":{ "type":"string", "pattern":"^[0-9]{1,}\.[0-9]{1,}$" }, "paletteStore":{"$ref":"PalettesStoreSchema.json"}, "bankStore":{"$ref":"BanksStoreSchema.json"} }, "required":["id","version","paletteStore","bankStore"] }); var SURF = null; function JSONFromProject(){ var proj = { id:"NESPProj", version:SUPPORTED_PROJECT_VERSIONS[SUPPORTED_PROJECT_VERSIONS.length - 1], paletteStore:CTRLPalettesStore.obj, bankStore:CTRLBanksStore.obj }; return JSON.stringify(proj); } function LoadFile(file){ if (SURF !== null){ var reader = new FileReader(); if (SURF instanceof NESBank){ reader.onload = function(e){ try { SURF.chr = new Uint8Array(e.target.result); } catch (e) { console.log(e.toString()); } } reader.readAsArrayBuffer(file); } } } function HANDLE_DragOver(e){ e.stopPropagation(); e.preventDefault(); e.dataTransfer.dropEffect = 'copy'; }; function HANDLE_FileDrop(e){ e.stopPropagation(); e.preventDefault(); var files = e.dataTransfer.files; for (let i=0; i < files.length; i++){ LoadFile(files[i]); } } function HANDLE_SaveProject(e){ var a = document.createElement("a"); var file = new Blob([JSONFromProject()], {type: "text/plain"}); a.href = window.URL.createObjectURL(file); a.download = "nesproject.json"; var body = document.querySelector("body"); body.appendChild(a); a.click(); setTimeout(function(){ // fixes firefox html removal bug window.URL.revokeObjectURL(url); a.remove(); }, 500); } function HANDLE_LoadProjectRequest(){ var input = document.querySelectorAll("input.project-loader"); if (input.length > 0){ input[0].click(); } } function HANDLE_LoadProject(e){ if (this.files && this.files.length > 0){ var reader = new FileReader(); reader.onload = (function(e) { var validator = null; try{ validator = JSONSchema.getValidator("NESPainterProject.json"); } catch (e) { console.log("Failed to validate project file. " + e.toString()); return; } if (validator(e.target.result)){ var o = JSON.parse(e.target.result); // TODO: Validate 'id' and 'version' properties. CTRLPalettesStore.obj = o.paletteStore; CTRLBanksStore.obj = o.banksStore; } if (this.parentNode.nodeName.toLowerCase() === "form"){ this.parentNode.reset(); } else { console.log("WARNING: Parent node is NOT a
element."); } }).bind(this); reader.readAsText(this.files[0]); } else { console.log("Project file not found or no file selected."); } } function HANDLE_SurfChange(surf){ if (surf instanceof NESBank){ SURF = surf; } else { SURF = null; } } class CTRLIO{ constructor(){ GlobalEvents.listen("change_surface", HANDLE_SurfChange); GlobalEvents.listen("save-project", HANDLE_SaveProject); GlobalEvents.listen("load-project", HANDLE_LoadProjectRequest); var input = document.querySelectorAll("input.project-loader"); if (input.length > 0){ input[0].addEventListener("change", HANDLE_LoadProject); } } initialize(){ var e = document.querySelectorAll(".drop-zone"); for (let i=0; i < e.length; e++){ e[i].addEventListener("dragover", HANDLE_DragOver); e[i].addEventListener("drop", HANDLE_FileDrop); } CTRLPalettesStore.initialize(); CTRLBanksStore.initialize(); } } const instance = new CTRLIO(); export default instance;