inventory-window
Version:
a GUI window for interactively manipulating an inventory of itempiles
77 lines (61 loc) • 3.27 kB
JavaScript
;
const InventoryWindow = require('./');
const Inventory = require('inventory');
const ItemPile = require('itempile');
const ever = require('ever');
const inv = new Inventory(5, 5);
inv.give(new ItemPile('diamond', 1));
inv.give(new ItemPile('emerald', 64));
inv.give(new ItemPile('emerald', 32));
inv.give(new ItemPile('emerald', 32));
for (let i = 0; i < 10; ++i) {
inv.give(new ItemPile('stick', 64));
}
inv.array[15] = new ItemPile('grass', 3); // block
inv.array[17] = new ItemPile('pick', 2, {damage:20});
inv.array[18] = new ItemPile('stick', 0);
inv.array[19] = new ItemPile('pick', 1, {damage:50});
inv.array[20] = new ItemPile('stick', 2);
inv.array[21] = new ItemPile('stick', 16);
inv.array[22] = new ItemPile('stick', 32);
inv.array[24] = new ItemPile('diamond', Infinity);
console.log(inv+'');
console.log(inv.size());
// a few simple images for testing
const images = {
diamond: '',
emerald: '',
stick: '',
pick: '',
grass_top: '',
grass_side: ''
};
const item_images = {
diamond: images.diamond,
emerald: images.emerald,
stick: images.stick,
pick: images.pick,
grass: {top:images.grass_top, front:images.grass_side, left:images.grass_side}
//grass: [images.grass_top, null, images.grass_side, images.grass_side] # arrays work too
};
const ucfirst = (s) => s.substr(0, 1).toUpperCase() + s.substring(1);
InventoryWindow.defaultGetTexture = (pile) => item_images[pile.item];
InventoryWindow.defaultGetMaxDamage = (pile) => 80;
InventoryWindow.defaultGetTooltip = (pile) => ucfirst(pile.item);
const w = new InventoryWindow({
inventory: inv
});
const container = w.createContainer();
console.log(container);
document.body.appendChild(container);
ever(document.body).on('contextmenu', (ev) => ev.preventDefault());
w.setSelected(7);
window.w = w;
const w2 = new InventoryWindow({
inventory: inv,
allowDrop: false});
document.body.appendChild(w2.createContainer());
const inv3 = new Inventory(4, 4);
const w3 = new InventoryWindow({inventory: inv3, linkedInventory:inv});
w.linkedInventory = inv3; // go both ways
document.body.appendChild(w3.createContainer());