|
- import GlobalEvents from "/app/js/EventCaller.js";
- import {NESPalette} from "/app/js/NESPalette.js";
-
- const ATTRIB_NESIDX = "nesidx";
- // The two attributes below MUST BOTH be in the element.
- const ATTRIB_PALIDX = "palidx"; // This is the palette index (0 - 3 (Tiles) 4 - 7 (Sprites))
- const ATTRIB_COLIDX = "palcolidx"; // This is the color index in the selected palette (0 - 3)
-
-
-
- var Active_Palette_Index = 0;
- var Active_Color_Index = 0;
-
-
-
- class CTRLPalettes{
- constructor(){
- this.__NESPalette = null;
- this.__pi = 0; // Palette index.
- this.__ci = 0; // Palette color index.
-
- var self = this;
-
- var handle_syspalette_clicked = function(event){
- if (this.hasAttribute(ATTRIB_NESIDX)){
- var idx = parseInt(this.getAttribute(ATTRIB_NESIDX), 16);
- if (idx >= 0 && idx < NESPalette.SystemColors.length){
- console.log(idx);
- // TODO: Set a selected Tile/Sprite palette index to the color index clicked.
- }
- }
- };
- var elist = document.querySelectorAll("[" + ATTRIB_NESIDX + "]");
- elist.forEach(function(el){
- var idx = parseInt(el.getAttribute(ATTRIB_NESIDX), 16);
- if (idx >= 0 && idx < NESPalette.SystemColor.length){
- el.style["background-color"] = NESPalette.SystemColor[idx];
- el.addEventListener("click", handle_syspalette_clicked);
- }
- });
-
-
- var handle_palcolor_clicked = function(event){
- if (this.hasAttribute(ATTRIB_PALIDX) && this.hasAttribute(ATTRIB_COLIDX)){
- self.__pi = this.getAttribute(ATTRIB_PALIDX);
- self.__ci = this.getAttribute(ATTRIB_COLIDX);
- console.log("Requesting Palette: " + self.__pi + " | Color: " + self.__ci);
- }
- };
- var elist = document.querySelectorAll("[" + ATTRIB_PALIDX + "]");
- elist.forEach(function(el){
- if (el.hasAttribute(ATTRIB_PALIDX) && el.hasAttribute(ATTRIB_COLIDX)){
- el.addEventListener("click", handle_palcolor_clicked);
- }
- });
- }
-
- get palette(){
- return this.__NESPalette;
- }
-
- set palette(p){
- if (!(p instanceof NESPalette)){
- throw new TypeError("Expected NESPalette object instance.");
- }
- this.__NESPalette = p;
- }
- }
-
-
- const instance = new CTRLPalettes();
- export default instance;
-
-
|