Browse Source

Trying to build out application interface and integrate listener interactions.

dev-tmpl
Bryan Miller 6 years ago
parent
commit
4bd8ea3e11
4 changed files with 69 additions and 17 deletions
  1. +6
    -8
      app/js/main.js
  2. +47
    -0
      app/js/ui/Emitters.js
  3. +4
    -4
      app/js/ui/Modal.js
  4. +12
    -5
      index.html

+ 6
- 8
app/js/main.js View File

import EventWindow from "/app/js/ui/EventWindow.js";
import GlobalEvents from "/app/js/EventCaller.js";
//import EventWindow from "/app/js/ui/EventWindow.js";
import EmitterElements from "/app/js/ui/Emitters.js";
import Modal from "/app/js/ui/Modal.js"; import Modal from "/app/js/ui/Modal.js";
import {NESPainter} from "/app/js/NESPainter.js"; import {NESPainter} from "/app/js/NESPainter.js";
import {NESPalette} from "/app/js/NESPalette.js"; import {NESPalette} from "/app/js/NESPalette.js";
} }
} }


function on_click(e){
console.log(e.target);
}

function handle_emitted(){ function handle_emitted(){
console.log("EMITTED EVENT!"); console.log("EMITTED EVENT!");
} }


function initialize(DOC){ function initialize(DOC){
EventWindow.listen("onclick", on_click);
EventWindow.enable_emitter_attributes();
EventWindow.listen("emitted-event", handle_emitted);
EmitterElements.initialize();
//EventWindow.enable_emitter_attributes();
GlobalEvents.listen("emitted-event", handle_emitted);


var nespainter = new NESPainter(DOC.getElementById("painter")); var nespainter = new NESPainter(DOC.getElementById("painter"));



+ 47
- 0
app/js/ui/Emitters.js View File

import GlobalEvents from "/app/js/EventCaller.js";


function handle_emitter(event){
var el = event.target;
if (el){
if (el.hasAttribute("emit")){
var args = [el.getAttribute("emit")];
if (el.hasAttribute("emit-args")){
try {
var j = JSON.parse(el.getAttribute("emit-args"));
if (j instanceof Array){
args.concat(j);
} else {
args.push(j);
}
} catch (e) {
console.log("Failed to emit '" + args[0] + "'. Attribute 'emit-args' contains malformed JSON.");
}
}
GlobalEvents.emit.apply(GlobalEvents, args);
}
}
}



export default {
initialize: function(){
var elist = document.querySelectorAll("[emit]");
elist.forEach(function(el){
el.addEventListener("click", handle_emitter);
});
},

initialize_element: function(el){
if (el.hasAttribute("emit")){
el.addEventListener("click", handle_emitter);
}
}
}







+ 4
- 4
app/js/ui/Modal.js View File

import EventWindow from "/app/js/ui/EventWindow.js";
import GlobalEvents from "/app/js/EventCaller.js";




class Modal{ class Modal{
constructor(){ constructor(){
this.__currentModalEl = null; this.__currentModalEl = null;


EventWindow.listen("onclick", (function(event){
window.addEventListener("click", (function(event){
if (event.target === this.__currentModalEl){ if (event.target === this.__currentModalEl){
this.close_modal(); this.close_modal();
} }
}).bind(this)); }).bind(this));


EventWindow.listen("modal-open", (function(event){
GlobalEvents.listen("modal-open", (function(event){
if (event.hasOwnProperty("id") && typeof(event.id) === 'string'){ if (event.hasOwnProperty("id") && typeof(event.id) === 'string'){
var force = (event.hasOwnProperty("force")) ? event.force === true : false; var force = (event.hasOwnProperty("force")) ? event.force === true : false;
this.open_modal_id(event.id, force); this.open_modal_id(event.id, force);
} }
}).bind(this)); }).bind(this));


EventWindow.listen("modal-close", (function(event){
GlobalEvents.listen("modal-close", (function(event){
this.close_modal(); this.close_modal();
}).bind(this)); }).bind(this));
} }

+ 12
- 5
index.html View File

<div class="home-menu pure-menu pure-menu-horizontal"> <div class="home-menu pure-menu pure-menu-horizontal">
<a class="pure-menu-heading" href="">Your Site</a> <a class="pure-menu-heading" href="">Your Site</a>
<ul class="pure-menu-list"> <ul class="pure-menu-list">
<li class="pure-menu-item pure-menu-selected"><a href="#" emit="modal-open" emit-args='{"id":"Welcome"}' class="pure-menu-link">Home</a></li>
<li class="pure-menu-item"><a href="#" class="pure-menu-link">Tour</a></li>
<li class="pure-menu-item"><a href="#" class="pure-menu-link">Sign Up</a></li>
<li class="pure-menu-item pure-menu-selected">
<button emit="modal-open" emit-args='{"id":"Welcome"}' class="pure-button">
<i class="fa fa-brush"></i>
</button>
</li>
<li class="pure-menu-item">
<button emit="modal-open" emit-args='{"id":"Welcome"}' class="pure-button">
<i class="fa fa-eraser"></i>
</button>
</li>
</ul> </ul>
</div> </div>
</div> </div>


<div class="content-wrapper"> <div class="content-wrapper">
<div class="pure-g"> <div class="pure-g">
<div class="pure-u-1-6"></div>
<div class="pure-u-2-3">
<div class="pure-u-1-8"></div>
<div class="pure-u-3-4">
<canvas id="painter" width:"128" height:"256"></canvas> <canvas id="painter" width:"128" height:"256"></canvas>
</div> </div>
</div> </div>

Loading…
Cancel
Save