Files
librePECS/pecslib.js

47 lines
1.2 KiB
JavaScript
Raw Normal View History

2025-06-30 16:01:25 -06:00
class pec {
// this is the object for the pecs themselves, this will be used both
// to populate the library, and to occupy pecSlot objects
constructor (word,image) {
var me = this;
this.word = "string" == typeof word ? word : "Empty";
this.image = image; // Add image processing here
var root = document.createElement("div");
root.draggable = true;
2025-06-30 16:01:25 -06:00
root.classList.add("pec");
var img = document.createElement("img");
img.src = me.image;
img.classList.add("pecImage");
root.appendChild(img);
var name = document.createElement("span");
name.innerText = word;
2025-06-30 16:01:25 -06:00
name.classList.add("pecNane");
root.appendChild(name);
root.mom = this;
root.addEventListener("click",(e)=>{
var targ = e.currentTarget.mom;
window.speechSynthesis.speak(targ.utterance);
});
this.DOM = root;
2025-06-30 16:01:25 -06:00
}
}
class pecSlot {
// Do I actually need this?
}
class pecBoard {
constructor (pecs=[]) {
var initPecs = [
null,null,null,null,
null,null,null,null,
null,null,null,null,
null,null,null,null];
pecs.map((p,i)=>{ if (p instanceof pec) { initPecs[i] = p; } });
this.pecs = initPecs;
}
}
class pecBook {
// I don't know if I need this one ether.
}