mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Merge branch 'ubruntu/trade-entity-name' into 'master'
Replace "Player 1" with an NPC name when trading with an NPC See merge request veloren/veloren!2588
This commit is contained in:
commit
89d948c827
@ -17,7 +17,7 @@ use client::Client;
|
||||
use common::{
|
||||
comp::{
|
||||
inventory::item::{MaterialStatManifest, Quality},
|
||||
Inventory,
|
||||
Inventory, Stats,
|
||||
},
|
||||
trade::{PendingTrade, SitePrices, TradeAction, TradePhase},
|
||||
};
|
||||
@ -169,7 +169,7 @@ impl<'a> Trade<'a> {
|
||||
(x, is_ours) if ours == is_ours => x,
|
||||
_ => check_if_us(1)?.0,
|
||||
};
|
||||
// TODO: update in accordence with https://gitlab.com/veloren/veloren/-/issues/960
|
||||
// TODO: update in accordance with https://gitlab.com/veloren/veloren/-/issues/960
|
||||
let inventory = inventories.get(entity)?;
|
||||
|
||||
// Alignment for Grid
|
||||
@ -188,6 +188,13 @@ impl<'a> Trade<'a> {
|
||||
.player_list()
|
||||
.get(&uid)
|
||||
.map(|info| info.player_alias.clone())
|
||||
.or_else(|| {
|
||||
self.client
|
||||
.state()
|
||||
.read_storage::<Stats>()
|
||||
.get(entity)
|
||||
.map(|e| e.name.to_owned())
|
||||
})
|
||||
.unwrap_or_else(|| format!("Player {}", who));
|
||||
|
||||
let offer_header = self
|
||||
|
@ -15,7 +15,7 @@ use common::{
|
||||
inventory::slot::{EquipSlot, Slot},
|
||||
invite::InviteKind,
|
||||
item::{tool::ToolKind, ItemDef, ItemDesc},
|
||||
ChatMsg, ChatType, InputKind, InventoryUpdateEvent, Pos, UtteranceKind, Vel,
|
||||
ChatMsg, ChatType, InputKind, InventoryUpdateEvent, Pos, Stats, UtteranceKind, Vel,
|
||||
},
|
||||
consts::{MAX_MOUNT_RANGE, MAX_PICKUP_RANGE},
|
||||
outcome::Outcome,
|
||||
@ -164,7 +164,15 @@ impl SessionState {
|
||||
};
|
||||
let target_name = match client.player_list().get(&target) {
|
||||
Some(info) => info.player_alias.clone(),
|
||||
None => format!("<entity {}>", target),
|
||||
None => match client.state().ecs().entity_from_uid(target.0) {
|
||||
Some(entity) => {
|
||||
let stats = client.state().read_storage::<Stats>();
|
||||
stats
|
||||
.get(entity)
|
||||
.map_or(format!("<entity {}>", target), |e| e.name.to_owned())
|
||||
},
|
||||
None => format!("<uid {}>", target),
|
||||
},
|
||||
};
|
||||
let answer_str = match answer {
|
||||
InviteAnswer::Accepted => "accepted",
|
||||
@ -698,7 +706,13 @@ impl PlayState for SessionState {
|
||||
.get(&uid)
|
||||
.map(|info| info.player_alias.clone())
|
||||
.unwrap_or_else(|| {
|
||||
format!("<entity {:?}>", uid)
|
||||
let stats = client
|
||||
.state()
|
||||
.read_storage::<Stats>();
|
||||
stats.get(entity).map_or(
|
||||
format!("<entity {:?}>", uid),
|
||||
|e| e.name.to_owned(),
|
||||
)
|
||||
});
|
||||
let msg = global_state
|
||||
.i18n
|
||||
|
Loading…
Reference in New Issue
Block a user