|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- import GlobalEvents from "/app/js/common/EventCaller.js";
- import NESBank from "/app/js/models/NESBank.js";
-
-
-
- var ELCtrl = null;
- var ELSel = null;
- var ELLab = null;
- var ELOff = null;
- var SURF = null;
-
-
- function OpenControls(){
- if (ELCtrl !== null && SURF !== null){
- switch(SURF.access_mode){
- case NESBank.ACCESSMODE_8K:
- ELSel.value = "8K";
- ELLab.classList.add("hidden");
- break;
- case NESBank.ACCESSMODE_4K:
- ELSel.value = "4K"; break;
- case NESBank.ACCESSMODE_2K:
- ELSel.value = "2K"; break;
- case NESBank.ACCESSMODE_1K:
- ELSel.value = "1K"; break;
- case NESBank.ACCESSMODE_1T:
- ElSel.value = "1T"; break;
- case NESBank.ACCESSMODE_2T:
- ElSel.value = "2T"; break;
- }
-
- if (ELSel.value !== "8K"){
- ELLab.classList.remove("hidden");
- ELOff.setAttribute("max", SURF.access_offset_length - 1);
- ELOff.value = SURF.access_offset;
- //ELOff.setAttribute("value", SURF.access_offset);
- }
- ELCtrl.classList.remove("hidden");
- }
- }
-
- function CloseControls(){
- if (ELCtrl !== null){
- ELCtrl.classList.add("hidden");
- }
- }
-
-
- function HANDLE_SurfChange(surf){
- if (surf instanceof NESBank){
- SURF = surf;
- OpenControls();
- } else {
- SURF = null;
- CloseControls();
- }
- }
-
-
- function HANDLE_RemoveDuplicates(){
- if (SURF !== null){
- SURF.removeDuplicates().compact();
- }
- }
-
-
- function HANDLE_ModeChange(){
- if (ELCtrl !== null && SURF !== null){
- var val = this.options[this.selectedIndex].value;
- switch(val){
- case "8K":
- SURF.access_mode = NESBank.ACCESSMODE_8K;
- ELLab.classList.add("hidden");
- break;
- case "4K":
- SURF.access_mode = NESBank.ACCESSMODE_4K; break;
- case "2K":
- SURF.access_mode = NESBank.ACCESSMODE_2K; break;
- case "1K":
- SURF.access_mode = NESBank.ACCESSMODE_1K; break;
- case "1T":
- SURF.access_mode = NESBank.ACCESSMODE_1T; break;
- case "2T":
- SURF.access_mode = NESBank.ACCESSMODE_2T; break;
- }
- if (SURF.access_mode !== NESBank.ACCESSMODE_8K){
- ELLab.classList.remove("hidden");
- //ELOff.setAttribute("value", SURF.access_offset);
- ELOff.setAttribute("max", SURF.access_offset_length - 1);
- ELOff.value = SURF.access_offset;
- }
- }
- }
-
-
- function HANDLE_OffsetChange(){
- if (ELCtrl !== null && SURF !== null){
- var val = parseInt(this.value);
- SURF.access_offset = val;
- }
- }
-
-
- class CTRLBankTools{
- constructor(){
- GlobalEvents.listen("change_surface", HANDLE_SurfChange);
- GlobalEvents.listen("bank_remove_duplicates", HANDLE_RemoveDuplicates);
- }
-
- close(){
- if (ELSel)
- ELSel.removeEventListener("change", HANDLE_ModeChange);
- if (ELOff)
- ELOff.removeEventListener("change", HANDLE_OffsetChange);
- if (ELCtrl)
- ELCtrl.classList.add("hidden");
- ELCTRL = null;
- ELSel = null;
- ELLab = null;
- ELOff = null;
- }
-
- initialize(){
- if (ELCtrl === null){
- ELCtrl = document.querySelector(".painter-bank-controls");
- if (!ELCtrl){
- console.log("ERROR: Failed to find 'painter-bank-controls' element");
- return;
- }
-
- ELSel = ELCtrl.querySelector(".painter-bank-mode");
- if (!ELSel){
- this.close();
- console.log("ERROR: Failed to find 'painter-bank-mode' element.");
- return;
- }
-
- ELLab = ELCtrl.querySelector(".painter-bank-offset");
- if (!ELLab){
- this.close();
- console.log("ERROR: Failed to find 'painter-bank-offset' element.");
- return;
- }
-
- ELOff = ELLab.querySelector("#offset-select");
- if (!ELOff){
- this.close();
- console.log("ERROR: Failed to find 'offset-select' element.");
- return;
- }
- ELSel.addEventListener("change", HANDLE_ModeChange);
- ELOff.addEventListener("change", HANDLE_OffsetChange);
- OpenControls();
- }
- }
- }
-
-
- const instance = new CTRLBankTools();
- export default instance;
-
-
-
-
|