Fix ability to send trade requests to every entity

This commit is contained in:
coffee-compiler 2024-08-14 09:53:58 +00:00 committed by crabman
parent 5ec99290f2
commit ea533afc01
2 changed files with 25 additions and 4 deletions

View File

@ -64,6 +64,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Text overflow and flickering in the crafting menu. - Text overflow and flickering in the crafting menu.
- Crash when deleting entries from the server list. - Crash when deleting entries from the server list.
- Active buttons in repair equipment interface when missing requirements. - Active buttons in repair equipment interface when missing requirements.
- Ability to send trade requests to every entity.
## [0.16.0] - 2024-03-30 ## [0.16.0] - 2024-03-30

View File

@ -19,8 +19,8 @@ use common::{
inventory::slot::{EquipSlot, Slot}, inventory::slot::{EquipSlot, Slot},
invite::InviteKind, invite::InviteKind,
item::{tool::ToolKind, ItemDesc}, item::{tool::ToolKind, ItemDesc},
CharacterActivity, ChatType, Content, Fluid, InputKind, InventoryUpdateEvent, Pos, Alignment, CharacterActivity, ChatType, Content, Fluid, InputKind, InventoryUpdateEvent,
PresenceKind, Stats, UtteranceKind, Vel, Pos, PresenceKind, Stats, UtteranceKind, Vel,
}, },
consts::MAX_MOUNT_RANGE, consts::MAX_MOUNT_RANGE,
event::UpdateCharacterMetadata, event::UpdateCharacterMetadata,
@ -1133,8 +1133,26 @@ impl PlayState for SessionState {
match interactable { match interactable {
Interactable::Block(_, _, _) => {}, Interactable::Block(_, _, _) => {},
Interactable::Entity(entity) => { Interactable::Entity(entity) => {
if let Some(uid) = let can_trade_to = client
client.state().ecs().uid_from_entity(*entity) .state()
.read_component_cloned::<Alignment>(*entity)
.is_some_and(|a| match a {
Alignment::Npc => true,
Alignment::Owned(owner)
if client.uid().is_some_and(
|uid| owner == uid,
) =>
{
true
},
_ => false,
});
if can_trade_to
&& let Some(uid) = client
.state()
.ecs()
.uid_from_entity(*entity)
{ {
let name = client let name = client
.player_list() .player_list()
@ -1149,12 +1167,14 @@ impl PlayState for SessionState {
|e| e.name.to_owned(), |e| e.name.to_owned(),
) )
}); });
self.hud.new_message(ChatType::Meta.into_msg( self.hud.new_message(ChatType::Meta.into_msg(
Content::localized_with_args( Content::localized_with_args(
"hud-trade-invite_sent", "hud-trade-invite_sent",
[("playername", name)], [("playername", name)],
), ),
)); ));
client.send_invite(uid, InviteKind::Trade) client.send_invite(uid, InviteKind::Trade)
}; };
}, },