mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Merge branch 'shouvik/prevent_empty_trades' into 'master'
Fixes #1452 - Prevents empty trades Closes #1452 See merge request veloren/veloren!3202
This commit is contained in:
commit
b09698b8ac
@ -116,6 +116,8 @@ impl PendingTrade {
|
|||||||
.map(|(i, _)| i)
|
.map(|(i, _)| i)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn is_empty_trade(&self) -> bool { self.offers[0].is_empty() && self.offers[1].is_empty() }
|
||||||
|
|
||||||
/// Invariants:
|
/// Invariants:
|
||||||
/// - A party is never shown as offering more of an item than they own
|
/// - A party is never shown as offering more of an item than they own
|
||||||
/// - Offers with a quantity of zero get removed from the trade
|
/// - Offers with a quantity of zero get removed from the trade
|
||||||
@ -165,7 +167,7 @@ impl PendingTrade {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
Accept(phase) => {
|
Accept(phase) => {
|
||||||
if self.phase == phase {
|
if self.phase == phase && !self.is_empty_trade() {
|
||||||
self.accept_flags[who] = true;
|
self.accept_flags[who] = true;
|
||||||
}
|
}
|
||||||
if self.accept_flags[0] && self.accept_flags[1] {
|
if self.accept_flags[0] && self.accept_flags[1] {
|
||||||
|
@ -1239,7 +1239,7 @@ impl<'a> AgentData<'a> {
|
|||||||
// results in lagging and moving to the review phase of an unfavorable trade
|
// results in lagging and moving to the review phase of an unfavorable trade
|
||||||
// (although since the phase is included in the message, this shouldn't
|
// (although since the phase is included in the message, this shouldn't
|
||||||
// result in fully accepting an unfavourable trade))
|
// result in fully accepting an unfavourable trade))
|
||||||
if !pending.accept_flags[who] {
|
if !pending.accept_flags[who] && !pending.is_empty_trade() {
|
||||||
event_emitter.emit(ServerEvent::ProcessTradeAction(
|
event_emitter.emit(ServerEvent::ProcessTradeAction(
|
||||||
*self.entity,
|
*self.entity,
|
||||||
tradeid,
|
tradeid,
|
||||||
|
@ -473,10 +473,25 @@ impl<'a> Trade<'a> {
|
|||||||
trade: &'a PendingTrade,
|
trade: &'a PendingTrade,
|
||||||
) -> <Self as Widget>::Event {
|
) -> <Self as Widget>::Event {
|
||||||
let mut event = None;
|
let mut event = None;
|
||||||
|
let (hover_img, press_img, accept_button_luminance) = if trade.is_empty_trade() {
|
||||||
|
//Darken the accept button if the trade is empty.
|
||||||
|
(
|
||||||
|
self.imgs.button,
|
||||||
|
self.imgs.button,
|
||||||
|
Color::Rgba(0.6, 0.6, 0.6, 1.0),
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
(
|
||||||
|
self.imgs.button_hover,
|
||||||
|
self.imgs.button_press,
|
||||||
|
Color::Rgba(1.0, 1.0, 1.0, 1.0),
|
||||||
|
)
|
||||||
|
};
|
||||||
if Button::image(self.imgs.button)
|
if Button::image(self.imgs.button)
|
||||||
.w_h(31.0 * 5.0, 12.0 * 2.0)
|
.w_h(31.0 * 5.0, 12.0 * 2.0)
|
||||||
.hover_image(self.imgs.button_hover)
|
.hover_image(hover_img)
|
||||||
.press_image(self.imgs.button_press)
|
.press_image(press_img)
|
||||||
|
.image_color(accept_button_luminance)
|
||||||
.bottom_left_with_margins_on(state.ids.bg, 90.0, 47.0)
|
.bottom_left_with_margins_on(state.ids.bg, 90.0, 47.0)
|
||||||
.label(self.localized_strings.get("hud.trade.accept"))
|
.label(self.localized_strings.get("hud.trade.accept"))
|
||||||
.label_font_size(self.fonts.cyri.scale(14))
|
.label_font_size(self.fonts.cyri.scale(14))
|
||||||
|
Loading…
Reference in New Issue
Block a user