Need to not transition out of END if the slot clicked is empty. Closes #45

master
Zed A. Shaw 4 months ago
parent 19682fd0bc
commit b0204772c7
  1. 27
      gui/dnd_loot.cpp
  2. 4
      gui/dnd_loot.hpp

@ -111,7 +111,6 @@ namespace gui {
END(CLOSE); END(CLOSE);
} break; } break;
case INV_SELECT: case INV_SELECT:
// BUG: should I do a bool here and not transition?
commit_move($status_ui.$gui, $grab_source, data); commit_move($status_ui.$gui, $grab_source, data);
END(CLOSE); END(CLOSE);
break; break;
@ -146,12 +145,14 @@ namespace gui {
switch(ev) { switch(ev) {
case LOOT_ITEM: case LOOT_ITEM:
hold_world_item(); if(hold_world_item()) {
state(DNDState::ITEM_PICKUP); state(DNDState::ITEM_PICKUP);
}
break; break;
case INV_SELECT: case INV_SELECT:
hold_inv_item(data); if(hold_inv_item(data)) {
state(DNDState::INV_PICKUP); state(DNDState::INV_PICKUP);
}
break; break;
case LOOT_OPEN: case LOOT_OPEN:
open(); open();
@ -186,17 +187,16 @@ namespace gui {
} }
void DNDLoot::clear_grab() { void DNDLoot::clear_grab() {
dbc::log("CLEARED!");
$grab_source = std::nullopt; $grab_source = std::nullopt;
$grab_sprite = nullptr; $grab_sprite = nullptr;
} }
void DNDLoot::open() { void DNDLoot::open() {
clear_grab();
$loot_ui.active = true; $loot_ui.active = true;
} }
void DNDLoot::close() { void DNDLoot::close() {
clear_grab();
$loot_ui.active = false; $loot_ui.active = false;
} }
@ -243,20 +243,25 @@ namespace gui {
} }
void DNDLoot::commit_move(guecs::UI& gui, std::optional<guecs::Entity> source_id, std::any data) { void DNDLoot::commit_move(guecs::UI& gui, std::optional<guecs::Entity> source_id, std::any data) {
dbc::check(source_id != std::nullopt, "source_id must exist");
auto& grab = gui.get<guecs::GrabSource>(*source_id); auto& grab = gui.get<guecs::GrabSource>(*source_id);
grab.commit(); grab.commit();
auto drop_id = std::any_cast<guecs::Entity>(data); auto drop_id = std::any_cast<guecs::Entity>(data);
auto& drop = gui.get<guecs::DropTarget>(drop_id); auto& drop = gui.get<guecs::DropTarget>(drop_id);
drop.commit(grab.world_entity);
if(drop.commit(grab.world_entity)) {
clear_grab(); clear_grab();
} else {
dbc::log("commit drop didn't happen");
}
// BUG: if the drop fails then need to put the grab back? // BUG: if the drop fails then need to put the grab back?
// How to confirm the drop will work before doing it? // How to confirm the drop will work before doing it?
// Or, maybe save the commit? // Or, maybe save the commit?
} }
void DNDLoot::hold_world_item() { bool DNDLoot::hold_world_item() {
// NOTE: if > 1 items, go to LOOT_OPEN instead // NOTE: if > 1 items, go to LOOT_OPEN instead
auto gui_id = $loot_ui.$gui.entity("item_0"); auto gui_id = $loot_ui.$gui.entity("item_0");
$grab_source = start_grab($loot_ui.$gui, gui_id); $grab_source = start_grab($loot_ui.$gui, gui_id);
@ -267,17 +272,19 @@ namespace gui {
// call this once to properly position the sprite // call this once to properly position the sprite
handle_mouse(Event::MOUSE_MOVE, $loot_ui.$gui); handle_mouse(Event::MOUSE_MOVE, $loot_ui.$gui);
} }
return $grab_source != std::nullopt;
} }
void DNDLoot::hold_inv_item(std::any& data) { bool DNDLoot::hold_inv_item(std::any& data) {
$grab_source = start_grab($status_ui.$gui, data); $grab_source = start_grab($status_ui.$gui, data);
if($grab_source) { if($grab_source) {
auto& source = $status_ui.$gui.get<guecs::GrabSource>(*$grab_source); auto& source = $status_ui.$gui.get<guecs::GrabSource>(*$grab_source);
$grab_sprite = source.sprite; $grab_sprite = source.sprite;
} else {
dbc::log("inv slot empty");
} }
return $grab_source != std::nullopt;
} }
/* /*

@ -52,8 +52,8 @@ namespace gui {
void commit_move(guecs::UI& gui, void commit_move(guecs::UI& gui,
std::optional<guecs::Entity> source_id, std::any data); std::optional<guecs::Entity> source_id, std::any data);
void hold_world_item(); bool hold_world_item();
void hold_inv_item(std::any& data); bool hold_inv_item(std::any& data);
bool throw_on_floor(); bool throw_on_floor();
void clear_grab(); void clear_grab();