summaryrefslogtreecommitdiff
path: root/src/gui/trade.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/trade.cpp')
-rw-r--r--src/gui/trade.cpp63
1 files changed, 61 insertions, 2 deletions
diff --git a/src/gui/trade.cpp b/src/gui/trade.cpp
index d4c5e0f6..8da3ba1a 100644
--- a/src/gui/trade.cpp
+++ b/src/gui/trade.cpp
@@ -36,17 +36,31 @@ TradeWindow::TradeWindow():
setContentSize(322, 130);
addButton = new Button("Add");
+ okButton = new Button("Ok");
cancelButton = new Button("Cancel");
+ tradeButton = new Button("Trade");
+
addButton->setPosition(2, 105);
- cancelButton->setPosition(200, 105);
+ okButton->setPosition(30, 105);
+ cancelButton->setPosition(270, 105);
+ tradeButton->setPosition(230,105);
addButton->setEventId("add");
+ okButton->setEventId("ok");
cancelButton->setEventId("cancel");
+ tradeButton->setEventId("trade");
+
addButton->addActionListener(this);
+ okButton->addActionListener(this);
cancelButton->addActionListener(this);
+ tradeButton->addActionListener(this);
+
+ tradeButton->setEnabled(false);
add(addButton);
+ add(okButton);
add(cancelButton);
+ add(tradeButton);
nameLabel = new gcn::Label("Other one");
nameLabel->setPosition(2, 45);
@@ -68,7 +82,9 @@ TradeWindow::TradeWindow():
TradeWindow::~TradeWindow()
{
delete addButton;
+ delete okButton;
delete cancelButton;
+ delete tradeButton;
delete nameLabel;
}
@@ -119,6 +135,38 @@ int TradeWindow::increaseQuantity(int index, bool own, int quantity) {
int TradeWindow::reset() {
my_items->resetItems();
trade_items->resetItems();
+ tradeButton->setEnabled(false);
+ okButton->setEnabled(true);
+ ok_other = false;
+ ok_me = false;
+ return 0;
+}
+
+int TradeWindow::setTradeButton(bool enabled) {
+ tradeButton->setEnabled(enabled);
+ return 0;
+}
+
+int TradeWindow::receivedOk(bool own) {
+ if (own) {
+ ok_me = true;
+ if (ok_other) {
+ tradeButton->setEnabled(true);
+ okButton->setEnabled(false);
+ } else {
+ tradeButton->setEnabled(false);
+ okButton->setEnabled(false);
+ }
+ } else {
+ ok_other = true;
+ if (ok_me) {
+ tradeButton->setEnabled(true);
+ okButton->setEnabled(false);
+ } else {
+ tradeButton->setEnabled(false);
+ okButton->setEnabled(true);
+ }
+ }
return 0;
}
@@ -161,6 +209,8 @@ void TradeWindow::action(const std::string &eventId)
{
if (eventId == "add") {
+ // This is still kinda buggy, when ok is clicked, will need to play
+ // RO a bit to review its trade behaviour
if (inventoryWindow->items->getIndex() >= 0 &&
inventoryWindow->items->getIndex() <= INVENTORY_SIZE) {
if (tradeWindow->my_items->getFreeSlot() >= 0) {
@@ -169,14 +219,23 @@ void TradeWindow::action(const std::string &eventId)
WFIFOW(2) = net_w_value(inventoryWindow->items->getIndex());
WFIFOL(4) = net_l_value(inventoryWindow->items->getQuantity());
WFIFOSET(8);
+ //chatWindow->chat_log("add packet sent", BY_SERVER);
while ((out_size > 0)) flush();
-
+
}
}
} else if (eventId == "cancel") {
WFIFOW(0) = net_w_value(0x00ed);
WFIFOSET(2);
while ((out_size > 0)) flush();
+ } else if (eventId == "ok") {
+ WFIFOW(0) = net_w_value(0x00eb);
+ WFIFOSET(2);
+ while ((out_size > 0)) flush();
+ } else if (eventId == "trade") {
+ WFIFOW(0) = net_w_value(0x00ef);
+ WFIFOSET(2);
+ while ((out_size > 0)) flush();
}
//if(selectedItem >= 0 && selectedItem <= INVENTORY_SIZE) {