Depth stacking within layers
This commit is contained in:
52
js/grid.js
52
js/grid.js
@@ -1,65 +1,47 @@
|
||||
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, privateMap, value) {
|
||||
if (!privateMap.has(receiver)) {
|
||||
throw new TypeError("attempted to set private field on non-instance");
|
||||
}
|
||||
privateMap.set(receiver, value);
|
||||
return value;
|
||||
};
|
||||
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, privateMap) {
|
||||
if (!privateMap.has(receiver)) {
|
||||
throw new TypeError("attempted to get private field on non-instance");
|
||||
}
|
||||
return privateMap.get(receiver);
|
||||
};
|
||||
var _prnt, _tileset, _layers;
|
||||
import { Layer } from './layer.js';
|
||||
export class Grid {
|
||||
constructor(prnt) {
|
||||
_prnt.set(this, void 0);
|
||||
_tileset.set(this, void 0);
|
||||
_layers.set(this, new Map());
|
||||
__classPrivateFieldSet(this, _prnt, prnt);
|
||||
__classPrivateFieldGet(this, _prnt).style.display = 'grid';
|
||||
this.layers = new Map();
|
||||
this.prnt = prnt;
|
||||
this.prnt.style.display = 'grid';
|
||||
}
|
||||
set_size(x, y) {
|
||||
__classPrivateFieldGet(this, _prnt).style.gridTemplateColumns = `repeat(${x}, 1fr)`;
|
||||
__classPrivateFieldGet(this, _prnt).style.gridTemplateRows = `repeat(${y}, 1fr)`;
|
||||
this.height = y;
|
||||
this.prnt.style.gridTemplateColumns = `repeat(${x}, 1fr)`;
|
||||
this.prnt.style.gridTemplateRows = `repeat(${y}, 1fr)`;
|
||||
}
|
||||
set_tileset(set) {
|
||||
__classPrivateFieldSet(this, _tileset, set);
|
||||
__classPrivateFieldGet(this, _prnt).style.backgroundImage = `url("images/${__classPrivateFieldGet(this, _tileset)}/land.svg")`;
|
||||
this.tileset = set;
|
||||
this.prnt.style.backgroundImage = `url("images/${this.tileset}/land.svg")`;
|
||||
// TODO: Notify layers
|
||||
}
|
||||
set_layers(layers) {
|
||||
const newNames = new Set(layers);
|
||||
for (const name of newNames) {
|
||||
if (!__classPrivateFieldGet(this, _layers).has(name)) {
|
||||
if (!this.layers.has(name)) {
|
||||
const layer = new Layer();
|
||||
layer.set_tileset(__classPrivateFieldGet(this, _tileset));
|
||||
__classPrivateFieldGet(this, _layers).set(name, layer);
|
||||
layer.set_tileset(this.tileset);
|
||||
this.layers.set(name, layer);
|
||||
}
|
||||
}
|
||||
for (const name of __classPrivateFieldGet(this, _layers).keys()) {
|
||||
for (const name of this.layers.keys()) {
|
||||
if (!newNames.has(name)) {
|
||||
// TODO: Notify layer to tear down
|
||||
__classPrivateFieldGet(this, _layers).delete(name);
|
||||
this.layers.delete(name);
|
||||
}
|
||||
}
|
||||
for (let i = 0; i < layers.length; i++) {
|
||||
const name = layers[i];
|
||||
const level = i + 1;
|
||||
const layer = __classPrivateFieldGet(this, _layers).get(name);
|
||||
layer.set_level(level);
|
||||
const layer = this.layers.get(layers[i]);
|
||||
layer.set_level(i * this.height);
|
||||
}
|
||||
}
|
||||
add_tile(tile_factory, x, y) {
|
||||
const tile = __classPrivateFieldGet(this, _layers).get(tile_factory.layer_name).add_tile(tile_factory);
|
||||
const tile = this.layers.get(tile_factory.layer_name).add_tile(tile_factory, y);
|
||||
// Grids are 1-indexed
|
||||
tile.elem.style.gridColumnStart = `${x + 1}`;
|
||||
tile.elem.style.gridRowStart = `${y + 1}`;
|
||||
__classPrivateFieldGet(this, _prnt).appendChild(tile.elem);
|
||||
this.prnt.appendChild(tile.elem);
|
||||
return tile;
|
||||
}
|
||||
}
|
||||
_prnt = new WeakMap(), _tileset = new WeakMap(), _layers = new WeakMap();
|
||||
//# sourceMappingURL=grid.js.map
|
||||
Reference in New Issue
Block a user