summaryrefslogtreecommitdiff
path: root/indra/newview/llcurrencyuimanager.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'indra/newview/llcurrencyuimanager.cpp')
-rw-r--r--indra/newview/llcurrencyuimanager.cpp812
1 files changed, 406 insertions, 406 deletions
diff --git a/indra/newview/llcurrencyuimanager.cpp b/indra/newview/llcurrencyuimanager.cpp
index 4c0a5cf183..6726b6a111 100644
--- a/indra/newview/llcurrencyuimanager.cpp
+++ b/indra/newview/llcurrencyuimanager.cpp
@@ -1,25 +1,25 @@
-/**
+/**
* @file llcurrencyuimanager.cpp
* @brief LLCurrencyUIManager class implementation
*
* $LicenseInfo:firstyear=2006&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$
*/
@@ -49,584 +49,584 @@
const F64 CURRENCY_ESTIMATE_FREQUENCY = 2.0;
- // how long of a pause in typing a currency buy amount before an
- // esimate is fetched from the server
+ // how long of a pause in typing a currency buy amount before an
+ // esimate is fetched from the server
class LLCurrencyUIManager::Impl
{
public:
- Impl(LLPanel& dialog);
- virtual ~Impl();
-
- LLPanel& mPanel;
-
- bool mHidden;
-
- bool mError;
- std::string mErrorMessage;
- std::string mErrorURI;
-
- std::string mZeroMessage;
-
- // user's choices
- S32 mUserCurrencyBuy;
- bool mUserEnteredCurrencyBuy;
-
- // from website
-
- // pre-viewer 2.0, the server returned estimates as an
- // integer US cents value, e.g., "1000" for $10.00
- // post-viewer 2.0, the server may also return estimates
- // as a string with currency embedded, e.g., "10.00 Euros"
- bool mUSDCurrencyEstimated;
- S32 mUSDCurrencyEstimatedCost;
- bool mLocalCurrencyEstimated;
- std::string mLocalCurrencyEstimatedCost;
- bool mSupportsInternationalBilling;
- std::string mSiteConfirm;
-
- bool mBought;
-
- enum TransactionType
- {
- TransactionNone,
- TransactionCurrency,
- TransactionBuy
- };
-
- TransactionType mTransactionType;
- LLXMLRPCTransaction* mTransaction;
-
- bool mCurrencyChanged;
- LLFrameTimer mCurrencyKeyTimer;
-
-
- void updateCurrencyInfo();
- void finishCurrencyInfo();
-
- void startCurrencyBuy(const std::string& password);
- void finishCurrencyBuy();
-
- void clearEstimate();
- bool hasEstimate() const;
- std::string getLocalEstimate() const;
-
- void startTransaction(TransactionType type,
- const char* method, LLXMLRPCValue params);
- bool checkTransaction();
- // return true if update needed
-
- void setError(const std::string& message, const std::string& uri);
- void clearError();
-
- bool considerUpdateCurrency();
- // return true if update needed
- void currencyKey(S32);
- static void onCurrencyKey(LLLineEditor* caller, void* data);
-
- void prepare();
- void updateUI();
+ Impl(LLPanel& dialog);
+ virtual ~Impl();
+
+ LLPanel& mPanel;
+
+ bool mHidden;
+
+ bool mError;
+ std::string mErrorMessage;
+ std::string mErrorURI;
+
+ std::string mZeroMessage;
+
+ // user's choices
+ S32 mUserCurrencyBuy;
+ bool mUserEnteredCurrencyBuy;
+
+ // from website
+
+ // pre-viewer 2.0, the server returned estimates as an
+ // integer US cents value, e.g., "1000" for $10.00
+ // post-viewer 2.0, the server may also return estimates
+ // as a string with currency embedded, e.g., "10.00 Euros"
+ bool mUSDCurrencyEstimated;
+ S32 mUSDCurrencyEstimatedCost;
+ bool mLocalCurrencyEstimated;
+ std::string mLocalCurrencyEstimatedCost;
+ bool mSupportsInternationalBilling;
+ std::string mSiteConfirm;
+
+ bool mBought;
+
+ enum TransactionType
+ {
+ TransactionNone,
+ TransactionCurrency,
+ TransactionBuy
+ };
+
+ TransactionType mTransactionType;
+ LLXMLRPCTransaction* mTransaction;
+
+ bool mCurrencyChanged;
+ LLFrameTimer mCurrencyKeyTimer;
+
+
+ void updateCurrencyInfo();
+ void finishCurrencyInfo();
+
+ void startCurrencyBuy(const std::string& password);
+ void finishCurrencyBuy();
+
+ void clearEstimate();
+ bool hasEstimate() const;
+ std::string getLocalEstimate() const;
+
+ void startTransaction(TransactionType type,
+ const char* method, LLXMLRPCValue params);
+ bool checkTransaction();
+ // return true if update needed
+
+ void setError(const std::string& message, const std::string& uri);
+ void clearError();
+
+ bool considerUpdateCurrency();
+ // return true if update needed
+ void currencyKey(S32);
+ static void onCurrencyKey(LLLineEditor* caller, void* data);
+
+ void prepare();
+ void updateUI();
};
// is potentially not fully constructed.
LLCurrencyUIManager::Impl::Impl(LLPanel& dialog)
- : mPanel(dialog),
- mHidden(false),
- mError(false),
- mUserCurrencyBuy(2000), // note, this is a default, real value set in llfloaterbuycurrency.cpp
- mUserEnteredCurrencyBuy(false),
- mSupportsInternationalBilling(false),
- mBought(false),
- mTransactionType(TransactionNone), mTransaction(0),
- mCurrencyChanged(false)
+ : mPanel(dialog),
+ mHidden(false),
+ mError(false),
+ mUserCurrencyBuy(2000), // note, this is a default, real value set in llfloaterbuycurrency.cpp
+ mUserEnteredCurrencyBuy(false),
+ mSupportsInternationalBilling(false),
+ mBought(false),
+ mTransactionType(TransactionNone), mTransaction(0),
+ mCurrencyChanged(false)
{
- clearEstimate();
+ clearEstimate();
}
LLCurrencyUIManager::Impl::~Impl()
{
- delete mTransaction;
+ delete mTransaction;
}
void LLCurrencyUIManager::Impl::updateCurrencyInfo()
{
- clearEstimate();
- mBought = false;
- mCurrencyChanged = false;
-
- if (mUserCurrencyBuy == 0)
- {
- mLocalCurrencyEstimated = true;
- return;
- }
-
- LLXMLRPCValue keywordArgs = LLXMLRPCValue::createStruct();
- keywordArgs.appendString("agentId", gAgent.getID().asString());
- keywordArgs.appendString(
- "secureSessionId",
- gAgent.getSecureSessionID().asString());
- keywordArgs.appendString("language", LLUI::getLanguage());
- keywordArgs.appendInt("currencyBuy", mUserCurrencyBuy);
- keywordArgs.appendString("viewerChannel", LLVersionInfo::instance().getChannel());
- keywordArgs.appendInt("viewerMajorVersion", LLVersionInfo::instance().getMajor());
- keywordArgs.appendInt("viewerMinorVersion", LLVersionInfo::instance().getMinor());
- keywordArgs.appendInt("viewerPatchVersion", LLVersionInfo::instance().getPatch());
- // With GitHub builds, the build number is too big to fit in a 32-bit int,
- // and XMLRPC_VALUE doesn't deal with integers wider than int. Use string.
- keywordArgs.appendString("viewerBuildVersion", stringize(LLVersionInfo::instance().getBuild()));
-
- LLXMLRPCValue params = LLXMLRPCValue::createArray();
- params.append(keywordArgs);
-
- startTransaction(TransactionCurrency, "getCurrencyQuote", params);
+ clearEstimate();
+ mBought = false;
+ mCurrencyChanged = false;
+
+ if (mUserCurrencyBuy == 0)
+ {
+ mLocalCurrencyEstimated = true;
+ return;
+ }
+
+ LLXMLRPCValue keywordArgs = LLXMLRPCValue::createStruct();
+ keywordArgs.appendString("agentId", gAgent.getID().asString());
+ keywordArgs.appendString(
+ "secureSessionId",
+ gAgent.getSecureSessionID().asString());
+ keywordArgs.appendString("language", LLUI::getLanguage());
+ keywordArgs.appendInt("currencyBuy", mUserCurrencyBuy);
+ keywordArgs.appendString("viewerChannel", LLVersionInfo::instance().getChannel());
+ keywordArgs.appendInt("viewerMajorVersion", LLVersionInfo::instance().getMajor());
+ keywordArgs.appendInt("viewerMinorVersion", LLVersionInfo::instance().getMinor());
+ keywordArgs.appendInt("viewerPatchVersion", LLVersionInfo::instance().getPatch());
+ // With GitHub builds, the build number is too big to fit in a 32-bit int,
+ // and XMLRPC_VALUE doesn't deal with integers wider than int. Use string.
+ keywordArgs.appendString("viewerBuildVersion", stringize(LLVersionInfo::instance().getBuild()));
+
+ LLXMLRPCValue params = LLXMLRPCValue::createArray();
+ params.append(keywordArgs);
+
+ startTransaction(TransactionCurrency, "getCurrencyQuote", params);
}
void LLCurrencyUIManager::Impl::finishCurrencyInfo()
{
- LLXMLRPCValue result = mTransaction->responseValue();
-
- bool success = result["success"].asBool();
- if (!success)
- {
- setError(
- result["errorMessage"].asString(),
- result["errorURI"].asString()
- );
- return;
- }
-
- LLXMLRPCValue currency = result["currency"];
-
- // old XML-RPC server: estimatedCost = value in US cents
- mUSDCurrencyEstimated = currency["estimatedCost"].isValid();
- if (mUSDCurrencyEstimated)
- {
- mUSDCurrencyEstimatedCost = currency["estimatedCost"].asInt();
- }
-
- // newer XML-RPC server: estimatedLocalCost = local currency string
- mLocalCurrencyEstimated = currency["estimatedLocalCost"].isValid();
- if (mLocalCurrencyEstimated)
- {
- mLocalCurrencyEstimatedCost = currency["estimatedLocalCost"].asString();
- mSupportsInternationalBilling = true;
- }
-
- S32 newCurrencyBuy = currency["currencyBuy"].asInt();
- if (newCurrencyBuy != mUserCurrencyBuy)
- {
- mUserCurrencyBuy = newCurrencyBuy;
- mUserEnteredCurrencyBuy = false;
- }
-
- mSiteConfirm = result["confirm"].asString();
+ LLXMLRPCValue result = mTransaction->responseValue();
+
+ bool success = result["success"].asBool();
+ if (!success)
+ {
+ setError(
+ result["errorMessage"].asString(),
+ result["errorURI"].asString()
+ );
+ return;
+ }
+
+ LLXMLRPCValue currency = result["currency"];
+
+ // old XML-RPC server: estimatedCost = value in US cents
+ mUSDCurrencyEstimated = currency["estimatedCost"].isValid();
+ if (mUSDCurrencyEstimated)
+ {
+ mUSDCurrencyEstimatedCost = currency["estimatedCost"].asInt();
+ }
+
+ // newer XML-RPC server: estimatedLocalCost = local currency string
+ mLocalCurrencyEstimated = currency["estimatedLocalCost"].isValid();
+ if (mLocalCurrencyEstimated)
+ {
+ mLocalCurrencyEstimatedCost = currency["estimatedLocalCost"].asString();
+ mSupportsInternationalBilling = true;
+ }
+
+ S32 newCurrencyBuy = currency["currencyBuy"].asInt();
+ if (newCurrencyBuy != mUserCurrencyBuy)
+ {
+ mUserCurrencyBuy = newCurrencyBuy;
+ mUserEnteredCurrencyBuy = false;
+ }
+
+ mSiteConfirm = result["confirm"].asString();
}
void LLCurrencyUIManager::Impl::startCurrencyBuy(const std::string& password)
{
- LLXMLRPCValue keywordArgs = LLXMLRPCValue::createStruct();
- keywordArgs.appendString("agentId", gAgent.getID().asString());
- keywordArgs.appendString(
- "secureSessionId",
- gAgent.getSecureSessionID().asString());
- keywordArgs.appendString("language", LLUI::getLanguage());
- keywordArgs.appendInt("currencyBuy", mUserCurrencyBuy);
- if (mUSDCurrencyEstimated)
- {
- keywordArgs.appendInt("estimatedCost", mUSDCurrencyEstimatedCost);
- }
- if (mLocalCurrencyEstimated)
- {
- keywordArgs.appendString("estimatedLocalCost", mLocalCurrencyEstimatedCost);
- }
- keywordArgs.appendString("confirm", mSiteConfirm);
- if (!password.empty())
- {
- keywordArgs.appendString("password", password);
- }
- keywordArgs.appendString("viewerChannel", LLVersionInfo::instance().getChannel());
- keywordArgs.appendInt("viewerMajorVersion", LLVersionInfo::instance().getMajor());
- keywordArgs.appendInt("viewerMinorVersion", LLVersionInfo::instance().getMinor());
- keywordArgs.appendInt("viewerPatchVersion", LLVersionInfo::instance().getPatch());
- // With GitHub builds, the build number is too big to fit in a 32-bit int,
- // and XMLRPC_VALUE doesn't deal with integers wider than int. Use string.
- keywordArgs.appendString("viewerBuildVersion", stringize(LLVersionInfo::instance().getBuild()));
-
- LLXMLRPCValue params = LLXMLRPCValue::createArray();
- params.append(keywordArgs);
-
- startTransaction(TransactionBuy, "buyCurrency", params);
-
- clearEstimate();
- mCurrencyChanged = false;
+ LLXMLRPCValue keywordArgs = LLXMLRPCValue::createStruct();
+ keywordArgs.appendString("agentId", gAgent.getID().asString());
+ keywordArgs.appendString(
+ "secureSessionId",
+ gAgent.getSecureSessionID().asString());
+ keywordArgs.appendString("language", LLUI::getLanguage());
+ keywordArgs.appendInt("currencyBuy", mUserCurrencyBuy);
+ if (mUSDCurrencyEstimated)
+ {
+ keywordArgs.appendInt("estimatedCost", mUSDCurrencyEstimatedCost);
+ }
+ if (mLocalCurrencyEstimated)
+ {
+ keywordArgs.appendString("estimatedLocalCost", mLocalCurrencyEstimatedCost);
+ }
+ keywordArgs.appendString("confirm", mSiteConfirm);
+ if (!password.empty())
+ {
+ keywordArgs.appendString("password", password);
+ }
+ keywordArgs.appendString("viewerChannel", LLVersionInfo::instance().getChannel());
+ keywordArgs.appendInt("viewerMajorVersion", LLVersionInfo::instance().getMajor());
+ keywordArgs.appendInt("viewerMinorVersion", LLVersionInfo::instance().getMinor());
+ keywordArgs.appendInt("viewerPatchVersion", LLVersionInfo::instance().getPatch());
+ // With GitHub builds, the build number is too big to fit in a 32-bit int,
+ // and XMLRPC_VALUE doesn't deal with integers wider than int. Use string.
+ keywordArgs.appendString("viewerBuildVersion", stringize(LLVersionInfo::instance().getBuild()));
+
+ LLXMLRPCValue params = LLXMLRPCValue::createArray();
+ params.append(keywordArgs);
+
+ startTransaction(TransactionBuy, "buyCurrency", params);
+
+ clearEstimate();
+ mCurrencyChanged = false;
}
void LLCurrencyUIManager::Impl::finishCurrencyBuy()
{
- LLXMLRPCValue result = mTransaction->responseValue();
+ LLXMLRPCValue result = mTransaction->responseValue();
- bool success = result["success"].asBool();
- if (!success)
- {
- setError(
- result["errorMessage"].asString(),
- result["errorURI"].asString()
- );
- }
- else
- {
- mUserCurrencyBuy = 0;
- mUserEnteredCurrencyBuy = false;
- mBought = true;
- }
+ bool success = result["success"].asBool();
+ if (!success)
+ {
+ setError(
+ result["errorMessage"].asString(),
+ result["errorURI"].asString()
+ );
+ }
+ else
+ {
+ mUserCurrencyBuy = 0;
+ mUserEnteredCurrencyBuy = false;
+ mBought = true;
+ }
}
void LLCurrencyUIManager::Impl::startTransaction(TransactionType type,
- const char* method, LLXMLRPCValue params)
+ const char* method, LLXMLRPCValue params)
{
- static std::string transactionURI;
- if (transactionURI.empty())
- {
- transactionURI = LLGridManager::getInstance()->getHelperURI() + "currency.php";
- }
+ static std::string transactionURI;
+ if (transactionURI.empty())
+ {
+ transactionURI = LLGridManager::getInstance()->getHelperURI() + "currency.php";
+ }
- delete mTransaction;
+ delete mTransaction;
- mTransactionType = type;
- mTransaction = new LLXMLRPCTransaction(
- transactionURI,
- method,
- params,
- false /* don't use gzip */
- );
+ mTransactionType = type;
+ mTransaction = new LLXMLRPCTransaction(
+ transactionURI,
+ method,
+ params,
+ false /* don't use gzip */
+ );
- clearError();
+ clearError();
}
void LLCurrencyUIManager::Impl::clearEstimate()
{
- mUSDCurrencyEstimated = false;
- mUSDCurrencyEstimatedCost = 0;
- mLocalCurrencyEstimated = false;
- mLocalCurrencyEstimatedCost = "0";
+ mUSDCurrencyEstimated = false;
+ mUSDCurrencyEstimatedCost = 0;
+ mLocalCurrencyEstimated = false;
+ mLocalCurrencyEstimatedCost = "0";
}
bool LLCurrencyUIManager::Impl::hasEstimate() const
{
- return (mUSDCurrencyEstimated || mLocalCurrencyEstimated);
+ return (mUSDCurrencyEstimated || mLocalCurrencyEstimated);
}
std::string LLCurrencyUIManager::Impl::getLocalEstimate() const
{
- if (mLocalCurrencyEstimated)
- {
- // we have the new-style local currency string
- return mLocalCurrencyEstimatedCost;
- }
- if (mUSDCurrencyEstimated)
- {
- // we have the old-style USD-specific value
- LLStringUtil::format_map_t args;
- {
- LLLocale locale_override(LLStringUtil::getLocale());
- args["[AMOUNT]"] = llformat("%#.2f", mUSDCurrencyEstimatedCost / 100.0);
- }
- return LLTrans::getString("LocalEstimateUSD", args);
- }
- return "";
+ if (mLocalCurrencyEstimated)
+ {
+ // we have the new-style local currency string
+ return mLocalCurrencyEstimatedCost;
+ }
+ if (mUSDCurrencyEstimated)
+ {
+ // we have the old-style USD-specific value
+ LLStringUtil::format_map_t args;
+ {
+ LLLocale locale_override(LLStringUtil::getLocale());
+ args["[AMOUNT]"] = llformat("%#.2f", mUSDCurrencyEstimatedCost / 100.0);
+ }
+ return LLTrans::getString("LocalEstimateUSD", args);
+ }
+ return "";
}
bool LLCurrencyUIManager::Impl::checkTransaction()
{
- if (!mTransaction)
- {
- return false;
- }
-
- if (!mTransaction->process())
- {
- return false;
- }
-
- if (mTransaction->status(NULL) != LLXMLRPCTransaction::StatusComplete)
- {
- setError(mTransaction->statusMessage(), mTransaction->statusURI());
- }
- else {
- switch (mTransactionType)
- {
- case TransactionCurrency: finishCurrencyInfo(); break;
- case TransactionBuy: finishCurrencyBuy(); break;
- default: ;
- }
- }
-
- delete mTransaction;
- mTransaction = NULL;
- mTransactionType = TransactionNone;
-
- return true;
+ if (!mTransaction)
+ {
+ return false;
+ }
+
+ if (!mTransaction->process())
+ {
+ return false;
+ }
+
+ if (mTransaction->status(NULL) != LLXMLRPCTransaction::StatusComplete)
+ {
+ setError(mTransaction->statusMessage(), mTransaction->statusURI());
+ }
+ else {
+ switch (mTransactionType)
+ {
+ case TransactionCurrency: finishCurrencyInfo(); break;
+ case TransactionBuy: finishCurrencyBuy(); break;
+ default: ;
+ }
+ }
+
+ delete mTransaction;
+ mTransaction = NULL;
+ mTransactionType = TransactionNone;
+
+ return true;
}
void LLCurrencyUIManager::Impl::setError(
- const std::string& message, const std::string& uri)
+ const std::string& message, const std::string& uri)
{
- mError = true;
- mErrorMessage = message;
- mErrorURI = uri;
+ mError = true;
+ mErrorMessage = message;
+ mErrorURI = uri;
}
void LLCurrencyUIManager::Impl::clearError()
{
- mError = false;
- mErrorMessage.clear();
- mErrorURI.clear();
+ mError = false;
+ mErrorMessage.clear();
+ mErrorURI.clear();
}
bool LLCurrencyUIManager::Impl::considerUpdateCurrency()
{
- if (mCurrencyChanged
- && !mTransaction
- && mCurrencyKeyTimer.getElapsedTimeF32() >= CURRENCY_ESTIMATE_FREQUENCY)
- {
- updateCurrencyInfo();
- return true;
- }
+ if (mCurrencyChanged
+ && !mTransaction
+ && mCurrencyKeyTimer.getElapsedTimeF32() >= CURRENCY_ESTIMATE_FREQUENCY)
+ {
+ updateCurrencyInfo();
+ return true;
+ }
- return false;
+ return false;
}
void LLCurrencyUIManager::Impl::currencyKey(S32 value)
{
- mUserEnteredCurrencyBuy = true;
- mCurrencyKeyTimer.reset();
+ mUserEnteredCurrencyBuy = true;
+ mCurrencyKeyTimer.reset();
+
+ if (mUserCurrencyBuy == value)
+ {
+ return;
+ }
+
+ mUserCurrencyBuy = value;
+
+ if (hasEstimate()) {
+ clearEstimate();
+ //cannot just simply refresh the whole UI, as the edit field will
+ // get reset and the cursor will change...
- if (mUserCurrencyBuy == value)
- {
- return;
- }
+ mPanel.getChildView("currency_est")->setVisible(FALSE);
+ mPanel.getChildView("getting_data")->setVisible(TRUE);
+ }
- mUserCurrencyBuy = value;
-
- if (hasEstimate()) {
- clearEstimate();
- //cannot just simply refresh the whole UI, as the edit field will
- // get reset and the cursor will change...
-
- mPanel.getChildView("currency_est")->setVisible(FALSE);
- mPanel.getChildView("getting_data")->setVisible(TRUE);
- }
-
- mCurrencyChanged = true;
+ mCurrencyChanged = true;
}
// static
void LLCurrencyUIManager::Impl::onCurrencyKey(
- LLLineEditor* caller, void* data)
+ LLLineEditor* caller, void* data)
{
- S32 value = atoi(caller->getText().c_str());
- LLCurrencyUIManager::Impl* self = (LLCurrencyUIManager::Impl*)data;
- self->currencyKey(value);
+ S32 value = atoi(caller->getText().c_str());
+ LLCurrencyUIManager::Impl* self = (LLCurrencyUIManager::Impl*)data;
+ self->currencyKey(value);
}
void LLCurrencyUIManager::Impl::prepare()
{
- LLLineEditor* lindenAmount = mPanel.getChild<LLLineEditor>("currency_amt");
- if (lindenAmount)
- {
- lindenAmount->setPrevalidate(LLTextValidate::validateNonNegativeS32);
- lindenAmount->setKeystrokeCallback(onCurrencyKey, this);
- }
+ LLLineEditor* lindenAmount = mPanel.getChild<LLLineEditor>("currency_amt");
+ if (lindenAmount)
+ {
+ lindenAmount->setPrevalidate(LLTextValidate::validateNonNegativeS32);
+ lindenAmount->setKeystrokeCallback(onCurrencyKey, this);
+ }
}
void LLCurrencyUIManager::Impl::updateUI()
{
- if (mHidden)
- {
- mPanel.getChildView("currency_action")->setVisible(FALSE);
- mPanel.getChildView("currency_amt")->setVisible(FALSE);
- mPanel.getChildView("currency_est")->setVisible(FALSE);
- return;
- }
-
- mPanel.getChildView("currency_action")->setVisible(TRUE);
-
- LLLineEditor* lindenAmount = mPanel.getChild<LLLineEditor>("currency_amt");
- if (lindenAmount)
- {
- lindenAmount->setVisible(true);
- lindenAmount->setLabel(mZeroMessage);
-
- if (!mUserEnteredCurrencyBuy)
- {
- if (mUserCurrencyBuy == 0)
- {
- lindenAmount->setText(LLStringUtil::null);
- }
- else
- {
- lindenAmount->setText(llformat("%d", mUserCurrencyBuy));
- }
-
- lindenAmount->selectAll();
- }
- }
-
- std::string estimated = (mUserCurrencyBuy == 0) ? mPanel.getString("estimated_zero") : getLocalEstimate();
- mPanel.getChild<LLUICtrl>("currency_est")->setTextArg("[LOCALAMOUNT]", estimated);
- mPanel.getChildView("currency_est")->setVisible( hasEstimate() || mUserCurrencyBuy == 0);
-
- mPanel.getChildView("currency_links")->setVisible( mSupportsInternationalBilling);
- mPanel.getChildView("exchange_rate_note")->setVisible( mSupportsInternationalBilling);
-
- if (mPanel.getChildView("buy_btn")->getEnabled()
- ||mPanel.getChildView("currency_est")->getVisible()
- || mPanel.getChildView("error_web")->getVisible())
- {
- mPanel.getChildView("getting_data")->setVisible(FALSE);
- }
+ if (mHidden)
+ {
+ mPanel.getChildView("currency_action")->setVisible(FALSE);
+ mPanel.getChildView("currency_amt")->setVisible(FALSE);
+ mPanel.getChildView("currency_est")->setVisible(FALSE);
+ return;
+ }
+
+ mPanel.getChildView("currency_action")->setVisible(TRUE);
+
+ LLLineEditor* lindenAmount = mPanel.getChild<LLLineEditor>("currency_amt");
+ if (lindenAmount)
+ {
+ lindenAmount->setVisible(true);
+ lindenAmount->setLabel(mZeroMessage);
+
+ if (!mUserEnteredCurrencyBuy)
+ {
+ if (mUserCurrencyBuy == 0)
+ {
+ lindenAmount->setText(LLStringUtil::null);
+ }
+ else
+ {
+ lindenAmount->setText(llformat("%d", mUserCurrencyBuy));
+ }
+
+ lindenAmount->selectAll();
+ }
+ }
+
+ std::string estimated = (mUserCurrencyBuy == 0) ? mPanel.getString("estimated_zero") : getLocalEstimate();
+ mPanel.getChild<LLUICtrl>("currency_est")->setTextArg("[LOCALAMOUNT]", estimated);
+ mPanel.getChildView("currency_est")->setVisible( hasEstimate() || mUserCurrencyBuy == 0);
+
+ mPanel.getChildView("currency_links")->setVisible( mSupportsInternationalBilling);
+ mPanel.getChildView("exchange_rate_note")->setVisible( mSupportsInternationalBilling);
+
+ if (mPanel.getChildView("buy_btn")->getEnabled()
+ ||mPanel.getChildView("currency_est")->getVisible()
+ || mPanel.getChildView("error_web")->getVisible())
+ {
+ mPanel.getChildView("getting_data")->setVisible(FALSE);
+ }
}
LLCurrencyUIManager::LLCurrencyUIManager(LLPanel& dialog)
- : impl(* new Impl(dialog))
+ : impl(* new Impl(dialog))
{
}
LLCurrencyUIManager::~LLCurrencyUIManager()
{
- delete &impl;
+ delete &impl;
}
void LLCurrencyUIManager::setAmount(int amount, bool noEstimate)
{
- impl.mUserCurrencyBuy = amount;
- impl.mUserEnteredCurrencyBuy = false;
- impl.updateUI();
-
- impl.mCurrencyChanged = !noEstimate;
+ impl.mUserCurrencyBuy = amount;
+ impl.mUserEnteredCurrencyBuy = false;
+ impl.updateUI();
+
+ impl.mCurrencyChanged = !noEstimate;
}
int LLCurrencyUIManager::getAmount()
{
- return impl.mUserCurrencyBuy;
+ return impl.mUserCurrencyBuy;
}
void LLCurrencyUIManager::setZeroMessage(const std::string& message)
{
- impl.mZeroMessage = message;
+ impl.mZeroMessage = message;
}
void LLCurrencyUIManager::setUSDEstimate(int amount)
{
- impl.mUSDCurrencyEstimatedCost = amount;
- impl.mUSDCurrencyEstimated = true;
- impl.updateUI();
-
- impl.mCurrencyChanged = false;
+ impl.mUSDCurrencyEstimatedCost = amount;
+ impl.mUSDCurrencyEstimated = true;
+ impl.updateUI();
+
+ impl.mCurrencyChanged = false;
}
int LLCurrencyUIManager::getUSDEstimate()
{
- return impl.mUSDCurrencyEstimated ? impl.mUSDCurrencyEstimatedCost : 0;
+ return impl.mUSDCurrencyEstimated ? impl.mUSDCurrencyEstimatedCost : 0;
}
void LLCurrencyUIManager::setLocalEstimate(const std::string &amount)
{
- impl.mLocalCurrencyEstimatedCost = amount;
- impl.mLocalCurrencyEstimated = true;
- impl.updateUI();
-
- impl.mCurrencyChanged = false;
+ impl.mLocalCurrencyEstimatedCost = amount;
+ impl.mLocalCurrencyEstimated = true;
+ impl.updateUI();
+
+ impl.mCurrencyChanged = false;
}
std::string LLCurrencyUIManager::getLocalEstimate() const
{
- return impl.getLocalEstimate();
+ return impl.getLocalEstimate();
}
void LLCurrencyUIManager::prepare()
{
- impl.prepare();
+ impl.prepare();
}
void LLCurrencyUIManager::updateUI(bool show)
{
- impl.mHidden = !show;
- impl.updateUI();
+ impl.mHidden = !show;
+ impl.updateUI();
}
bool LLCurrencyUIManager::process()
{
- bool changed = false;
- changed |= impl.checkTransaction();
- changed |= impl.considerUpdateCurrency();
- return changed;
+ bool changed = false;
+ changed |= impl.checkTransaction();
+ changed |= impl.considerUpdateCurrency();
+ return changed;
}
void LLCurrencyUIManager::buy(const std::string& buy_msg)
{
- if (!canBuy())
- {
- return;
- }
+ if (!canBuy())
+ {
+ return;
+ }
- LLUIString msg = buy_msg;
- msg.setArg("[LINDENS]", llformat("%d", impl.mUserCurrencyBuy));
- msg.setArg("[LOCALAMOUNT]", getLocalEstimate());
- LLConfirmationManager::confirm(impl.mSiteConfirm,
- msg,
- impl,
- &LLCurrencyUIManager::Impl::startCurrencyBuy);
+ LLUIString msg = buy_msg;
+ msg.setArg("[LINDENS]", llformat("%d", impl.mUserCurrencyBuy));
+ msg.setArg("[LOCALAMOUNT]", getLocalEstimate());
+ LLConfirmationManager::confirm(impl.mSiteConfirm,
+ msg,
+ impl,
+ &LLCurrencyUIManager::Impl::startCurrencyBuy);
}
bool LLCurrencyUIManager::inProcess()
{
- return impl.mTransactionType != Impl::TransactionNone;
+ return impl.mTransactionType != Impl::TransactionNone;
}
bool LLCurrencyUIManager::canCancel()
{
- return impl.mTransactionType != Impl::TransactionBuy;
+ return impl.mTransactionType != Impl::TransactionBuy;
}
bool LLCurrencyUIManager::canBuy()
{
- return impl.mTransactionType == Impl::TransactionNone
- && impl.hasEstimate()
- && impl.mUserCurrencyBuy > 0;
+ return impl.mTransactionType == Impl::TransactionNone
+ && impl.hasEstimate()
+ && impl.mUserCurrencyBuy > 0;
}
bool LLCurrencyUIManager::buying()
{
- return impl.mTransactionType == Impl::TransactionBuy;
+ return impl.mTransactionType == Impl::TransactionBuy;
}
bool LLCurrencyUIManager::bought()
{
- return impl.mBought;
+ return impl.mBought;
}
void LLCurrencyUIManager::clearError()
{
- impl.clearError();
+ impl.clearError();
}
bool LLCurrencyUIManager::hasError()
{
- return impl.mError;
+ return impl.mError;
}
std::string LLCurrencyUIManager::errorMessage()
{
- return impl.mErrorMessage;
+ return impl.mErrorMessage;
}
std::string LLCurrencyUIManager::errorURI()
{
- return impl.mErrorURI;
+ return impl.mErrorURI;
}