diff options
Diffstat (limited to 'indra/newview/llfloaterpay.cpp')
-rw-r--r-- | indra/newview/llfloaterpay.cpp | 788 |
1 files changed, 394 insertions, 394 deletions
diff --git a/indra/newview/llfloaterpay.cpp b/indra/newview/llfloaterpay.cpp index 94261b2e4e..d607f2361a 100644 --- a/indra/newview/llfloaterpay.cpp +++ b/indra/newview/llfloaterpay.cpp @@ -1,4 +1,4 @@ -/** +/** * @file llfloaterpay.cpp * @author Aaron Brashears, Kelly Washington, James Cook * @brief Implementation of the LLFloaterPay class. @@ -6,21 +6,21 @@ * $LicenseInfo:firstyear=2002&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2010, Linden Research, Inc. - * + * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. - * + * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. - * + * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - * + * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ @@ -31,7 +31,7 @@ #include "message.h" #include "llfloater.h" -#include "lllslconstants.h" // MAX_PAY_BUTTONS +#include "lllslconstants.h" // MAX_PAY_BUTTONS #include "lluuid.h" #include "llagent.h" @@ -66,10 +66,10 @@ class LLFloaterPay; struct LLGiveMoneyInfo { - LLFloaterPay* mFloater; - S32 mAmount; - LLGiveMoneyInfo(LLFloaterPay* floater, S32 amount) : - mFloater(floater), mAmount(amount){} + LLFloaterPay* mFloater; + S32 mAmount; + LLGiveMoneyInfo(LLFloaterPay* floater, S32 amount) : + mFloater(floater), mAmount(amount){} }; typedef std::shared_ptr<LLGiveMoneyInfo> give_money_ptr; @@ -81,43 +81,43 @@ typedef std::shared_ptr<LLGiveMoneyInfo> give_money_ptr; class LLFloaterPay : public LLFloater { public: - LLFloaterPay(const LLSD& key); - virtual ~LLFloaterPay(); - /*virtual*/ BOOL postBuild(); - /*virtual*/ void onClose(bool app_quitting); - - void setCallback(money_callback callback) { mCallback = callback; } - - - static void payViaObject(money_callback callback, LLSafeHandle<LLObjectSelection> selection); - - static void payDirectly(money_callback callback, - const LLUUID& target_id, - bool is_group); - static bool payConfirmationCallback(const LLSD& notification, - const LLSD& response, - give_money_ptr info); + LLFloaterPay(const LLSD& key); + virtual ~LLFloaterPay(); + /*virtual*/ BOOL postBuild(); + /*virtual*/ void onClose(bool app_quitting); + + void setCallback(money_callback callback) { mCallback = callback; } + + + static void payViaObject(money_callback callback, LLSafeHandle<LLObjectSelection> selection); + + static void payDirectly(money_callback callback, + const LLUUID& target_id, + bool is_group); + static bool payConfirmationCallback(const LLSD& notification, + const LLSD& response, + give_money_ptr info); private: - static void onCancel(void* data); - static void onKeystroke(LLLineEditor* editor, void* data); - static void onGive(give_money_ptr info); - void give(S32 amount); - static void processPayPriceReply(LLMessageSystem* msg, void **userdata); - void finishPayUI(const LLUUID& target_id, BOOL is_group); + static void onCancel(void* data); + static void onKeystroke(LLLineEditor* editor, void* data); + static void onGive(give_money_ptr info); + void give(S32 amount); + static void processPayPriceReply(LLMessageSystem* msg, void **userdata); + void finishPayUI(const LLUUID& target_id, BOOL is_group); protected: - std::vector<give_money_ptr> mCallbackData; - money_callback mCallback; - LLTextBox* mObjectNameText; - LLUUID mTargetUUID; - BOOL mTargetIsGroup; - BOOL mHaveName; + std::vector<give_money_ptr> mCallbackData; + money_callback mCallback; + LLTextBox* mObjectNameText; + LLUUID mTargetUUID; + BOOL mTargetIsGroup; + BOOL mHaveName; - LLButton* mQuickPayButton[MAX_PAY_BUTTONS]; - give_money_ptr mQuickPayInfo[MAX_PAY_BUTTONS]; + LLButton* mQuickPayButton[MAX_PAY_BUTTONS]; + give_money_ptr mQuickPayInfo[MAX_PAY_BUTTONS]; - LLSafeHandle<LLObjectSelection> mObjectSelection; + LLSafeHandle<LLObjectSelection> mObjectSelection; }; @@ -125,13 +125,13 @@ const S32 FASTPAY_BUTTON_WIDTH = 80; const S32 PAY_AMOUNT_NOTIFICATION = 200; LLFloaterPay::LLFloaterPay(const LLSD& key) - : LLFloater(key), - mCallbackData(), - mCallback(NULL), - mObjectNameText(NULL), - mTargetUUID(key.asUUID()), - mTargetIsGroup(FALSE), - mHaveName(FALSE) + : LLFloater(key), + mCallbackData(), + mCallback(NULL), + mObjectNameText(NULL), + mTargetUUID(key.asUUID()), + mTargetIsGroup(FALSE), + mHaveName(FALSE) { } @@ -143,343 +143,343 @@ LLFloaterPay::~LLFloaterPay() { (*iter)->mFloater = NULL; } - mCallbackData.clear(); - // Name callbacks will be automatically disconnected since LLFloater is trackable - - // In case this floater is currently waiting for a reply. - gMessageSystem->setHandlerFuncFast(_PREHASH_PayPriceReply, 0, 0); + mCallbackData.clear(); + // Name callbacks will be automatically disconnected since LLFloater is trackable + + // In case this floater is currently waiting for a reply. + gMessageSystem->setHandlerFuncFast(_PREHASH_PayPriceReply, 0, 0); } BOOL LLFloaterPay::postBuild() { - S32 i = 0; - - give_money_ptr info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_0)); - mCallbackData.push_back(info); + S32 i = 0; - childSetAction("fastpay 1", boost::bind(LLFloaterPay::onGive, info)); - getChildView("fastpay 1")->setVisible(FALSE); + give_money_ptr info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_0)); + mCallbackData.push_back(info); - mQuickPayButton[i] = getChild<LLButton>("fastpay 1"); - mQuickPayInfo[i] = info; - ++i; + childSetAction("fastpay 1", boost::bind(LLFloaterPay::onGive, info)); + getChildView("fastpay 1")->setVisible(FALSE); - info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_1)); - mCallbackData.push_back(info); + mQuickPayButton[i] = getChild<LLButton>("fastpay 1"); + mQuickPayInfo[i] = info; + ++i; - childSetAction("fastpay 5", boost::bind(LLFloaterPay::onGive, info)); - getChildView("fastpay 5")->setVisible(FALSE); + info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_1)); + mCallbackData.push_back(info); - mQuickPayButton[i] = getChild<LLButton>("fastpay 5"); - mQuickPayInfo[i] = info; - ++i; + childSetAction("fastpay 5", boost::bind(LLFloaterPay::onGive, info)); + getChildView("fastpay 5")->setVisible(FALSE); - info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_2)); - mCallbackData.push_back(info); + mQuickPayButton[i] = getChild<LLButton>("fastpay 5"); + mQuickPayInfo[i] = info; + ++i; - childSetAction("fastpay 10", boost::bind(LLFloaterPay::onGive, info)); - getChildView("fastpay 10")->setVisible(FALSE); + info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_2)); + mCallbackData.push_back(info); - mQuickPayButton[i] = getChild<LLButton>("fastpay 10"); - mQuickPayInfo[i] = info; - ++i; + childSetAction("fastpay 10", boost::bind(LLFloaterPay::onGive, info)); + getChildView("fastpay 10")->setVisible(FALSE); - info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_3)); - mCallbackData.push_back(info); + mQuickPayButton[i] = getChild<LLButton>("fastpay 10"); + mQuickPayInfo[i] = info; + ++i; - childSetAction("fastpay 20", boost::bind(LLFloaterPay::onGive, info)); - getChildView("fastpay 20")->setVisible(FALSE); + info = give_money_ptr(new LLGiveMoneyInfo(this, PAY_BUTTON_DEFAULT_3)); + mCallbackData.push_back(info); - mQuickPayButton[i] = getChild<LLButton>("fastpay 20"); - mQuickPayInfo[i] = info; - ++i; + childSetAction("fastpay 20", boost::bind(LLFloaterPay::onGive, info)); + getChildView("fastpay 20")->setVisible(FALSE); + mQuickPayButton[i] = getChild<LLButton>("fastpay 20"); + mQuickPayInfo[i] = info; + ++i; - getChildView("amount text")->setVisible(FALSE); - getChildView("amount")->setVisible(FALSE); - getChild<LLLineEditor>("amount")->setKeystrokeCallback(&LLFloaterPay::onKeystroke, this); - getChild<LLLineEditor>("amount")->setPrevalidate(LLTextValidate::validateNonNegativeS32); + getChildView("amount text")->setVisible(FALSE); + getChildView("amount")->setVisible(FALSE); - info = give_money_ptr(new LLGiveMoneyInfo(this, 0)); - mCallbackData.push_back(info); + getChild<LLLineEditor>("amount")->setKeystrokeCallback(&LLFloaterPay::onKeystroke, this); + getChild<LLLineEditor>("amount")->setPrevalidate(LLTextValidate::validateNonNegativeS32); - childSetAction("pay btn", boost::bind(LLFloaterPay::onGive, info)); - setDefaultBtn("pay btn"); - getChildView("pay btn")->setVisible(FALSE); - getChildView("pay btn")->setEnabled(FALSE); + info = give_money_ptr(new LLGiveMoneyInfo(this, 0)); + mCallbackData.push_back(info); - childSetAction("cancel btn",&LLFloaterPay::onCancel,this); + childSetAction("pay btn", boost::bind(LLFloaterPay::onGive, info)); + setDefaultBtn("pay btn"); + getChildView("pay btn")->setVisible(FALSE); + getChildView("pay btn")->setEnabled(FALSE); - return TRUE; + childSetAction("cancel btn",&LLFloaterPay::onCancel,this); + + return TRUE; } // virtual void LLFloaterPay::onClose(bool app_quitting) { - // Deselect the objects - mObjectSelection = NULL; + // Deselect the objects + mObjectSelection = NULL; } // static void LLFloaterPay::processPayPriceReply(LLMessageSystem* msg, void **userdata) { - LLFloaterPay* self = (LLFloaterPay*)userdata; - if (self) - { - S32 price; - LLUUID target; - - msg->getUUIDFast(_PREHASH_ObjectData,_PREHASH_ObjectID,target); - if (target != self->mTargetUUID) - { - // This is a message for a different object's pay info - return; - } - - msg->getS32Fast(_PREHASH_ObjectData,_PREHASH_DefaultPayPrice,price); - - if (PAY_PRICE_HIDE == price) - { - self->getChildView("amount")->setVisible(FALSE); - self->getChildView("pay btn")->setVisible(FALSE); - self->getChildView("amount text")->setVisible(FALSE); - } - else if (PAY_PRICE_DEFAULT == price) - { - self->getChildView("amount")->setVisible(TRUE); - self->getChildView("pay btn")->setVisible(TRUE); - self->getChildView("amount text")->setVisible(TRUE); - } - else - { - // PAY_PRICE_HIDE and PAY_PRICE_DEFAULT are negative values - // So we take the absolute value here after we have checked for those cases - - self->getChildView("amount")->setVisible(TRUE); - self->getChildView("pay btn")->setVisible(TRUE); - self->getChildView("pay btn")->setEnabled(TRUE); - self->getChildView("amount text")->setVisible(TRUE); - - self->getChild<LLUICtrl>("amount")->setValue(llformat("%d", llabs(price))); - } - - S32 num_blocks = msg->getNumberOfBlocksFast(_PREHASH_ButtonData); - S32 i = 0; - if (num_blocks > MAX_PAY_BUTTONS) num_blocks = MAX_PAY_BUTTONS; - - S32 max_pay_amount = 0; - S32 padding_required = 0; - - for (i=0;i<num_blocks;++i) - { - S32 pay_button; - msg->getS32Fast(_PREHASH_ButtonData,_PREHASH_PayButton,pay_button,i); - if (pay_button > 0) - { - std::string button_str = "L$"; - button_str += LLResMgr::getInstance()->getMonetaryString( pay_button ); - - self->mQuickPayButton[i]->setLabelSelected(button_str); - self->mQuickPayButton[i]->setLabelUnselected(button_str); - self->mQuickPayButton[i]->setVisible(TRUE); - self->mQuickPayInfo[i]->mAmount = pay_button; - - if ( pay_button > max_pay_amount ) - { - max_pay_amount = pay_button; - } - } - else - { - self->mQuickPayButton[i]->setVisible(FALSE); - } - } - - // build a string containing the maximum value and calc nerw button width from it. - std::string balance_str = "L$"; - balance_str += LLResMgr::getInstance()->getMonetaryString( max_pay_amount ); - const LLFontGL* font = LLFontGL::getFontSansSerif(); - S32 new_button_width = font->getWidth( std::string(balance_str)); - new_button_width += ( 12 + 12 ); // padding - - // dialong is sized for 2 digit pay amounts - larger pay values need to be scaled - const S32 threshold = 100000; - if ( max_pay_amount >= threshold ) - { - S32 num_digits_threshold = (S32)log10((double)threshold) + 1; - S32 num_digits_max = (S32)log10((double)max_pay_amount) + 1; - - // calculate the extra width required by 2 buttons with max amount and some commas - padding_required = ( num_digits_max - num_digits_threshold + ( num_digits_max / 3 ) ) * font->getWidth( std::string("0") ); - }; - - // change in button width - S32 button_delta = new_button_width - FASTPAY_BUTTON_WIDTH; - if ( button_delta < 0 ) - button_delta = 0; - - // now we know the maximum amount, we can resize all the buttons to be - for (i=0;i<num_blocks;++i) - { - LLRect r; - r = self->mQuickPayButton[i]->getRect(); - - // RHS button colum needs to move further because LHS changed too - if ( i % 2 ) - { - r.setCenterAndSize( r.getCenterX() + ( button_delta * 3 ) / 2 , - r.getCenterY(), - r.getWidth() + button_delta, - r.getHeight() ); - } - else - { - r.setCenterAndSize( r.getCenterX() + button_delta / 2, - r.getCenterY(), - r.getWidth() + button_delta, - r.getHeight() ); - } - self->mQuickPayButton[i]->setRect( r ); - } - - for (i=num_blocks;i<MAX_PAY_BUTTONS;++i) - { - self->mQuickPayButton[i]->setVisible(FALSE); - } - - self->reshape( self->getRect().getWidth() + padding_required, self->getRect().getHeight(), FALSE ); - } - msg->setHandlerFunc("PayPriceReply",NULL,NULL); + LLFloaterPay* self = (LLFloaterPay*)userdata; + if (self) + { + S32 price; + LLUUID target; + + msg->getUUIDFast(_PREHASH_ObjectData,_PREHASH_ObjectID,target); + if (target != self->mTargetUUID) + { + // This is a message for a different object's pay info + return; + } + + msg->getS32Fast(_PREHASH_ObjectData,_PREHASH_DefaultPayPrice,price); + + if (PAY_PRICE_HIDE == price) + { + self->getChildView("amount")->setVisible(FALSE); + self->getChildView("pay btn")->setVisible(FALSE); + self->getChildView("amount text")->setVisible(FALSE); + } + else if (PAY_PRICE_DEFAULT == price) + { + self->getChildView("amount")->setVisible(TRUE); + self->getChildView("pay btn")->setVisible(TRUE); + self->getChildView("amount text")->setVisible(TRUE); + } + else + { + // PAY_PRICE_HIDE and PAY_PRICE_DEFAULT are negative values + // So we take the absolute value here after we have checked for those cases + + self->getChildView("amount")->setVisible(TRUE); + self->getChildView("pay btn")->setVisible(TRUE); + self->getChildView("pay btn")->setEnabled(TRUE); + self->getChildView("amount text")->setVisible(TRUE); + + self->getChild<LLUICtrl>("amount")->setValue(llformat("%d", llabs(price))); + } + + S32 num_blocks = msg->getNumberOfBlocksFast(_PREHASH_ButtonData); + S32 i = 0; + if (num_blocks > MAX_PAY_BUTTONS) num_blocks = MAX_PAY_BUTTONS; + + S32 max_pay_amount = 0; + S32 padding_required = 0; + + for (i=0;i<num_blocks;++i) + { + S32 pay_button; + msg->getS32Fast(_PREHASH_ButtonData,_PREHASH_PayButton,pay_button,i); + if (pay_button > 0) + { + std::string button_str = "L$"; + button_str += LLResMgr::getInstance()->getMonetaryString( pay_button ); + + self->mQuickPayButton[i]->setLabelSelected(button_str); + self->mQuickPayButton[i]->setLabelUnselected(button_str); + self->mQuickPayButton[i]->setVisible(TRUE); + self->mQuickPayInfo[i]->mAmount = pay_button; + + if ( pay_button > max_pay_amount ) + { + max_pay_amount = pay_button; + } + } + else + { + self->mQuickPayButton[i]->setVisible(FALSE); + } + } + + // build a string containing the maximum value and calc nerw button width from it. + std::string balance_str = "L$"; + balance_str += LLResMgr::getInstance()->getMonetaryString( max_pay_amount ); + const LLFontGL* font = LLFontGL::getFontSansSerif(); + S32 new_button_width = font->getWidth( std::string(balance_str)); + new_button_width += ( 12 + 12 ); // padding + + // dialong is sized for 2 digit pay amounts - larger pay values need to be scaled + const S32 threshold = 100000; + if ( max_pay_amount >= threshold ) + { + S32 num_digits_threshold = (S32)log10((double)threshold) + 1; + S32 num_digits_max = (S32)log10((double)max_pay_amount) + 1; + + // calculate the extra width required by 2 buttons with max amount and some commas + padding_required = ( num_digits_max - num_digits_threshold + ( num_digits_max / 3 ) ) * font->getWidth( std::string("0") ); + }; + + // change in button width + S32 button_delta = new_button_width - FASTPAY_BUTTON_WIDTH; + if ( button_delta < 0 ) + button_delta = 0; + + // now we know the maximum amount, we can resize all the buttons to be + for (i=0;i<num_blocks;++i) + { + LLRect r; + r = self->mQuickPayButton[i]->getRect(); + + // RHS button colum needs to move further because LHS changed too + if ( i % 2 ) + { + r.setCenterAndSize( r.getCenterX() + ( button_delta * 3 ) / 2 , + r.getCenterY(), + r.getWidth() + button_delta, + r.getHeight() ); + } + else + { + r.setCenterAndSize( r.getCenterX() + button_delta / 2, + r.getCenterY(), + r.getWidth() + button_delta, + r.getHeight() ); + } + self->mQuickPayButton[i]->setRect( r ); + } + + for (i=num_blocks;i<MAX_PAY_BUTTONS;++i) + { + self->mQuickPayButton[i]->setVisible(FALSE); + } + + self->reshape( self->getRect().getWidth() + padding_required, self->getRect().getHeight(), FALSE ); + } + msg->setHandlerFunc("PayPriceReply",NULL,NULL); } // static void LLFloaterPay::payViaObject(money_callback callback, LLSafeHandle<LLObjectSelection> selection) { - // Object that lead to the selection, may be child - LLViewerObject* object = selection->getPrimaryObject(); - if (!object) - return; - - LLFloaterPay *floater = LLFloaterReg::showTypedInstance<LLFloaterPay>("pay_object", LLSD(object->getID())); - if (!floater) - return; - - floater->setCallback(callback); - // Hold onto the selection until we close - floater->mObjectSelection = selection; - - LLSelectNode* node = selection->getFirstRootNode(); - if (!node) - { - // object no longer exists - LLNotificationsUtil::add("PayObjectFailed"); - floater->closeFloater(); - return; - } - - LLHost target_region = object->getRegion()->getHost(); - - LLMessageSystem* msg = gMessageSystem; - msg->newMessageFast(_PREHASH_RequestPayPrice); - msg->nextBlockFast(_PREHASH_ObjectData); - msg->addUUIDFast(_PREHASH_ObjectID, object->getID()); - msg->sendReliable(target_region); - msg->setHandlerFuncFast(_PREHASH_PayPriceReply, processPayPriceReply,(void **)floater); - - LLUUID owner_id; - BOOL is_group = FALSE; - node->mPermissions->getOwnership(owner_id, is_group); - - floater->getChild<LLUICtrl>("object_name_text")->setValue(node->mName); - - floater->finishPayUI(owner_id, is_group); + // Object that lead to the selection, may be child + LLViewerObject* object = selection->getPrimaryObject(); + if (!object) + return; + + LLFloaterPay *floater = LLFloaterReg::showTypedInstance<LLFloaterPay>("pay_object", LLSD(object->getID())); + if (!floater) + return; + + floater->setCallback(callback); + // Hold onto the selection until we close + floater->mObjectSelection = selection; + + LLSelectNode* node = selection->getFirstRootNode(); + if (!node) + { + // object no longer exists + LLNotificationsUtil::add("PayObjectFailed"); + floater->closeFloater(); + return; + } + + LLHost target_region = object->getRegion()->getHost(); + + LLMessageSystem* msg = gMessageSystem; + msg->newMessageFast(_PREHASH_RequestPayPrice); + msg->nextBlockFast(_PREHASH_ObjectData); + msg->addUUIDFast(_PREHASH_ObjectID, object->getID()); + msg->sendReliable(target_region); + msg->setHandlerFuncFast(_PREHASH_PayPriceReply, processPayPriceReply,(void **)floater); + + LLUUID owner_id; + BOOL is_group = FALSE; + node->mPermissions->getOwnership(owner_id, is_group); + + floater->getChild<LLUICtrl>("object_name_text")->setValue(node->mName); + + floater->finishPayUI(owner_id, is_group); } -void LLFloaterPay::payDirectly(money_callback callback, - const LLUUID& target_id, - bool is_group) +void LLFloaterPay::payDirectly(money_callback callback, + const LLUUID& target_id, + bool is_group) { - LLFloaterPay *floater = LLFloaterReg::showTypedInstance<LLFloaterPay>("pay_resident", LLSD(target_id)); - if (!floater) - return; - - floater->setCallback(callback); - floater->mObjectSelection = NULL; - - floater->getChildView("amount")->setVisible(TRUE); - floater->getChildView("pay btn")->setVisible(TRUE); - floater->getChildView("amount text")->setVisible(TRUE); - - for(S32 i=0;i<MAX_PAY_BUTTONS;++i) - { - floater->mQuickPayButton[i]->setVisible(TRUE); - } - - floater->finishPayUI(target_id, is_group); + LLFloaterPay *floater = LLFloaterReg::showTypedInstance<LLFloaterPay>("pay_resident", LLSD(target_id)); + if (!floater) + return; + + floater->setCallback(callback); + floater->mObjectSelection = NULL; + + floater->getChildView("amount")->setVisible(TRUE); + floater->getChildView("pay btn")->setVisible(TRUE); + floater->getChildView("amount text")->setVisible(TRUE); + + for(S32 i=0;i<MAX_PAY_BUTTONS;++i) + { + floater->mQuickPayButton[i]->setVisible(TRUE); + } + + floater->finishPayUI(target_id, is_group); } bool LLFloaterPay::payConfirmationCallback(const LLSD& notification, const LLSD& response, give_money_ptr info) { - if (!info.get() || !info->mFloater) - { - return false; - } - - S32 option = LLNotificationsUtil::getSelectedOption(notification, response); - if (option == 0) - { - info->mFloater->give(info->mAmount); - info->mFloater->closeFloater(); - } - - return false; + if (!info.get() || !info->mFloater) + { + return false; + } + + S32 option = LLNotificationsUtil::getSelectedOption(notification, response); + if (option == 0) + { + info->mFloater->give(info->mAmount); + info->mFloater->closeFloater(); + } + + return false; } void LLFloaterPay::finishPayUI(const LLUUID& target_id, BOOL is_group) { - std::string slurl; - if (is_group) - { - setTitle(getString("payee_group")); - slurl = LLSLURL("group", target_id, "inspect").getSLURLString(); - } - else - { - setTitle(getString("payee_resident")); - slurl = LLSLURL("agent", target_id, "inspect").getSLURLString(); - } - getChild<LLTextBox>("payee_name")->setText(slurl); - - // Make sure the amount field has focus - - LLLineEditor* amount = getChild<LLLineEditor>("amount"); - amount->setFocus(TRUE); - amount->selectAll(); - - mTargetIsGroup = is_group; + std::string slurl; + if (is_group) + { + setTitle(getString("payee_group")); + slurl = LLSLURL("group", target_id, "inspect").getSLURLString(); + } + else + { + setTitle(getString("payee_resident")); + slurl = LLSLURL("agent", target_id, "inspect").getSLURLString(); + } + getChild<LLTextBox>("payee_name")->setText(slurl); + + // Make sure the amount field has focus + + LLLineEditor* amount = getChild<LLLineEditor>("amount"); + amount->setFocus(TRUE); + amount->selectAll(); + + mTargetIsGroup = is_group; } // static void LLFloaterPay::onCancel(void* data) { - LLFloaterPay* self = reinterpret_cast<LLFloaterPay*>(data); - if(self) - { - self->closeFloater(); - } + LLFloaterPay* self = reinterpret_cast<LLFloaterPay*>(data); + if(self) + { + self->closeFloater(); + } } // static void LLFloaterPay::onKeystroke(LLLineEditor*, void* data) { - LLFloaterPay* self = reinterpret_cast<LLFloaterPay*>(data); - if(self) - { - // enable the Pay button when amount is non-empty and positive, disable otherwise - std::string amtstr = self->getChild<LLUICtrl>("amount")->getValue().asString(); - self->getChildView("pay btn")->setEnabled(!amtstr.empty() && atoi(amtstr.c_str()) > 0); - } + LLFloaterPay* self = reinterpret_cast<LLFloaterPay*>(data); + if(self) + { + // enable the Pay button when amount is non-empty and positive, disable otherwise + std::string amtstr = self->getChild<LLUICtrl>("amount")->getValue().asString(); + self->getChildView("pay btn")->setEnabled(!amtstr.empty() && atoi(amtstr.c_str()) > 0); + } } // static @@ -542,63 +542,63 @@ void LLFloaterPay::onGive(give_money_ptr info) void LLFloaterPay::give(S32 amount) { - if(mCallback) - { - // if the amount is 0, that menas that we should use the - // text field. - if(amount == 0) - { - amount = atoi(getChild<LLUICtrl>("amount")->getValue().asString().c_str()); - } - - // Try to pay an object. - if (mObjectSelection.notNull()) - { - LLViewerObject* dest_object = gObjectList.findObject(mTargetUUID); - if(dest_object) - { - LLViewerRegion* region = dest_object->getRegion(); - if (region) - { - // Find the name of the root object - LLSelectNode* node = mObjectSelection->getFirstRootNode(); - std::string object_name; - if (node) - { - object_name = node->mName; - } - S32 tx_type = TRANS_PAY_OBJECT; - if(dest_object->isAvatar()) tx_type = TRANS_GIFT; - mCallback(mTargetUUID, region, amount, FALSE, tx_type, object_name); - mObjectSelection = NULL; - - // request the object owner in order to check if the owner needs to be unmuted - LLMessageSystem* msg = gMessageSystem; - msg->newMessageFast(_PREHASH_RequestObjectPropertiesFamily); - msg->nextBlockFast(_PREHASH_AgentData); - msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID()); - msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID()); - msg->nextBlockFast(_PREHASH_ObjectData); - msg->addU32Fast(_PREHASH_RequestFlags, OBJECT_PAY_REQUEST ); - msg->addUUIDFast(_PREHASH_ObjectID, mTargetUUID); - msg->sendReliable( region->getHost() ); - } - } - else - { - LLNotificationsUtil::add("PayObjectFailed"); - } - } - else - { - // just transfer the L$ - std::string paymentMessage(getChild<LLLineEditor>("payment_message")->getValue().asString()); - mCallback(mTargetUUID, gAgent.getRegion(), amount, mTargetIsGroup, TRANS_GIFT, (paymentMessage.empty() ? LLStringUtil::null : paymentMessage)); - - // check if the payee needs to be unmuted - LLMuteList::getInstance()->autoRemove(mTargetUUID, LLMuteList::AR_MONEY); - } - } + if(mCallback) + { + // if the amount is 0, that menas that we should use the + // text field. + if(amount == 0) + { + amount = atoi(getChild<LLUICtrl>("amount")->getValue().asString().c_str()); + } + + // Try to pay an object. + if (mObjectSelection.notNull()) + { + LLViewerObject* dest_object = gObjectList.findObject(mTargetUUID); + if(dest_object) + { + LLViewerRegion* region = dest_object->getRegion(); + if (region) + { + // Find the name of the root object + LLSelectNode* node = mObjectSelection->getFirstRootNode(); + std::string object_name; + if (node) + { + object_name = node->mName; + } + S32 tx_type = TRANS_PAY_OBJECT; + if(dest_object->isAvatar()) tx_type = TRANS_GIFT; + mCallback(mTargetUUID, region, amount, FALSE, tx_type, object_name); + mObjectSelection = NULL; + + // request the object owner in order to check if the owner needs to be unmuted + LLMessageSystem* msg = gMessageSystem; + msg->newMessageFast(_PREHASH_RequestObjectPropertiesFamily); + msg->nextBlockFast(_PREHASH_AgentData); + msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID()); + msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID()); + msg->nextBlockFast(_PREHASH_ObjectData); + msg->addU32Fast(_PREHASH_RequestFlags, OBJECT_PAY_REQUEST ); + msg->addUUIDFast(_PREHASH_ObjectID, mTargetUUID); + msg->sendReliable( region->getHost() ); + } + } + else + { + LLNotificationsUtil::add("PayObjectFailed"); + } + } + else + { + // just transfer the L$ + std::string paymentMessage(getChild<LLLineEditor>("payment_message")->getValue().asString()); + mCallback(mTargetUUID, gAgent.getRegion(), amount, mTargetIsGroup, TRANS_GIFT, (paymentMessage.empty() ? LLStringUtil::null : paymentMessage)); + + // check if the payee needs to be unmuted + LLMuteList::getInstance()->autoRemove(mTargetUUID, LLMuteList::AR_MONEY); + } + } } //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ @@ -606,22 +606,22 @@ void LLFloaterPay::give(S32 amount) //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ void LLFloaterPayUtil::registerFloater() { - // Sneaky, use same code but different XML for dialogs - LLFloaterReg::add("pay_resident", "floater_pay.xml", - &LLFloaterReg::build<LLFloaterPay>); - LLFloaterReg::add("pay_object", "floater_pay_object.xml", - &LLFloaterReg::build<LLFloaterPay>); + // Sneaky, use same code but different XML for dialogs + LLFloaterReg::add("pay_resident", "floater_pay.xml", + &LLFloaterReg::build<LLFloaterPay>); + LLFloaterReg::add("pay_object", "floater_pay_object.xml", + &LLFloaterReg::build<LLFloaterPay>); } void LLFloaterPayUtil::payViaObject(money_callback callback, - LLSafeHandle<LLObjectSelection> selection) + LLSafeHandle<LLObjectSelection> selection) { - LLFloaterPay::payViaObject(callback, selection); + LLFloaterPay::payViaObject(callback, selection); } void LLFloaterPayUtil::payDirectly(money_callback callback, - const LLUUID& target_id, - bool is_group) + const LLUUID& target_id, + bool is_group) { - LLFloaterPay::payDirectly(callback, target_id, is_group); + LLFloaterPay::payDirectly(callback, target_id, is_group); } |