#include "status_ui.hpp" #include "components.hpp" #include "inventory.hpp" #include "color.hpp" #include "guecs.hpp" #include "rand.hpp" #include namespace gui { using namespace guecs; using std::any, std::any_cast, std::string, std::make_any; StatusUI::StatusUI(GameLevel level) : $level(level), $ritual_ui(level) { $gui.position(STATUS_UI_X, STATUS_UI_Y, STATUS_UI_WIDTH, STATUS_UI_HEIGHT); $gui.layout( "[ ritual_ui ]" "[inv_slot1 | inv_slot2 | inv_slot3]" "[inv_slot4 | inv_slot5 | inv_slot6]" "[*%(100,300)log_view]" "[_]" "[_]"); size_t inv_id = 0; for(auto [name, entity] : $gui.$name_ents) { if(name.starts_with("inv_")) { $slots[name] = inv_id++; } } } void StatusUI::init() { $gui.world().set_the({$gui.$parser}); for(auto& [name, cell] : $gui.cells()) { if(name == "log_view") { $log_to = $gui.entity("log_view"); $gui.set($log_to, {}); $gui.set($log_to, {L"Welcome to the Game!", 20}); } else { auto button = $gui.entity(name); $gui.set(button, {}); $gui.set(button, {L""}); $gui.set(button, {make_any(name)}); if(name == "ritual_ui") { $gui.set(button, { [this](auto, auto){ select_ritual(); } }); } else { $gui.set(button, { [this](auto ent, auto data){ select_slot(ent, data); } }); } } } $ritual_ui.init(); $gui.init(); } bool StatusUI::mouse(float x, float y) { if($ritual_ui.is_open()) { return $ritual_ui.mouse(x, y); } else { return $gui.mouse(x, y); } } void StatusUI::select_ritual() { $ritual_ui.toggle(); } void StatusUI::select_slot(DinkyECS::Entity ent, any slot_name) { dbc::check(slot_name.has_value(), "passed select_slot an any without a value"); auto cn = $gui.get(ent); auto world = $level.world; if(world->has($level.player)) { auto& inventory = world->get($level.player); size_t inv_id = $slots[any_cast(slot_name)]; if(inventory.has_item(inv_id)) { auto [used, name] = inventory.use($level, inv_id); if(used) { // log(fmt::format(L"Used item: {}", name)); log(fmt::format(L"Used item: {}", L"FIX ME ZED")); } else { // log(fmt::format(L"You are out of {}.", name)); log(fmt::format(L"Used item: {}", L"FIX ME ZED")); } } } } /* WARNING: This is really not the greatest way to do this. */ void StatusUI::update() { if($gui.has($log_to)) { auto& text = $gui.get($log_to); //BUG: I'm calling this what it is, fix it wstring log_garbage; for(auto msg : $messages) { log_garbage += msg + L"\n"; } text.update(log_garbage); } auto world = $level.world; if(world->has($level.player)) { auto& inventory = world->get($level.player); for(auto& [slot_name, inv_id] : $slots) { if(inventory.has_item(inv_id)) { auto slot = $gui.entity(slot_name); auto& item = inventory.get(inv_id); auto comp_sprite = components::get(item.data); $gui.set_init(slot, {comp_sprite.name}); string count_label = fmt::format("{}", item.count); auto& label = $gui.get(slot); label.text->setString(count_label); auto& sprite = $gui.get(slot); if(item.count == 0) { sprite.sprite->setColor({125, 125, 125}); } else { sprite.sprite->setColor({255, 255, 255}); } } } } } void StatusUI::render(sf::RenderWindow &window) { $gui.render(window); $ritual_ui.render(window); } void StatusUI::log(wstring msg) { $messages.push_front(msg); if($messages.size() > MAX_LOG_MESSAGES) { $messages.pop_back(); } update(); } void StatusUI::update_level(GameLevel &level) { $level = level; init(); } }