80 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {Point, Rect, Size} from "./engine/datatypes.ts";
 | |
| import {DrawPile} from "./drawpile.ts";
 | |
| import {withCamera} from "./layout.ts";
 | |
| import {getSkillsModal} from "./skillsmodal.ts";
 | |
| import {addButton} from "./button.ts";
 | |
| import {getSleepModal} from "./sleepmodal.ts";
 | |
| 
 | |
| type Button = {
 | |
|   label: string,
 | |
|   cbClick: () => void,
 | |
| }
 | |
| 
 | |
| export class Hotbar {
 | |
|   #drawpile: DrawPile;
 | |
|   constructor() {
 | |
|     this.#drawpile = new DrawPile();
 | |
|   }
 | |
| 
 | |
|   get #cellSize(): Size {
 | |
|     return new Size(96, 32);
 | |
| }
 | |
| 
 | |
|   get size(): Size {
 | |
|     let {w: cellW, h: cellH} = this.#cellSize;
 | |
|     let w = this.#computeButtons().length * cellW;
 | |
|     return new Size(w, cellH)
 | |
|   }
 | |
| 
 | |
|   #computeButtons(): Button[] {
 | |
|     let buttons: Button[] = [];
 | |
|     buttons.push({
 | |
|       label: "Skills",
 | |
|       cbClick: () => {
 | |
|         getSkillsModal().setShown(true)
 | |
|       }
 | |
|     })
 | |
|     /*
 | |
|     buttons.push({
 | |
|       label: "Thralls"
 | |
|     })
 | |
|      */
 | |
|     buttons.push({
 | |
|       label: "Sleep",
 | |
|       cbClick: () => {
 | |
|         getSleepModal().setShown(true)
 | |
|       }
 | |
|     })
 | |
|     return buttons;
 | |
|   }
 | |
| 
 | |
|   update() {
 | |
|     withCamera("Hotbar", () => this.#update())
 | |
|   }
 | |
| 
 | |
|   #update() {
 | |
|     this.#drawpile.clear();
 | |
| 
 | |
|     let buttons = this.#computeButtons();
 | |
| 
 | |
|     let cellSize = this.#cellSize;
 | |
| 
 | |
|     let x = 0;
 | |
|     for (let b of buttons.values()) {
 | |
|       addButton(this.#drawpile, b.label, new Rect(new Point(x, 0), cellSize), true, b.cbClick);
 | |
|       x += cellSize.w;
 | |
|     }
 | |
|     this.#drawpile.executeOnClick();
 | |
| 
 | |
|   }
 | |
| 
 | |
|   draw() {
 | |
|     // D.fillRect(new Point(-4, -4), this.size.add(new Size(8, 8)), BG_INSET);
 | |
|     withCamera("Hotbar", () => this.#drawpile.draw());
 | |
|   }
 | |
| }
 | |
| 
 | |
| let active = new Hotbar();
 | |
| export function getHotbar(): Hotbar {
 | |
|   return active;
 | |
| } |