Automated merge up from viewer-development
commit
61e3c95dbf
21
build.sh
21
build.sh
|
|
@ -170,13 +170,7 @@ do
|
|||
mkdir -p "$build_dir"
|
||||
if pre_build "$variant" "$build_dir" >> "$build_log" 2>&1
|
||||
then
|
||||
if $build_link_parallel
|
||||
then
|
||||
begin_section BuildParallel
|
||||
( build "$variant" "$build_dir" > "$build_dir/build.log" 2>&1 ) &
|
||||
build_processes="$build_processes $!"
|
||||
end_section BuildParallel
|
||||
elif $build_coverity
|
||||
if $build_coverity
|
||||
then
|
||||
mkdir -p "$build_dir/cvbuild"
|
||||
coverity_config=`cygpath --windows "$coverity_dir/config/coverity_config.xml"`
|
||||
|
|
@ -198,7 +192,6 @@ do
|
|||
begin_section CovAnalyze\
|
||||
&&\
|
||||
"$coverity_dir"/bin/cov-analyze\
|
||||
--cxx\
|
||||
--security\
|
||||
--concurrency\
|
||||
--dir "$coverity_tmpdir"\
|
||||
|
|
@ -209,14 +202,14 @@ do
|
|||
begin_section CovCommit\
|
||||
&&\
|
||||
"$coverity_dir"/bin/cov-commit-defects\
|
||||
--product "$coverity_product"\
|
||||
--stream "$coverity_product"\
|
||||
--dir "$coverity_tmpdir"\
|
||||
--remote "$coverity_server"\
|
||||
--host "$coverity_server"\
|
||||
--strip-path "$coverity_root"\
|
||||
--target "$branch/$arch"\
|
||||
--version "$revision"\
|
||||
--description "$repo: $variant $revision"\
|
||||
--user admin --password admin\
|
||||
--user admin --password coverity\
|
||||
>> "$build_log" 2>&1\
|
||||
|| record_failure "Coverity Build Failed"
|
||||
# since any step could have failed, rely on the enclosing block to close any pending sub-blocks
|
||||
|
|
@ -227,6 +220,12 @@ do
|
|||
then
|
||||
upload_item log "$build_dir"/cvbuild/build-log.txt text/plain
|
||||
fi
|
||||
elif $build_link_parallel
|
||||
then
|
||||
begin_section BuildParallel
|
||||
( build "$variant" "$build_dir" > "$build_dir/build.log" 2>&1 ) &
|
||||
build_processes="$build_processes $!"
|
||||
end_section BuildParallel
|
||||
else
|
||||
begin_section "Build$variant"
|
||||
build "$variant" "$build_dir" >> "$build_log" 2>&1
|
||||
|
|
|
|||
|
|
@ -372,6 +372,7 @@ Jonathan Yap
|
|||
STORM-679
|
||||
STORM-737
|
||||
STORM-726
|
||||
STORM-812
|
||||
VWR-17801
|
||||
STORM-785
|
||||
Kage Pixel
|
||||
|
|
|
|||
|
|
@ -417,6 +417,7 @@ set(viewer_SOURCE_FILES
|
|||
llsecapi.cpp
|
||||
llsechandler_basic.cpp
|
||||
llselectmgr.cpp
|
||||
llshareavatarhandler.cpp
|
||||
llsidepanelappearance.cpp
|
||||
llsidepanelinventory.cpp
|
||||
llsidepanelinventorysubpanel.cpp
|
||||
|
|
@ -558,6 +559,7 @@ set(viewer_SOURCE_FILES
|
|||
llvoclouds.cpp
|
||||
llvograss.cpp
|
||||
llvoground.cpp
|
||||
llvoicecallhandler.cpp
|
||||
llvoicechannel.cpp
|
||||
llvoiceclient.cpp
|
||||
llvoicevisualizer.cpp
|
||||
|
|
@ -1888,29 +1890,29 @@ if (PACKAGE)
|
|||
endif (LINUX)
|
||||
|
||||
if(RELEASE_CRASH_REPORTING OR NON_RELEASE_CRASH_REPORTING)
|
||||
if(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
if(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
set(LLBUILD_CONFIG ${CMAKE_BUILD_TYPE})
|
||||
else(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
else(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
# set LLBUILD_CONFIG to be a shell variable evaluated at build time
|
||||
# reflecting the configuration we are currently building.
|
||||
set(LLBUILD_CONFIG ${CMAKE_CFG_INTDIR})
|
||||
endif(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
add_custom_command(OUTPUT "${VIEWER_SYMBOL_FILE}"
|
||||
COMMAND "${PYTHON_EXECUTABLE}"
|
||||
ARGS
|
||||
"${CMAKE_CURRENT_SOURCE_DIR}/generate_breakpad_symbols.py"
|
||||
"${LLBUILD_CONFIG}"
|
||||
"${VIEWER_DIST_DIR}"
|
||||
"${VIEWER_EXE_GLOBS}"
|
||||
"${VIEWER_LIB_GLOB}"
|
||||
"${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/bin/dump_syms"
|
||||
"${VIEWER_SYMBOL_FILE}"
|
||||
DEPENDS generate_breakpad_symbols.py
|
||||
endif(CMAKE_CFG_INTDIR STREQUAL ".")
|
||||
add_custom_command(OUTPUT "${VIEWER_SYMBOL_FILE}"
|
||||
COMMAND "${PYTHON_EXECUTABLE}"
|
||||
ARGS
|
||||
"${CMAKE_CURRENT_SOURCE_DIR}/generate_breakpad_symbols.py"
|
||||
"${LLBUILD_CONFIG}"
|
||||
"${VIEWER_DIST_DIR}"
|
||||
"${VIEWER_EXE_GLOBS}"
|
||||
"${VIEWER_LIB_GLOB}"
|
||||
"${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/bin/dump_syms"
|
||||
"${VIEWER_SYMBOL_FILE}"
|
||||
DEPENDS generate_breakpad_symbols.py
|
||||
VERBATIM)
|
||||
|
||||
add_custom_target(generate_breakpad_symbols DEPENDS "${VIEWER_SYMBOL_FILE}")
|
||||
add_dependencies(generate_breakpad_symbols "${VIEWER_BINARY_NAME}" "${VIEWER_COPY_MANIFEST}")
|
||||
add_dependencies(package generate_breakpad_symbols)
|
||||
add_custom_target(generate_breakpad_symbols DEPENDS "${VIEWER_SYMBOL_FILE}")
|
||||
add_dependencies(generate_breakpad_symbols "${VIEWER_BINARY_NAME}" "${VIEWER_COPY_MANIFEST}")
|
||||
add_dependencies(package generate_breakpad_symbols)
|
||||
endif(RELEASE_CRASH_REPORTING OR NON_RELEASE_CRASH_REPORTING)
|
||||
endif (PACKAGE)
|
||||
|
||||
|
|
|
|||
|
|
@ -3992,6 +3992,17 @@
|
|||
<key>Value</key>
|
||||
<string>http://search.secondlife.com/viewer/[CATEGORY]/?q=[QUERY]&p=[AUTH_TOKEN]&r=[MATURITY]&lang=[LANGUAGE]&g=[GODLIKE]&sid=[SESSION_ID]&rid=[REGION_ID]&pid=[PARCEL_ID]&channel=[CHANNEL]&version=[VERSION]&major=[VERSION_MAJOR]&minor=[VERSION_MINOR]&patch=[VERSION_PATCH]&build=[VERSION_BUILD]</string>
|
||||
</map>
|
||||
<key>WebProfileURL</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>URL for Web Profiles</string>
|
||||
<key>Persist</key>
|
||||
<integer>0</integer>
|
||||
<key>Type</key>
|
||||
<string>String</string>
|
||||
<key>Value</key>
|
||||
<string>https://my.secondlife.com/[AGENT_NAME]</string>
|
||||
</map>
|
||||
<key>HighResSnapshot</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
|
|
|
|||
|
|
@ -218,7 +218,10 @@ LLAgent::LLAgent() :
|
|||
mFirstLogin(FALSE),
|
||||
mGenderChosen(FALSE),
|
||||
|
||||
mAppearanceSerialNum(0)
|
||||
mAppearanceSerialNum(0),
|
||||
|
||||
mMouselookModeInSignal(NULL),
|
||||
mMouselookModeOutSignal(NULL)
|
||||
{
|
||||
for (U32 i = 0; i < TOTAL_CONTROLS; i++)
|
||||
{
|
||||
|
|
@ -269,6 +272,9 @@ LLAgent::~LLAgent()
|
|||
{
|
||||
cleanup();
|
||||
|
||||
delete mMouselookModeInSignal;
|
||||
delete mMouselookModeOutSignal;
|
||||
|
||||
// *Note: this is where LLViewerCamera::getInstance() used to be deleted.
|
||||
}
|
||||
|
||||
|
|
@ -1735,6 +1741,11 @@ void LLAgent::endAnimationUpdateUI()
|
|||
|
||||
LLFloaterCamera::onLeavingMouseLook();
|
||||
|
||||
if (mMouselookModeOutSignal)
|
||||
{
|
||||
(*mMouselookModeOutSignal)();
|
||||
}
|
||||
|
||||
// Only pop if we have pushed...
|
||||
if (TRUE == mViewsPushed)
|
||||
{
|
||||
|
|
@ -1840,6 +1851,11 @@ void LLAgent::endAnimationUpdateUI()
|
|||
|
||||
mViewsPushed = TRUE;
|
||||
|
||||
if (mMouselookModeInSignal)
|
||||
{
|
||||
(*mMouselookModeInSignal)();
|
||||
}
|
||||
|
||||
// hide all floaters except the mini map
|
||||
|
||||
#if 0 // Use this once all floaters are registered
|
||||
|
|
@ -1899,7 +1915,6 @@ void LLAgent::endAnimationUpdateUI()
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
else if (gAgentCamera.getCameraMode() == CAMERA_MODE_CUSTOMIZE_AVATAR)
|
||||
{
|
||||
|
|
@ -1931,6 +1946,18 @@ void LLAgent::endAnimationUpdateUI()
|
|||
gAgentCamera.updateLastCamera();
|
||||
}
|
||||
|
||||
boost::signals2::connection LLAgent::setMouselookModeInCallback( const camera_signal_t::slot_type& cb )
|
||||
{
|
||||
if (!mMouselookModeInSignal) mMouselookModeInSignal = new camera_signal_t();
|
||||
return mMouselookModeInSignal->connect(cb);
|
||||
}
|
||||
|
||||
boost::signals2::connection LLAgent::setMouselookModeOutCallback( const camera_signal_t::slot_type& cb )
|
||||
{
|
||||
if (!mMouselookModeOutSignal) mMouselookModeOutSignal = new camera_signal_t();
|
||||
return mMouselookModeOutSignal->connect(cb);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// heardChat()
|
||||
//-----------------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -39,6 +39,8 @@
|
|||
#include "llvoavatardefines.h"
|
||||
#include "llslurl.h"
|
||||
|
||||
#include <boost/signals2.hpp>
|
||||
|
||||
extern const BOOL ANIMATE;
|
||||
extern const U8 AGENT_STATE_TYPING; // Typing indication
|
||||
extern const U8 AGENT_STATE_EDITING; // Set when agent has objects selected
|
||||
|
|
@ -410,7 +412,13 @@ public:
|
|||
BOOL getCustomAnim() const { return mCustomAnim; }
|
||||
void setCustomAnim(BOOL anim) { mCustomAnim = anim; }
|
||||
|
||||
typedef boost::signals2::signal<void ()> camera_signal_t;
|
||||
boost::signals2::connection setMouselookModeInCallback( const camera_signal_t::slot_type& cb );
|
||||
boost::signals2::connection setMouselookModeOutCallback( const camera_signal_t::slot_type& cb );
|
||||
|
||||
private:
|
||||
camera_signal_t* mMouselookModeInSignal;
|
||||
camera_signal_t* mMouselookModeOutSignal;
|
||||
BOOL mCustomAnim; // Current animation is ANIM_AGENT_CUSTOMIZE ?
|
||||
LLAnimPauseRequest mPauseRequest;
|
||||
BOOL mViewsPushed; // Keep track of whether or not we have pushed views
|
||||
|
|
|
|||
|
|
@ -56,9 +56,11 @@
|
|||
#include "llmutelist.h"
|
||||
#include "llnotificationsutil.h" // for LLNotificationsUtil
|
||||
#include "llpaneloutfitedit.h"
|
||||
#include "llpanelprofile.h"
|
||||
#include "llrecentpeople.h"
|
||||
#include "llsidetray.h"
|
||||
#include "lltrans.h"
|
||||
#include "llviewercontrol.h"
|
||||
#include "llviewerobjectlist.h"
|
||||
#include "llviewermessage.h" // for handle_lure
|
||||
#include "llviewerregion.h"
|
||||
|
|
@ -306,6 +308,20 @@ void LLAvatarActions::showProfile(const LLUUID& id)
|
|||
params["id"] = id;
|
||||
params["open_tab_name"] = "panel_profile";
|
||||
|
||||
// PROFILES: open in webkit window
|
||||
std::string full_name;
|
||||
if (gCacheName->getFullName(id,full_name))
|
||||
{
|
||||
std::string agent_name = LLCacheName::buildUsername(full_name);
|
||||
llinfos << "opening web profile for " << agent_name << llendl;
|
||||
std::string url = getProfileURL(agent_name);
|
||||
LLWeb::loadWebURLInternal(url);
|
||||
}
|
||||
else
|
||||
{
|
||||
llwarns << "no name info for agent id " << id << llendl;
|
||||
}
|
||||
#if 0
|
||||
//Show own profile
|
||||
if(gAgent.getID() == id)
|
||||
{
|
||||
|
|
@ -316,6 +332,7 @@ void LLAvatarActions::showProfile(const LLUUID& id)
|
|||
{
|
||||
LLSideTray::getInstance()->showPanel("panel_profile_view", params);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -286,6 +286,7 @@ LLFloaterPreference::LLFloaterPreference(const LLSD& key)
|
|||
mLanguageChanged(false),
|
||||
mDoubleClickActionDirty(false)
|
||||
{
|
||||
|
||||
//Build Floater is now Called from LLFloaterReg::add("preferences", "floater_preferences.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterPreference>);
|
||||
|
||||
static bool registered_dialog = false;
|
||||
|
|
@ -322,16 +323,61 @@ LLFloaterPreference::LLFloaterPreference(const LLSD& key)
|
|||
mCommitCallbackRegistrar.add("Pref.getUIColor", boost::bind(&LLFloaterPreference::getUIColor, this ,_1, _2));
|
||||
mCommitCallbackRegistrar.add("Pref.MaturitySettings", boost::bind(&LLFloaterPreference::onChangeMaturity, this));
|
||||
mCommitCallbackRegistrar.add("Pref.BlockList", boost::bind(&LLFloaterPreference::onClickBlockList, this));
|
||||
|
||||
sSkin = gSavedSettings.getString("SkinCurrent");
|
||||
|
||||
mCommitCallbackRegistrar.add("Pref.CommitDoubleClickChekbox", boost::bind(&LLFloaterPreference::onDoubleClickCheckBox, this, _1));
|
||||
mCommitCallbackRegistrar.add("Pref.CommitRadioDoubleClick", boost::bind(&LLFloaterPreference::onDoubleClickRadio, this));
|
||||
|
||||
sSkin = gSavedSettings.getString("SkinCurrent");
|
||||
|
||||
gSavedSettings.getControl("NameTagShowUsernames")->getCommitSignal()->connect(boost::bind(&handleNameTagOptionChanged, _2));
|
||||
gSavedSettings.getControl("NameTagShowFriends")->getCommitSignal()->connect(boost::bind(&handleNameTagOptionChanged, _2));
|
||||
gSavedSettings.getControl("UseDisplayNames")->getCommitSignal()->connect(boost::bind(&handleDisplayNamesOptionChanged, _2));
|
||||
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver( gAgent.getID(), this );
|
||||
}
|
||||
|
||||
void LLFloaterPreference::processProperties( void* pData, EAvatarProcessorType type )
|
||||
{
|
||||
if ( APT_PROPERTIES == type )
|
||||
{
|
||||
const LLAvatarData* pAvatarData = static_cast<const LLAvatarData*>( pData );
|
||||
if( pAvatarData && gAgent.getID() == pAvatarData->avatar_id )
|
||||
{
|
||||
storeAvatarProperties( pAvatarData );
|
||||
processProfileProperties( pAvatarData );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void LLFloaterPreference::storeAvatarProperties( const LLAvatarData* pAvatarData )
|
||||
{
|
||||
mAvatarProperties.avatar_id = gAgent.getID();
|
||||
mAvatarProperties.image_id = pAvatarData->image_id;
|
||||
mAvatarProperties.fl_image_id = pAvatarData->fl_image_id;
|
||||
mAvatarProperties.about_text = pAvatarData->about_text;
|
||||
mAvatarProperties.fl_about_text = pAvatarData->fl_about_text;
|
||||
mAvatarProperties.profile_url = pAvatarData->profile_url;
|
||||
mAvatarProperties.flags = pAvatarData->flags;
|
||||
mAvatarProperties.allow_publish = pAvatarData->flags & AVATAR_ALLOW_PUBLISH;
|
||||
}
|
||||
|
||||
void LLFloaterPreference::processProfileProperties(const LLAvatarData* pAvatarData )
|
||||
{
|
||||
getChild<LLUICtrl>("online_searchresults")->setValue( (bool)(pAvatarData->flags & AVATAR_ALLOW_PUBLISH) );
|
||||
}
|
||||
|
||||
void LLFloaterPreference::saveAvatarProperties( void )
|
||||
{
|
||||
mAvatarProperties.allow_publish = getChild<LLUICtrl>("online_searchresults")->getValue();
|
||||
if ( mAvatarProperties.allow_publish )
|
||||
{
|
||||
mAvatarProperties.flags |= AVATAR_ALLOW_PUBLISH;
|
||||
}
|
||||
|
||||
LLAvatarPropertiesProcessor::getInstance()->sendAvatarPropertiesUpdate( &mAvatarProperties );
|
||||
}
|
||||
|
||||
|
||||
BOOL LLFloaterPreference::postBuild()
|
||||
{
|
||||
gSavedSettings.getControl("PlainTextChatHistory")->getSignal()->connect(boost::bind(&LLIMFloater::processChatHistoryStyleUpdate, _2));
|
||||
|
|
@ -415,6 +461,8 @@ void LLFloaterPreference::saveSettings()
|
|||
|
||||
void LLFloaterPreference::apply()
|
||||
{
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver( gAgent.getID(), this );
|
||||
|
||||
LLTabContainer* tabcontainer = getChild<LLTabContainer>("pref core");
|
||||
if (sSkin != gSavedSettings.getString("SkinCurrent"))
|
||||
{
|
||||
|
|
@ -486,6 +534,8 @@ void LLFloaterPreference::apply()
|
|||
}
|
||||
}
|
||||
|
||||
saveAvatarProperties();
|
||||
|
||||
if (mDoubleClickActionDirty)
|
||||
{
|
||||
updateDoubleClickSettings();
|
||||
|
|
@ -527,6 +577,7 @@ void LLFloaterPreference::cancel()
|
|||
|
||||
void LLFloaterPreference::onOpen(const LLSD& key)
|
||||
{
|
||||
|
||||
// this variable and if that follows it are used to properly handle busy mode response message
|
||||
static bool initialized = FALSE;
|
||||
// if user is logged in and we haven't initialized busy_response yet, do it
|
||||
|
|
@ -553,7 +604,7 @@ void LLFloaterPreference::onOpen(const LLSD& key)
|
|||
(gAgent.isMature() || gAgent.isGodlike());
|
||||
|
||||
LLComboBox* maturity_combo = getChild<LLComboBox>("maturity_desired_combobox");
|
||||
|
||||
LLAvatarPropertiesProcessor::getInstance()->sendAvatarPropertiesRequest( gAgent.getID() );
|
||||
if (can_choose_maturity)
|
||||
{
|
||||
// if they're not adult or a god, they shouldn't see the adult selection, so delete it
|
||||
|
|
|
|||
|
|
@ -34,6 +34,7 @@
|
|||
#define LL_LLFLOATERPREFERENCE_H
|
||||
|
||||
#include "llfloater.h"
|
||||
#include "llavatarpropertiesprocessor.h"
|
||||
|
||||
class LLPanelPreference;
|
||||
class LLPanelLCD;
|
||||
|
|
@ -55,7 +56,7 @@ typedef enum
|
|||
|
||||
|
||||
// Floater to control preferences (display, audio, bandwidth, general.
|
||||
class LLFloaterPreference : public LLFloater
|
||||
class LLFloaterPreference : public LLFloater, public LLAvatarPropertiesObserver
|
||||
{
|
||||
public:
|
||||
LLFloaterPreference(const LLSD& key);
|
||||
|
|
@ -77,6 +78,11 @@ public:
|
|||
// translate user's busy response message according to current locale if message is default, otherwise do nothing
|
||||
static void initBusyResponse();
|
||||
|
||||
void processProperties( void* pData, EAvatarProcessorType type );
|
||||
void processProfileProperties(const LLAvatarData* pAvatarData );
|
||||
void storeAvatarProperties( const LLAvatarData* pAvatarData );
|
||||
void saveAvatarProperties( void );
|
||||
|
||||
protected:
|
||||
void onBtnOK();
|
||||
void onBtnCancel();
|
||||
|
|
@ -164,6 +170,8 @@ private:
|
|||
|
||||
bool mOriginalHideOnlineStatus;
|
||||
std::string mDirectoryVisibility;
|
||||
|
||||
LLAvatarData mAvatarProperties;
|
||||
};
|
||||
|
||||
class LLPanelPreference : public LLPanel
|
||||
|
|
|
|||
|
|
@ -72,7 +72,6 @@
|
|||
#include "llweb.h"
|
||||
#include "llslider.h"
|
||||
#include "message.h"
|
||||
|
||||
#include "llwindow.h" // copyTextToClipboard()
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
|
|
@ -106,8 +105,8 @@ class LLWorldMapHandler : public LLCommandHandler
|
|||
{
|
||||
public:
|
||||
// requires trusted browser to trigger
|
||||
LLWorldMapHandler() : LLCommandHandler("worldmap", UNTRUSTED_THROTTLE) { }
|
||||
|
||||
LLWorldMapHandler() : LLCommandHandler("worldmap", UNTRUSTED_THROTTLE ) { }
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map,
|
||||
LLMediaCtrl* web)
|
||||
{
|
||||
|
|
@ -117,21 +116,52 @@ public:
|
|||
LLFloaterReg::showInstance("world_map", "center");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
// support the secondlife:///app/worldmap/{LOCATION}/{COORDS} SLapp
|
||||
const std::string region_name = LLURI::unescape(params[0].asString());
|
||||
S32 x = (params.size() > 1) ? params[1].asInteger() : 128;
|
||||
S32 y = (params.size() > 2) ? params[2].asInteger() : 128;
|
||||
S32 z = (params.size() > 3) ? params[3].asInteger() : 0;
|
||||
|
||||
|
||||
LLFloaterWorldMap::getInstance()->trackURL(region_name, x, y, z);
|
||||
LLFloaterReg::showInstance("world_map", "center");
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
};
|
||||
LLWorldMapHandler gWorldMapHandler;
|
||||
|
||||
// SocialMap handler secondlife:///app/maptrackavatar/id
|
||||
class LLMapTrackAvatarHandler : public LLCommandHandler
|
||||
{
|
||||
public:
|
||||
// requires trusted browser to trigger
|
||||
LLMapTrackAvatarHandler() : LLCommandHandler("maptrackavatar", UNTRUSTED_THROTTLE)
|
||||
{
|
||||
}
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map, LLMediaCtrl* web)
|
||||
{
|
||||
//Make sure we have some parameters
|
||||
if (params.size() == 0)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
//Get the ID
|
||||
LLUUID id;
|
||||
if (!id.set( params[0], FALSE ))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
LLFloaterWorldMap::getInstance()->avatarTrackFromSlapp( id );
|
||||
LLFloaterReg::showInstance( "world_map", "center" );
|
||||
|
||||
return true;
|
||||
}
|
||||
};
|
||||
LLMapTrackAvatarHandler gMapTrackAvatar;
|
||||
|
||||
LLFloaterWorldMap* gFloaterWorldMap = NULL;
|
||||
|
||||
|
|
@ -142,7 +172,7 @@ public:
|
|||
virtual ~LLMapInventoryObserver() {}
|
||||
virtual void changed(U32 mask);
|
||||
};
|
||||
|
||||
|
||||
void LLMapInventoryObserver::changed(U32 mask)
|
||||
{
|
||||
// if there's a change we're interested in.
|
||||
|
|
@ -184,16 +214,16 @@ const LLUUID LLFloaterWorldMap::sHomeID( "10000000-0000-0000-0000-000000000001"
|
|||
|
||||
LLFloaterWorldMap::LLFloaterWorldMap(const LLSD& key)
|
||||
: LLFloater(key),
|
||||
mInventory(NULL),
|
||||
mInventoryObserver(NULL),
|
||||
mFriendObserver(NULL),
|
||||
mCompletingRegionName(),
|
||||
mCompletingRegionPos(),
|
||||
mWaitingForTracker(FALSE),
|
||||
mIsClosing(FALSE),
|
||||
mSetToUserPosition(TRUE),
|
||||
mTrackedLocation(0,0,0),
|
||||
mTrackedStatus(LLTracker::TRACKING_NOTHING)
|
||||
mInventory(NULL),
|
||||
mInventoryObserver(NULL),
|
||||
mFriendObserver(NULL),
|
||||
mCompletingRegionName(),
|
||||
mCompletingRegionPos(),
|
||||
mWaitingForTracker(FALSE),
|
||||
mIsClosing(FALSE),
|
||||
mSetToUserPosition(TRUE),
|
||||
mTrackedLocation(0,0,0),
|
||||
mTrackedStatus(LLTracker::TRACKING_NOTHING)
|
||||
{
|
||||
gFloaterWorldMap = this;
|
||||
|
||||
|
|
@ -210,7 +240,7 @@ LLFloaterWorldMap::LLFloaterWorldMap(const LLSD& key)
|
|||
mCommitCallbackRegistrar.add("WMap.ShowAgent", boost::bind(&LLFloaterWorldMap::onShowAgentBtn, this));
|
||||
mCommitCallbackRegistrar.add("WMap.Clear", boost::bind(&LLFloaterWorldMap::onClearBtn, this));
|
||||
mCommitCallbackRegistrar.add("WMap.CopySLURL", boost::bind(&LLFloaterWorldMap::onCopySLURL, this));
|
||||
|
||||
|
||||
gSavedSettings.getControl("PreferredMaturity")->getSignal()->connect(boost::bind(&LLFloaterWorldMap::onChangeMaturity, this));
|
||||
}
|
||||
|
||||
|
|
@ -223,32 +253,32 @@ void* LLFloaterWorldMap::createWorldMapView(void* data)
|
|||
BOOL LLFloaterWorldMap::postBuild()
|
||||
{
|
||||
mPanel = getChild<LLPanel>("objects_mapview");
|
||||
|
||||
|
||||
LLComboBox *avatar_combo = getChild<LLComboBox>("friend combo");
|
||||
avatar_combo->selectFirstItem();
|
||||
avatar_combo->setPrearrangeCallback( boost::bind(&LLFloaterWorldMap::onAvatarComboPrearrange, this) );
|
||||
avatar_combo->setTextEntryCallback( boost::bind(&LLFloaterWorldMap::onComboTextEntry, this) );
|
||||
|
||||
|
||||
LLSearchEditor *location_editor = getChild<LLSearchEditor>("location");
|
||||
location_editor->setFocusChangedCallback(boost::bind(&LLFloaterWorldMap::onLocationFocusChanged, this, _1));
|
||||
location_editor->setKeystrokeCallback( boost::bind(&LLFloaterWorldMap::onSearchTextEntry, this));
|
||||
|
||||
getChild<LLScrollListCtrl>("search_results")->setDoubleClickCallback( boost::bind(&LLFloaterWorldMap::onClickTeleportBtn, this));
|
||||
|
||||
|
||||
LLComboBox *landmark_combo = getChild<LLComboBox>( "landmark combo");
|
||||
landmark_combo->selectFirstItem();
|
||||
landmark_combo->setPrearrangeCallback( boost::bind(&LLFloaterWorldMap::onLandmarkComboPrearrange, this) );
|
||||
landmark_combo->setTextEntryCallback( boost::bind(&LLFloaterWorldMap::onComboTextEntry, this) );
|
||||
|
||||
|
||||
mCurZoomVal = log(LLWorldMapView::sMapScale)/log(2.f);
|
||||
getChild<LLUICtrl>("zoom slider")->setValue(LLWorldMapView::sMapScale);
|
||||
|
||||
|
||||
setDefaultBtn(NULL);
|
||||
|
||||
|
||||
mZoomTimer.stop();
|
||||
|
||||
|
||||
onChangeMaturity();
|
||||
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
|
@ -257,11 +287,11 @@ LLFloaterWorldMap::~LLFloaterWorldMap()
|
|||
{
|
||||
// All cleaned up by LLView destructor
|
||||
mPanel = NULL;
|
||||
|
||||
|
||||
// Inventory deletes all observers on shutdown
|
||||
mInventory = NULL;
|
||||
mInventoryObserver = NULL;
|
||||
|
||||
|
||||
// avatar tracker will delete this for us.
|
||||
mFriendObserver = NULL;
|
||||
|
||||
|
|
@ -285,13 +315,13 @@ void LLFloaterWorldMap::onClose(bool app_quitting)
|
|||
void LLFloaterWorldMap::onOpen(const LLSD& key)
|
||||
{
|
||||
bool center_on_target = (key.asString() == "center");
|
||||
|
||||
|
||||
mIsClosing = FALSE;
|
||||
|
||||
|
||||
LLWorldMapView* map_panel;
|
||||
map_panel = (LLWorldMapView*)gFloaterWorldMap->mPanel;
|
||||
map_panel->clearLastClick();
|
||||
|
||||
|
||||
{
|
||||
// reset pan on show, so it centers on you again
|
||||
if (!center_on_target)
|
||||
|
|
@ -299,27 +329,27 @@ void LLFloaterWorldMap::onOpen(const LLSD& key)
|
|||
LLWorldMapView::setPan(0, 0, TRUE);
|
||||
}
|
||||
map_panel->updateVisibleBlocks();
|
||||
|
||||
|
||||
// Reload items as they may have changed
|
||||
LLWorldMap::getInstance()->reloadItems();
|
||||
|
||||
|
||||
// We may already have a bounding box for the regions of the world,
|
||||
// so use that to adjust the view.
|
||||
adjustZoomSliderBounds();
|
||||
|
||||
|
||||
// Could be first show
|
||||
//LLFirstUse::useMap();
|
||||
|
||||
|
||||
// Start speculative download of landmarks
|
||||
const LLUUID landmark_folder_id = gInventory.findCategoryUUIDForType(LLFolderType::FT_LANDMARK);
|
||||
LLInventoryModelBackgroundFetch::instance().start(landmark_folder_id);
|
||||
|
||||
|
||||
getChild<LLUICtrl>("location")->setFocus( TRUE);
|
||||
gFocusMgr.triggerFocusFlash();
|
||||
|
||||
|
||||
buildAvatarIDList();
|
||||
buildLandmarkIDLists();
|
||||
|
||||
|
||||
// If nothing is being tracked, set flag so the user position will be found
|
||||
mSetToUserPosition = ( LLTracker::getTrackingStatus() == LLTracker::TRACKING_NOTHING );
|
||||
}
|
||||
|
|
@ -356,7 +386,7 @@ BOOL LLFloaterWorldMap::handleScrollWheel(S32 x, S32 y, S32 clicks)
|
|||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return LLFloater::handleScrollWheel(x, y, clicks);
|
||||
}
|
||||
|
||||
|
|
@ -381,7 +411,7 @@ void LLFloaterWorldMap::draw()
|
|||
bool agent_on_prelude = (regionp && regionp->isPrelude());
|
||||
bool enable_go_home = gAgent.isGodlike() || !agent_on_prelude;
|
||||
getChildView("Go Home")->setEnabled(enable_go_home);
|
||||
|
||||
|
||||
updateLocation();
|
||||
|
||||
LLTracker::ETrackingStatus tracking_status = LLTracker::getTrackingStatus();
|
||||
|
|
@ -393,7 +423,7 @@ void LLFloaterWorldMap::draw()
|
|||
{
|
||||
getChild<LLUICtrl>("avatar_icon")->setColor( map_track_disabled_color);
|
||||
}
|
||||
|
||||
|
||||
if (LLTracker::TRACKING_LANDMARK == tracking_status)
|
||||
{
|
||||
getChild<LLUICtrl>("landmark_icon")->setColor( map_track_color);
|
||||
|
|
@ -402,7 +432,7 @@ void LLFloaterWorldMap::draw()
|
|||
{
|
||||
getChild<LLUICtrl>("landmark_icon")->setColor( map_track_disabled_color);
|
||||
}
|
||||
|
||||
|
||||
if (LLTracker::TRACKING_LOCATION == tracking_status)
|
||||
{
|
||||
getChild<LLUICtrl>("location_icon")->setColor( map_track_color);
|
||||
|
|
@ -422,21 +452,21 @@ void LLFloaterWorldMap::draw()
|
|||
getChild<LLUICtrl>("location_icon")->setColor( map_track_disabled_color);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// check for completion of tracking data
|
||||
if (mWaitingForTracker)
|
||||
{
|
||||
centerOnTarget(TRUE);
|
||||
}
|
||||
|
||||
|
||||
getChildView("Teleport")->setEnabled((BOOL)tracking_status);
|
||||
// getChildView("Clear")->setEnabled((BOOL)tracking_status);
|
||||
// getChildView("Clear")->setEnabled((BOOL)tracking_status);
|
||||
getChildView("Show Destination")->setEnabled((BOOL)tracking_status || LLWorldMap::getInstance()->isTracking());
|
||||
getChildView("copy_slurl")->setEnabled((mSLURL.isValid()) );
|
||||
|
||||
|
||||
setMouseOpaque(TRUE);
|
||||
getDragHandle()->setMouseOpaque(TRUE);
|
||||
|
||||
|
||||
//RN: snaps to zoom value because interpolation caused jitter in the text rendering
|
||||
if (!mZoomTimer.getStarted() && mCurZoomVal != (F32)getChild<LLUICtrl>("zoom slider")->getValue().asReal())
|
||||
{
|
||||
|
|
@ -451,7 +481,7 @@ void LLFloaterWorldMap::draw()
|
|||
mCurZoomVal = lerp(mCurZoomVal, (F32)getChild<LLUICtrl>("zoom slider")->getValue().asReal(), interp);
|
||||
F32 map_scale = 256.f*pow(2.f, mCurZoomVal);
|
||||
LLWorldMapView::setScale( map_scale );
|
||||
|
||||
|
||||
// Enable/disable checkboxes depending on the zoom level
|
||||
// If above threshold level (i.e. low res) -> Disable all checkboxes
|
||||
// If under threshold level (i.e. high res) -> Enable all checkboxes
|
||||
|
|
@ -477,7 +507,7 @@ void LLFloaterWorldMap::trackAvatar( const LLUUID& avatar_id, const std::string&
|
|||
{
|
||||
LLCtrlSelectionInterface *iface = childGetSelectionInterface("friend combo");
|
||||
if (!iface) return;
|
||||
|
||||
|
||||
buildAvatarIDList();
|
||||
if(iface->setCurrentByID(avatar_id) || gAgent.isGodlike())
|
||||
{
|
||||
|
|
@ -507,7 +537,7 @@ void LLFloaterWorldMap::trackLandmark( const LLUUID& landmark_item_id )
|
|||
{
|
||||
LLCtrlSelectionInterface *iface = childGetSelectionInterface("landmark combo");
|
||||
if (!iface) return;
|
||||
|
||||
|
||||
buildLandmarkIDLists();
|
||||
BOOL found = FALSE;
|
||||
S32 idx;
|
||||
|
|
@ -519,7 +549,7 @@ void LLFloaterWorldMap::trackLandmark( const LLUUID& landmark_item_id )
|
|||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (found && iface->setCurrentByID( landmark_item_id ) )
|
||||
{
|
||||
LLUUID asset_id = mLandmarkAssetIDList.get( idx );
|
||||
|
|
@ -528,17 +558,17 @@ void LLFloaterWorldMap::trackLandmark( const LLUUID& landmark_item_id )
|
|||
if (combo) name = combo->getSimple();
|
||||
mTrackedStatus = LLTracker::TRACKING_LANDMARK;
|
||||
LLTracker::trackLandmark(mLandmarkAssetIDList.get( idx ), // assetID
|
||||
mLandmarkItemIDList.get( idx ), // itemID
|
||||
name); // name
|
||||
|
||||
mLandmarkItemIDList.get( idx ), // itemID
|
||||
name); // name
|
||||
|
||||
if( asset_id != sHomeID )
|
||||
{
|
||||
// start the download process
|
||||
gLandmarkList.getAsset( asset_id);
|
||||
}
|
||||
|
||||
|
||||
// We have to download both region info and landmark data, so set busy. JC
|
||||
// getWindow()->incBusyCount();
|
||||
// getWindow()->incBusyCount();
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -574,10 +604,10 @@ void LLFloaterWorldMap::trackLocation(const LLVector3d& pos_global)
|
|||
S32 world_y = S32(pos_global.mdV[1] / 256);
|
||||
LLWorldMapMessage::getInstance()->sendMapBlockRequest(world_x, world_y, world_x, world_y, true);
|
||||
setDefaultBtn("");
|
||||
|
||||
|
||||
// clicked on a non-region - turn off coord display
|
||||
enableTeleportCoordsDisplay( false );
|
||||
|
||||
|
||||
return;
|
||||
}
|
||||
if (sim_info->isDown())
|
||||
|
|
@ -588,33 +618,33 @@ void LLFloaterWorldMap::trackLocation(const LLVector3d& pos_global)
|
|||
LLWorldMap::getInstance()->setTrackingInvalid();
|
||||
LLTracker::stopTracking(NULL);
|
||||
setDefaultBtn("");
|
||||
|
||||
|
||||
// clicked on a down region - turn off coord display
|
||||
enableTeleportCoordsDisplay( false );
|
||||
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
std::string sim_name = sim_info->getName();
|
||||
F32 region_x = (F32)fmod( pos_global.mdV[VX], (F64)REGION_WIDTH_METERS );
|
||||
F32 region_y = (F32)fmod( pos_global.mdV[VY], (F64)REGION_WIDTH_METERS );
|
||||
std::string full_name = llformat("%s (%d, %d, %d)",
|
||||
sim_name.c_str(),
|
||||
llround(region_x),
|
||||
llround(region_y),
|
||||
llround((F32)pos_global.mdV[VZ]));
|
||||
|
||||
sim_name.c_str(),
|
||||
llround(region_x),
|
||||
llround(region_y),
|
||||
llround((F32)pos_global.mdV[VZ]));
|
||||
|
||||
std::string tooltip("");
|
||||
mTrackedStatus = LLTracker::TRACKING_LOCATION;
|
||||
LLTracker::trackLocation(pos_global, full_name, tooltip);
|
||||
LLWorldMap::getInstance()->cancelTracking(); // The floater is taking over the tracking
|
||||
|
||||
|
||||
LLVector3d coord_pos = LLTracker::getTrackedPositionGlobal();
|
||||
updateTeleportCoordsDisplay( coord_pos );
|
||||
|
||||
|
||||
// we have a valid region - turn on coord display
|
||||
enableTeleportCoordsDisplay( true );
|
||||
|
||||
|
||||
setDefaultBtn("Teleport");
|
||||
}
|
||||
|
||||
|
|
@ -631,7 +661,7 @@ void LLFloaterWorldMap::updateTeleportCoordsDisplay( const LLVector3d& pos )
|
|||
{
|
||||
// if we're going to update their value, we should also enable them
|
||||
enableTeleportCoordsDisplay( true );
|
||||
|
||||
|
||||
// convert global specified position to a local one
|
||||
F32 region_local_x = (F32)fmod( pos.mdV[VX], (F64)REGION_WIDTH_METERS );
|
||||
F32 region_local_y = (F32)fmod( pos.mdV[VY], (F64)REGION_WIDTH_METERS );
|
||||
|
|
@ -646,16 +676,16 @@ void LLFloaterWorldMap::updateTeleportCoordsDisplay( const LLVector3d& pos )
|
|||
void LLFloaterWorldMap::updateLocation()
|
||||
{
|
||||
bool gotSimName;
|
||||
|
||||
|
||||
LLTracker::ETrackingStatus status = LLTracker::getTrackingStatus();
|
||||
|
||||
|
||||
// These values may get updated by a message, so need to check them every frame
|
||||
// The fields may be changed by the user, so only update them if the data changes
|
||||
LLVector3d pos_global = LLTracker::getTrackedPositionGlobal();
|
||||
if (pos_global.isExactlyZero())
|
||||
{
|
||||
LLVector3d agentPos = gAgent.getPositionGlobal();
|
||||
|
||||
|
||||
// Set to avatar's current postion if nothing is selected
|
||||
if ( status == LLTracker::TRACKING_NOTHING && mSetToUserPosition )
|
||||
{
|
||||
|
|
@ -665,19 +695,19 @@ void LLFloaterWorldMap::updateLocation()
|
|||
if ( gotSimName )
|
||||
{
|
||||
mSetToUserPosition = FALSE;
|
||||
|
||||
|
||||
// Fill out the location field
|
||||
getChild<LLUICtrl>("location")->setValue(agent_sim_name);
|
||||
|
||||
|
||||
// update the coordinate display with location of avatar in region
|
||||
updateTeleportCoordsDisplay( agentPos );
|
||||
|
||||
|
||||
// Figure out where user is
|
||||
// Set the current SLURL
|
||||
mSLURL = LLSLURL(agent_sim_name, gAgent.getPositionGlobal());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return; // invalid location
|
||||
}
|
||||
std::string sim_name;
|
||||
|
|
@ -699,17 +729,17 @@ void LLFloaterWorldMap::updateLocation()
|
|||
pos_global[2] = 200;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
getChild<LLUICtrl>("location")->setValue(sim_name);
|
||||
|
||||
|
||||
// refresh coordinate display to reflect where user clicked.
|
||||
LLVector3d coord_pos = LLTracker::getTrackedPositionGlobal();
|
||||
updateTeleportCoordsDisplay( coord_pos );
|
||||
|
||||
|
||||
// simNameFromPosGlobal can fail, so don't give the user an invalid SLURL
|
||||
if ( gotSimName )
|
||||
{
|
||||
mSLURL = LLSLURL(sim_name, pos_global);
|
||||
mSLURL = LLSLURL(sim_name, pos_global);
|
||||
}
|
||||
else
|
||||
{ // Empty SLURL will disable the "Copy SLURL to clipboard" button
|
||||
|
|
@ -736,12 +766,12 @@ void LLFloaterWorldMap::trackURL(const std::string& region_name, S32 x_coord, S3
|
|||
{
|
||||
// fill in UI based on URL
|
||||
gFloaterWorldMap->getChild<LLUICtrl>("location")->setValue(region_name);
|
||||
|
||||
|
||||
// Save local coords to highlight position after region global
|
||||
// position is returned.
|
||||
gFloaterWorldMap->mCompletingRegionPos.set(
|
||||
(F32)x_coord, (F32)y_coord, (F32)z_coord);
|
||||
|
||||
(F32)x_coord, (F32)y_coord, (F32)z_coord);
|
||||
|
||||
// pass sim name to combo box
|
||||
gFloaterWorldMap->mCompletingRegionName = region_name;
|
||||
LLWorldMapMessage::getInstance()->sendNamedRegionRequest(region_name);
|
||||
|
|
@ -813,7 +843,7 @@ void LLFloaterWorldMap::buildAvatarIDList()
|
|||
{
|
||||
LLCtrlListInterface *list = childGetListInterface("friend combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
// Delete all but the "None" entry
|
||||
S32 list_size = list->getItemCount();
|
||||
if (list_size > 1)
|
||||
|
|
@ -821,7 +851,7 @@ void LLFloaterWorldMap::buildAvatarIDList()
|
|||
list->selectItemRange(1, -1);
|
||||
list->operateOnSelection(LLCtrlListInterface::OP_DELETE);
|
||||
}
|
||||
|
||||
|
||||
// Get all of the calling cards for avatar that are currently online
|
||||
LLCollectMappableBuddies collector;
|
||||
LLAvatarTracker::instance().applyFunctor(collector);
|
||||
|
|
@ -833,7 +863,7 @@ void LLFloaterWorldMap::buildAvatarIDList()
|
|||
{
|
||||
list->addSimpleElement((*it).first, ADD_BOTTOM, (*it).second);
|
||||
}
|
||||
|
||||
|
||||
list->setCurrentByID( LLAvatarTracker::instance().getAvatarID() );
|
||||
list->selectFirstItem();
|
||||
}
|
||||
|
|
@ -843,7 +873,7 @@ void LLFloaterWorldMap::buildLandmarkIDLists()
|
|||
{
|
||||
LLCtrlListInterface *list = childGetListInterface("landmark combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
// Delete all but the "None" entry
|
||||
S32 list_size = list->getItemCount();
|
||||
if (list_size > 1)
|
||||
|
|
@ -851,17 +881,17 @@ void LLFloaterWorldMap::buildLandmarkIDLists()
|
|||
list->selectItemRange(1, -1);
|
||||
list->operateOnSelection(LLCtrlListInterface::OP_DELETE);
|
||||
}
|
||||
|
||||
|
||||
mLandmarkItemIDList.reset();
|
||||
mLandmarkAssetIDList.reset();
|
||||
|
||||
|
||||
// Get all of the current landmarks
|
||||
mLandmarkAssetIDList.put( LLUUID::null );
|
||||
mLandmarkItemIDList.put( LLUUID::null );
|
||||
|
||||
|
||||
mLandmarkAssetIDList.put( sHomeID );
|
||||
mLandmarkItemIDList.put( sHomeID );
|
||||
|
||||
|
||||
LLInventoryModel::cat_array_t cats;
|
||||
LLInventoryModel::item_array_t items;
|
||||
LLIsType is_landmark(LLAssetType::AT_LANDMARK);
|
||||
|
|
@ -870,20 +900,20 @@ void LLFloaterWorldMap::buildLandmarkIDLists()
|
|||
items,
|
||||
LLInventoryModel::EXCLUDE_TRASH,
|
||||
is_landmark);
|
||||
|
||||
|
||||
std::sort(items.begin(), items.end(), LLViewerInventoryItem::comparePointers());
|
||||
|
||||
S32 count = items.count();
|
||||
for(S32 i = 0; i < count; ++i)
|
||||
{
|
||||
LLInventoryItem* item = items.get(i);
|
||||
|
||||
|
||||
list->addSimpleElement(item->getName(), ADD_BOTTOM, item->getUUID());
|
||||
|
||||
|
||||
mLandmarkAssetIDList.put( item->getAssetUUID() );
|
||||
mLandmarkItemIDList.put( item->getUUID() );
|
||||
}
|
||||
|
||||
|
||||
list->selectFirstItem();
|
||||
}
|
||||
|
||||
|
|
@ -949,31 +979,31 @@ void LLFloaterWorldMap::adjustZoomSliderBounds()
|
|||
// Currently (01/26/09), this value allows the whole grid to be visible in a 1024x1024 window.
|
||||
S32 world_width_regions = MAX_VISIBLE_REGIONS;
|
||||
S32 world_height_regions = MAX_VISIBLE_REGIONS;
|
||||
|
||||
|
||||
// Find how much space we have to display the world
|
||||
LLWorldMapView* map_panel;
|
||||
map_panel = (LLWorldMapView*)mPanel;
|
||||
LLRect view_rect = map_panel->getRect();
|
||||
|
||||
|
||||
// View size in pixels
|
||||
S32 view_width = view_rect.getWidth();
|
||||
S32 view_height = view_rect.getHeight();
|
||||
|
||||
|
||||
// Pixels per region to display entire width/height
|
||||
F32 width_pixels_per_region = (F32) view_width / (F32) world_width_regions;
|
||||
F32 height_pixels_per_region = (F32) view_height / (F32) world_height_regions;
|
||||
|
||||
|
||||
F32 pixels_per_region = llmin(width_pixels_per_region,
|
||||
height_pixels_per_region);
|
||||
|
||||
|
||||
// Round pixels per region to an even number of slider increments
|
||||
S32 slider_units = llfloor(pixels_per_region / 0.2f);
|
||||
pixels_per_region = slider_units * 0.2f;
|
||||
|
||||
|
||||
// Make sure the zoom slider can be moved at least a little bit.
|
||||
// Likewise, less than the increment pixels per region is just silly.
|
||||
pixels_per_region = llclamp(pixels_per_region, 1.f, ZOOM_MAX);
|
||||
|
||||
|
||||
F32 min_power = log(pixels_per_region/256.f)/log(2.f);
|
||||
|
||||
getChild<LLSlider>("zoom slider")->setMinValue(min_power);
|
||||
|
|
@ -997,19 +1027,19 @@ void LLFloaterWorldMap::onLandmarkComboPrearrange( )
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
LLCtrlListInterface *list = childGetListInterface("landmark combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
LLUUID current_choice = list->getCurrentID();
|
||||
|
||||
|
||||
buildLandmarkIDLists();
|
||||
|
||||
|
||||
if( current_choice.isNull() || !list->setCurrentByID( current_choice ) )
|
||||
{
|
||||
LLTracker::stopTracking(NULL);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
void LLFloaterWorldMap::onComboTextEntry()
|
||||
|
|
@ -1033,18 +1063,18 @@ void LLFloaterWorldMap::onLandmarkComboCommit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
LLCtrlListInterface *list = childGetListInterface("landmark combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
LLUUID asset_id;
|
||||
LLUUID item_id = list->getCurrentID();
|
||||
|
||||
|
||||
LLTracker::stopTracking(NULL);
|
||||
|
||||
|
||||
//RN: stopTracking() clears current combobox selection, need to reassert it here
|
||||
list->setCurrentByID(item_id);
|
||||
|
||||
|
||||
if( item_id.isNull() )
|
||||
{
|
||||
}
|
||||
|
|
@ -1068,7 +1098,7 @@ void LLFloaterWorldMap::onLandmarkComboCommit()
|
|||
|
||||
trackLandmark( item_id);
|
||||
onShowTargetBtn();
|
||||
|
||||
|
||||
// Reset to user postion if nothing is tracked
|
||||
mSetToUserPosition = ( LLTracker::getTrackingStatus() == LLTracker::TRACKING_NOTHING );
|
||||
}
|
||||
|
|
@ -1080,19 +1110,19 @@ void LLFloaterWorldMap::onAvatarComboPrearrange( )
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
LLCtrlListInterface *list = childGetListInterface("friend combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
LLUUID current_choice;
|
||||
|
||||
|
||||
if( LLAvatarTracker::instance().haveTrackingInfo() )
|
||||
{
|
||||
current_choice = LLAvatarTracker::instance().getAvatarID();
|
||||
}
|
||||
|
||||
|
||||
buildAvatarIDList();
|
||||
|
||||
|
||||
if( !list->setCurrentByID( current_choice ) || current_choice.isNull() )
|
||||
{
|
||||
LLTracker::stopTracking(NULL);
|
||||
|
|
@ -1105,10 +1135,10 @@ void LLFloaterWorldMap::onAvatarComboCommit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
LLCtrlListInterface *list = childGetListInterface("friend combo");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
const LLUUID& new_avatar_id = list->getCurrentID();
|
||||
if (new_avatar_id.notNull())
|
||||
{
|
||||
|
|
@ -1124,6 +1154,12 @@ void LLFloaterWorldMap::onAvatarComboCommit()
|
|||
}
|
||||
}
|
||||
|
||||
void LLFloaterWorldMap::avatarTrackFromSlapp( const LLUUID& id )
|
||||
{
|
||||
trackAvatar( id, "av" );
|
||||
onShowTargetBtn();
|
||||
}
|
||||
|
||||
void LLFloaterWorldMap::onLocationFocusChanged( LLFocusableElement* focus )
|
||||
{
|
||||
updateSearchEnabled();
|
||||
|
|
@ -1148,13 +1184,13 @@ void LLFloaterWorldMap::onLocationCommit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
clearLocationSelection(FALSE);
|
||||
mCompletingRegionName = "";
|
||||
mLastRegionName = "";
|
||||
|
||||
|
||||
std::string str = getChild<LLUICtrl>("location")->getValue().asString();
|
||||
|
||||
|
||||
// Trim any leading and trailing spaces in the search target
|
||||
std::string saved_str = str;
|
||||
LLStringUtil::trim( str );
|
||||
|
|
@ -1162,7 +1198,7 @@ void LLFloaterWorldMap::onLocationCommit()
|
|||
{ // Set the value in the UI if any spaces were removed
|
||||
getChild<LLUICtrl>("location")->setValue(str);
|
||||
}
|
||||
|
||||
|
||||
LLStringUtil::toLower(str);
|
||||
mCompletingRegionName = str;
|
||||
LLWorldMap::getInstance()->setTrackingCommit();
|
||||
|
|
@ -1183,13 +1219,13 @@ void LLFloaterWorldMap::onCoordinatesCommit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
S32 x_coord = (S32)childGetValue("teleport_coordinate_x").asReal();
|
||||
S32 y_coord = (S32)childGetValue("teleport_coordinate_y").asReal();
|
||||
S32 z_coord = (S32)childGetValue("teleport_coordinate_z").asReal();
|
||||
|
||||
|
||||
const std::string region_name = childGetValue("location").asString();
|
||||
|
||||
|
||||
trackURL( region_name, x_coord, y_coord, z_coord );
|
||||
}
|
||||
|
||||
|
|
@ -1225,7 +1261,7 @@ void LLFloaterWorldMap::onCopySLURL()
|
|||
|
||||
LLSD args;
|
||||
args["SLURL"] = mSLURL.getSLURLString();
|
||||
|
||||
|
||||
LLNotificationsUtil::add("CopySLURL", args);
|
||||
}
|
||||
|
||||
|
|
@ -1246,26 +1282,26 @@ void LLFloaterWorldMap::centerOnTarget(BOOL animate)
|
|||
else
|
||||
{
|
||||
// We've got the position finally, so we're no longer busy. JC
|
||||
// getWindow()->decBusyCount();
|
||||
// getWindow()->decBusyCount();
|
||||
pos_global = LLTracker::getTrackedPositionGlobal() - gAgentCamera.getCameraPositionGlobal();
|
||||
}
|
||||
}
|
||||
else if(LLWorldMap::getInstance()->isTracking())
|
||||
{
|
||||
pos_global = LLWorldMap::getInstance()->getTrackedPositionGlobal() - gAgentCamera.getCameraPositionGlobal();;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
// default behavior = center on agent
|
||||
pos_global.clearVec();
|
||||
}
|
||||
|
||||
|
||||
LLWorldMapView::setPan( -llfloor((F32)(pos_global.mdV[VX] * (F64)LLWorldMapView::sMapScale / REGION_WIDTH_METERS)),
|
||||
-llfloor((F32)(pos_global.mdV[VY] * (F64)LLWorldMapView::sMapScale / REGION_WIDTH_METERS)),
|
||||
!animate);
|
||||
-llfloor((F32)(pos_global.mdV[VY] * (F64)LLWorldMapView::sMapScale / REGION_WIDTH_METERS)),
|
||||
!animate);
|
||||
mWaitingForTracker = FALSE;
|
||||
}
|
||||
|
||||
|
|
@ -1273,7 +1309,7 @@ void LLFloaterWorldMap::centerOnTarget(BOOL animate)
|
|||
void LLFloaterWorldMap::fly()
|
||||
{
|
||||
LLVector3d pos_global = LLTracker::getTrackedPositionGlobal();
|
||||
|
||||
|
||||
// Start the autopilot and close the floater,
|
||||
// so we can see where we're flying
|
||||
if (!pos_global.isExactlyZero())
|
||||
|
|
@ -1294,7 +1330,7 @@ void LLFloaterWorldMap::teleport()
|
|||
BOOL teleport_home = FALSE;
|
||||
LLVector3d pos_global;
|
||||
LLAvatarTracker& av_tracker = LLAvatarTracker::instance();
|
||||
|
||||
|
||||
LLTracker::ETrackingStatus tracking_status = LLTracker::getTrackingStatus();
|
||||
if (LLTracker::TRACKING_AVATAR == tracking_status
|
||||
&& av_tracker.haveTrackingInfo() )
|
||||
|
|
@ -1317,10 +1353,10 @@ void LLFloaterWorldMap::teleport()
|
|||
&& landmark->getRegionID(region_id))
|
||||
{
|
||||
LLLandmark::requestRegionHandle(
|
||||
gMessageSystem,
|
||||
gAgent.getRegionHost(),
|
||||
region_id,
|
||||
NULL);
|
||||
gMessageSystem,
|
||||
gAgent.getRegionHost(),
|
||||
region_id,
|
||||
NULL);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -1332,7 +1368,7 @@ void LLFloaterWorldMap::teleport()
|
|||
{
|
||||
make_ui_sound("UISndInvalidOp");
|
||||
}
|
||||
|
||||
|
||||
// Do the teleport, which will also close the floater
|
||||
if (teleport_home)
|
||||
{
|
||||
|
|
@ -1367,7 +1403,7 @@ void LLFloaterWorldMap::teleportToLandmark()
|
|||
{
|
||||
BOOL has_destination = FALSE;
|
||||
LLUUID destination_id; // Null means "home"
|
||||
|
||||
|
||||
if( LLTracker::getTrackedLandmarkAssetID() == sHomeID )
|
||||
{
|
||||
has_destination = TRUE;
|
||||
|
|
@ -1388,14 +1424,14 @@ void LLFloaterWorldMap::teleportToLandmark()
|
|||
if(landmark->getRegionID(region_id))
|
||||
{
|
||||
LLLandmark::requestRegionHandle(
|
||||
gMessageSystem,
|
||||
gAgent.getRegionHost(),
|
||||
region_id,
|
||||
NULL);
|
||||
gMessageSystem,
|
||||
gAgent.getRegionHost(),
|
||||
region_id,
|
||||
NULL);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if( has_destination )
|
||||
{
|
||||
gAgent.teleportViaLandmark( destination_id );
|
||||
|
|
@ -1428,12 +1464,12 @@ void LLFloaterWorldMap::updateSims(bool found_null_sim)
|
|||
{
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
LLScrollListCtrl *list = getChild<LLScrollListCtrl>("search_results");
|
||||
list->operateOnAll(LLCtrlListInterface::OP_DELETE);
|
||||
|
||||
|
||||
S32 name_length = mCompletingRegionName.length();
|
||||
|
||||
|
||||
LLSD match;
|
||||
|
||||
S32 num_results = 0;
|
||||
|
|
@ -1443,7 +1479,7 @@ void LLFloaterWorldMap::updateSims(bool found_null_sim)
|
|||
LLSimInfo* info = it->second;
|
||||
std::string sim_name_lower = info->getName();
|
||||
LLStringUtil::toLower(sim_name_lower);
|
||||
|
||||
|
||||
if (sim_name_lower.substr(0, name_length) == mCompletingRegionName)
|
||||
{
|
||||
if (sim_name_lower == mCompletingRegionName)
|
||||
|
|
@ -1459,12 +1495,12 @@ void LLFloaterWorldMap::updateSims(bool found_null_sim)
|
|||
num_results++;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (found_null_sim)
|
||||
{
|
||||
mCompletingRegionName = "";
|
||||
}
|
||||
|
||||
|
||||
// if match found, highlight it and go
|
||||
if (!match.isUndefined())
|
||||
{
|
||||
|
|
@ -1472,7 +1508,7 @@ void LLFloaterWorldMap::updateSims(bool found_null_sim)
|
|||
getChild<LLUICtrl>("search_results")->setFocus(TRUE);
|
||||
onCommitSearchResult();
|
||||
}
|
||||
|
||||
|
||||
// if we found nothing, say "none"
|
||||
if (num_results == 0)
|
||||
{
|
||||
|
|
@ -1486,7 +1522,7 @@ void LLFloaterWorldMap::onCommitSearchResult()
|
|||
{
|
||||
LLCtrlListInterface *list = childGetListInterface("search_results");
|
||||
if (!list) return;
|
||||
|
||||
|
||||
LLSD selected_value = list->getSelectedValue();
|
||||
std::string sim_name = selected_value.asString();
|
||||
if (sim_name.empty())
|
||||
|
|
@ -1494,19 +1530,19 @@ void LLFloaterWorldMap::onCommitSearchResult()
|
|||
return;
|
||||
}
|
||||
LLStringUtil::toLower(sim_name);
|
||||
|
||||
|
||||
std::map<U64, LLSimInfo*>::const_iterator it;
|
||||
for (it = LLWorldMap::getInstance()->getRegionMap().begin(); it != LLWorldMap::getInstance()->getRegionMap().end(); ++it)
|
||||
{
|
||||
LLSimInfo* info = it->second;
|
||||
|
||||
|
||||
if (info->isName(sim_name))
|
||||
{
|
||||
LLVector3d pos_global = info->getGlobalOrigin();
|
||||
|
||||
|
||||
const F64 SIM_COORD_DEFAULT = 128.0;
|
||||
LLVector3 pos_local(SIM_COORD_DEFAULT, SIM_COORD_DEFAULT, 0.0f);
|
||||
|
||||
|
||||
// Did this value come from a trackURL() request?
|
||||
if (!mCompletingRegionPos.isExactlyZero())
|
||||
{
|
||||
|
|
@ -1516,14 +1552,14 @@ void LLFloaterWorldMap::onCommitSearchResult()
|
|||
pos_global.mdV[VX] += (F64)pos_local.mV[VX];
|
||||
pos_global.mdV[VY] += (F64)pos_local.mV[VY];
|
||||
pos_global.mdV[VZ] = (F64)pos_local.mV[VZ];
|
||||
|
||||
|
||||
getChild<LLUICtrl>("location")->setValue(sim_name);
|
||||
trackLocation(pos_global);
|
||||
setDefaultBtn("Teleport");
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
onShowTargetBtn();
|
||||
}
|
||||
|
||||
|
|
@ -1531,15 +1567,15 @@ void LLFloaterWorldMap::onChangeMaturity()
|
|||
{
|
||||
bool can_access_mature = gAgent.canAccessMature();
|
||||
bool can_access_adult = gAgent.canAccessAdult();
|
||||
|
||||
|
||||
getChildView("events_mature_icon")->setVisible( can_access_mature);
|
||||
getChildView("events_mature_label")->setVisible( can_access_mature);
|
||||
getChildView("events_mature_chk")->setVisible( can_access_mature);
|
||||
|
||||
|
||||
getChildView("events_adult_icon")->setVisible( can_access_adult);
|
||||
getChildView("events_adult_label")->setVisible( can_access_adult);
|
||||
getChildView("events_adult_chk")->setVisible( can_access_adult);
|
||||
|
||||
|
||||
// disable mature / adult events.
|
||||
if (!can_access_mature)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -106,6 +106,11 @@ public:
|
|||
// teleport to the tracked item, if there is one
|
||||
void teleport();
|
||||
void onChangeMaturity();
|
||||
|
||||
|
||||
//Slapp instigated avatar tracking
|
||||
void avatarTrackFromSlapp( const LLUUID& id );
|
||||
|
||||
protected:
|
||||
void onGoHome();
|
||||
|
||||
|
|
|
|||
|
|
@ -921,6 +921,8 @@ LLInventoryPanel* LLInventoryPanel::getActiveInventoryPanel(BOOL auto_open)
|
|||
{
|
||||
S32 z_min = S32_MAX;
|
||||
LLInventoryPanel* res = NULL;
|
||||
LLFloater* active_inv_floaterp = NULL;
|
||||
|
||||
// A. If the inventory side panel is open, use that preferably.
|
||||
if (is_inventorysp_active())
|
||||
{
|
||||
|
|
@ -941,6 +943,7 @@ LLInventoryPanel* LLInventoryPanel::getActiveInventoryPanel(BOOL auto_open)
|
|||
{
|
||||
res = inventorySP->getActivePanel();
|
||||
z_min = gFloaterView->getZOrder(inv_floater);
|
||||
active_inv_floaterp = inv_floater;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -960,10 +963,19 @@ LLInventoryPanel* LLInventoryPanel::getActiveInventoryPanel(BOOL auto_open)
|
|||
{
|
||||
res = iv->getPanel();
|
||||
z_min = z_order;
|
||||
active_inv_floaterp = iv;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (res) return res;
|
||||
|
||||
if (res)
|
||||
{
|
||||
// Make sure the floater is not minimized (STORM-438).
|
||||
if (active_inv_floaterp && active_inv_floaterp->isMinimized())
|
||||
active_inv_floaterp->setMinimized(FALSE);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
// C. If no panels are open and we don't want to force open a panel, then just abort out.
|
||||
if (!auto_open) return NULL;
|
||||
|
|
|
|||
|
|
@ -477,6 +477,7 @@ LLPanelAvatarProfile::LLPanelAvatarProfile()
|
|||
|
||||
BOOL LLPanelAvatarProfile::postBuild()
|
||||
{
|
||||
childSetCommitCallback("see_profile_btn",(boost::bind(&LLPanelAvatarProfile::onSeeProfileBtnClick,this)),NULL);
|
||||
childSetCommitCallback("add_friend",(boost::bind(&LLPanelAvatarProfile::onAddFriendButtonClick,this)),NULL);
|
||||
childSetCommitCallback("im",(boost::bind(&LLPanelAvatarProfile::onIMButtonClick,this)),NULL);
|
||||
childSetCommitCallback("call",(boost::bind(&LLPanelAvatarProfile::onCallButtonClick,this)),NULL);
|
||||
|
|
@ -624,6 +625,35 @@ void LLPanelAvatarProfile::processGroupProperties(const LLAvatarGroups* avatar_g
|
|||
getChild<LLUICtrl>("sl_groups")->setValue(groups);
|
||||
}
|
||||
|
||||
void LLPanelAvatarProfile::got_full_name_callback( const LLUUID& id, const std::string& full_name, bool is_group )
|
||||
{
|
||||
LLStringUtil::format_map_t args;
|
||||
|
||||
std::string name;
|
||||
if (LLAvatarNameCache::useDisplayNames())
|
||||
{
|
||||
name = LLCacheName::buildUsername(full_name);
|
||||
}
|
||||
else
|
||||
{
|
||||
name = full_name;
|
||||
}
|
||||
|
||||
args["[NAME]"] = name;
|
||||
|
||||
std::string linden_name = getString("name_text_args", args);
|
||||
getChild<LLUICtrl>("name_descr_text")->setValue(linden_name);
|
||||
}
|
||||
|
||||
void LLPanelAvatarProfile::onNameCache(const LLUUID& agent_id, const LLAvatarName& av_name)
|
||||
{
|
||||
LLStringUtil::format_map_t args;
|
||||
args["[DISPLAY_NAME]"] = av_name.mDisplayName;
|
||||
|
||||
std::string display_name = getString("display_name_text_args", args);
|
||||
getChild<LLUICtrl>("display_name_descr_text")->setValue(display_name);
|
||||
}
|
||||
|
||||
void LLPanelAvatarProfile::fillCommonData(const LLAvatarData* avatar_data)
|
||||
{
|
||||
//remove avatar id from cache to get fresh info
|
||||
|
|
@ -635,6 +665,24 @@ void LLPanelAvatarProfile::fillCommonData(const LLAvatarData* avatar_data)
|
|||
LLStringUtil::format(birth_date, LLSD().with("datetime", (S32) avatar_data->born_on.secondsSinceEpoch()));
|
||||
args["[REG_DATE]"] = birth_date;
|
||||
}
|
||||
|
||||
// ask (asynchronously) for the avatar name
|
||||
std::string full_name;
|
||||
if (gCacheName->getFullName(avatar_data->agent_id, full_name))
|
||||
{
|
||||
// name in cache, call callback directly
|
||||
got_full_name_callback( avatar_data->agent_id, full_name, false );
|
||||
}
|
||||
else
|
||||
{
|
||||
// not in cache, lookup name
|
||||
gCacheName->get(avatar_data->agent_id, false, boost::bind( &LLPanelAvatarProfile::got_full_name_callback, this, _1, _2, _3 ));
|
||||
}
|
||||
|
||||
// get display name
|
||||
LLAvatarNameCache::get(avatar_data->avatar_id,
|
||||
boost::bind(&LLPanelAvatarProfile::onNameCache, this, _1, _2));
|
||||
|
||||
args["[AGE]"] = LLDateUtil::ageFromDate( avatar_data->born_on, LLDate::now());
|
||||
std::string register_date = getString("RegisterDateFormat", args);
|
||||
getChild<LLUICtrl>("register_date")->setValue(register_date );
|
||||
|
|
@ -734,6 +782,11 @@ void LLPanelAvatarProfile::onAddFriendButtonClick()
|
|||
LLAvatarActions::requestFriendshipDialog(getAvatarId());
|
||||
}
|
||||
|
||||
void LLPanelAvatarProfile::onSeeProfileBtnClick()
|
||||
{
|
||||
LLAvatarActions::showProfile(getAvatarId());
|
||||
}
|
||||
|
||||
void LLPanelAvatarProfile::onIMButtonClick()
|
||||
{
|
||||
LLAvatarActions::startIM(getAvatarId());
|
||||
|
|
|
|||
|
|
@ -1,295 +1,298 @@
|
|||
/**
|
||||
* @file llpanelavatar.h
|
||||
* @brief LLPanelAvatar and related class definitions
|
||||
*
|
||||
* $LicenseInfo:firstyear=2004&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$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLPANELAVATAR_H
|
||||
#define LL_LLPANELAVATAR_H
|
||||
|
||||
#include "llpanel.h"
|
||||
#include "llavatarpropertiesprocessor.h"
|
||||
#include "llcallingcard.h"
|
||||
#include "llvoiceclient.h"
|
||||
|
||||
class LLComboBox;
|
||||
class LLLineEditor;
|
||||
|
||||
enum EOnlineStatus
|
||||
{
|
||||
ONLINE_STATUS_NO = 0,
|
||||
ONLINE_STATUS_YES = 1
|
||||
};
|
||||
|
||||
/**
|
||||
* Base class for any Profile View or My Profile Panel.
|
||||
*/
|
||||
class LLPanelProfileTab
|
||||
: public LLPanel
|
||||
, public LLAvatarPropertiesObserver
|
||||
{
|
||||
public:
|
||||
|
||||
/**
|
||||
* Sets avatar ID, sets panel as observer of avatar related info replies from server.
|
||||
*/
|
||||
virtual void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* Returns avatar ID.
|
||||
*/
|
||||
virtual const LLUUID& getAvatarId() { return mAvatarId; }
|
||||
|
||||
/**
|
||||
* Sends update data request to server.
|
||||
*/
|
||||
virtual void updateData() = 0;
|
||||
|
||||
/**
|
||||
* Clears panel data if viewing avatar info for first time and sends update data request.
|
||||
*/
|
||||
virtual void onOpen(const LLSD& key);
|
||||
|
||||
/**
|
||||
* Profile tabs should close any opened panels here.
|
||||
*
|
||||
* Called from LLPanelProfile::onOpen() before opening new profile.
|
||||
* See LLPanelPicks::onClosePanel for example. LLPanelPicks closes picture info panel
|
||||
* before new profile is displayed, otherwise new profile will
|
||||
* be hidden behind picture info panel.
|
||||
*/
|
||||
virtual void onClosePanel() {}
|
||||
|
||||
/**
|
||||
* Resets controls visibility, state, etc.
|
||||
*/
|
||||
virtual void resetControls(){};
|
||||
|
||||
/**
|
||||
* Clears all data received from server.
|
||||
*/
|
||||
virtual void resetData(){};
|
||||
|
||||
/*virtual*/ ~LLPanelProfileTab();
|
||||
|
||||
protected:
|
||||
|
||||
LLPanelProfileTab();
|
||||
|
||||
/**
|
||||
* Scrolls panel to top when viewing avatar info for first time.
|
||||
*/
|
||||
void scrollToTop();
|
||||
|
||||
virtual void onMapButtonClick();
|
||||
|
||||
virtual void updateButtons();
|
||||
|
||||
private:
|
||||
|
||||
LLUUID mAvatarId;
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying Avatar's first and second life related info.
|
||||
*/
|
||||
class LLPanelAvatarProfile
|
||||
: public LLPanelProfileTab
|
||||
, public LLFriendObserver
|
||||
, public LLVoiceClientStatusObserver
|
||||
{
|
||||
public:
|
||||
LLPanelAvatarProfile();
|
||||
/*virtual*/ ~LLPanelAvatarProfile();
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/**
|
||||
* LLFriendObserver trigger
|
||||
*/
|
||||
virtual void changed(U32 mask);
|
||||
|
||||
// Implements LLVoiceClientStatusObserver::onChange() to enable the call
|
||||
// button when voice is available
|
||||
/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal);
|
||||
|
||||
/*virtual*/ void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* Processes data received from server.
|
||||
*/
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type);
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
/*virtual*/ void updateData();
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
/*virtual*/ void resetData();
|
||||
|
||||
protected:
|
||||
|
||||
/**
|
||||
* Process profile related data received from server.
|
||||
*/
|
||||
virtual void processProfileProperties(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Processes group related data received from server.
|
||||
*/
|
||||
virtual void processGroupProperties(const LLAvatarGroups* avatar_groups);
|
||||
|
||||
/**
|
||||
* Fills common for Avatar profile and My Profile fields.
|
||||
*/
|
||||
virtual void fillCommonData(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Fills partner data.
|
||||
*/
|
||||
virtual void fillPartnerData(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Fills account status.
|
||||
*/
|
||||
virtual void fillAccountStatus(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Opens "Pay Resident" dialog.
|
||||
*/
|
||||
void pay();
|
||||
|
||||
/**
|
||||
* opens inventory and IM for sharing items
|
||||
*/
|
||||
void share();
|
||||
|
||||
/**
|
||||
* Add/remove resident to/from your block list.
|
||||
*/
|
||||
void toggleBlock();
|
||||
|
||||
void kick();
|
||||
void freeze();
|
||||
void unfreeze();
|
||||
void csr();
|
||||
|
||||
bool enableShowOnMap();
|
||||
bool enableBlock();
|
||||
bool enableUnblock();
|
||||
bool enableGod();
|
||||
|
||||
|
||||
void onAddFriendButtonClick();
|
||||
void onIMButtonClick();
|
||||
void onCallButtonClick();
|
||||
void onTeleportButtonClick();
|
||||
void onShareButtonClick();
|
||||
|
||||
private:
|
||||
|
||||
typedef std::map< std::string,LLUUID> group_map_t;
|
||||
group_map_t mGroups;
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying own first and second life related info.
|
||||
*/
|
||||
class LLPanelMyProfile
|
||||
: public LLPanelAvatarProfile
|
||||
{
|
||||
public:
|
||||
LLPanelMyProfile();
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
protected:
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/*virtual*/ void processProfileProperties(const LLAvatarData* avatar_data);
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
protected:
|
||||
void onStatusMessageChanged();
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying Avatar's notes and modifying friend's rights.
|
||||
*/
|
||||
class LLPanelAvatarNotes
|
||||
: public LLPanelProfileTab
|
||||
, public LLFriendObserver
|
||||
, public LLVoiceClientStatusObserver
|
||||
{
|
||||
public:
|
||||
LLPanelAvatarNotes();
|
||||
/*virtual*/ ~LLPanelAvatarNotes();
|
||||
|
||||
virtual void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* LLFriendObserver trigger
|
||||
*/
|
||||
virtual void changed(U32 mask);
|
||||
|
||||
// Implements LLVoiceClientStatusObserver::onChange() to enable the call
|
||||
// button when voice is available
|
||||
/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal);
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type);
|
||||
|
||||
/*virtual*/ void updateData();
|
||||
|
||||
protected:
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
/*virtual*/ void resetData();
|
||||
|
||||
/**
|
||||
* Fills rights data for friends.
|
||||
*/
|
||||
void fillRightsData();
|
||||
|
||||
void rightsConfirmationCallback(const LLSD& notification,
|
||||
const LLSD& response, S32 rights);
|
||||
void confirmModifyRights(bool grant, S32 rights);
|
||||
void onCommitRights();
|
||||
void onCommitNotes();
|
||||
|
||||
void onAddFriendButtonClick();
|
||||
void onIMButtonClick();
|
||||
void onCallButtonClick();
|
||||
void onTeleportButtonClick();
|
||||
void onShareButtonClick();
|
||||
void enableCheckboxes(bool enable);
|
||||
};
|
||||
|
||||
#endif // LL_LLPANELAVATAR_H
|
||||
/**
|
||||
* @file llpanelavatar.h
|
||||
* @brief LLPanelAvatar and related class definitions
|
||||
*
|
||||
* $LicenseInfo:firstyear=2004&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$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLPANELAVATAR_H
|
||||
#define LL_LLPANELAVATAR_H
|
||||
|
||||
#include "llpanel.h"
|
||||
#include "llavatarpropertiesprocessor.h"
|
||||
#include "llcallingcard.h"
|
||||
#include "llvoiceclient.h"
|
||||
#include "llavatarnamecache.h"
|
||||
|
||||
class LLComboBox;
|
||||
class LLLineEditor;
|
||||
|
||||
enum EOnlineStatus
|
||||
{
|
||||
ONLINE_STATUS_NO = 0,
|
||||
ONLINE_STATUS_YES = 1
|
||||
};
|
||||
|
||||
/**
|
||||
* Base class for any Profile View or My Profile Panel.
|
||||
*/
|
||||
class LLPanelProfileTab
|
||||
: public LLPanel
|
||||
, public LLAvatarPropertiesObserver
|
||||
{
|
||||
public:
|
||||
|
||||
/**
|
||||
* Sets avatar ID, sets panel as observer of avatar related info replies from server.
|
||||
*/
|
||||
virtual void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* Returns avatar ID.
|
||||
*/
|
||||
virtual const LLUUID& getAvatarId() { return mAvatarId; }
|
||||
|
||||
/**
|
||||
* Sends update data request to server.
|
||||
*/
|
||||
virtual void updateData() = 0;
|
||||
|
||||
/**
|
||||
* Clears panel data if viewing avatar info for first time and sends update data request.
|
||||
*/
|
||||
virtual void onOpen(const LLSD& key);
|
||||
|
||||
/**
|
||||
* Profile tabs should close any opened panels here.
|
||||
*
|
||||
* Called from LLPanelProfile::onOpen() before opening new profile.
|
||||
* See LLPanelPicks::onClosePanel for example. LLPanelPicks closes picture info panel
|
||||
* before new profile is displayed, otherwise new profile will
|
||||
* be hidden behind picture info panel.
|
||||
*/
|
||||
virtual void onClosePanel() {}
|
||||
|
||||
/**
|
||||
* Resets controls visibility, state, etc.
|
||||
*/
|
||||
virtual void resetControls(){};
|
||||
|
||||
/**
|
||||
* Clears all data received from server.
|
||||
*/
|
||||
virtual void resetData(){};
|
||||
|
||||
/*virtual*/ ~LLPanelProfileTab();
|
||||
|
||||
protected:
|
||||
|
||||
LLPanelProfileTab();
|
||||
|
||||
/**
|
||||
* Scrolls panel to top when viewing avatar info for first time.
|
||||
*/
|
||||
void scrollToTop();
|
||||
|
||||
virtual void onMapButtonClick();
|
||||
|
||||
virtual void updateButtons();
|
||||
|
||||
private:
|
||||
|
||||
LLUUID mAvatarId;
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying Avatar's first and second life related info.
|
||||
*/
|
||||
class LLPanelAvatarProfile
|
||||
: public LLPanelProfileTab
|
||||
, public LLFriendObserver
|
||||
, public LLVoiceClientStatusObserver
|
||||
{
|
||||
public:
|
||||
LLPanelAvatarProfile();
|
||||
/*virtual*/ ~LLPanelAvatarProfile();
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/**
|
||||
* LLFriendObserver trigger
|
||||
*/
|
||||
virtual void changed(U32 mask);
|
||||
|
||||
// Implements LLVoiceClientStatusObserver::onChange() to enable the call
|
||||
// button when voice is available
|
||||
/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal);
|
||||
|
||||
/*virtual*/ void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* Processes data received from server.
|
||||
*/
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type);
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
/*virtual*/ void updateData();
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
/*virtual*/ void resetData();
|
||||
|
||||
protected:
|
||||
|
||||
/**
|
||||
* Process profile related data received from server.
|
||||
*/
|
||||
virtual void processProfileProperties(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Processes group related data received from server.
|
||||
*/
|
||||
virtual void processGroupProperties(const LLAvatarGroups* avatar_groups);
|
||||
|
||||
/**
|
||||
* Fills common for Avatar profile and My Profile fields.
|
||||
*/
|
||||
virtual void fillCommonData(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Fills partner data.
|
||||
*/
|
||||
virtual void fillPartnerData(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Fills account status.
|
||||
*/
|
||||
virtual void fillAccountStatus(const LLAvatarData* avatar_data);
|
||||
|
||||
/**
|
||||
* Opens "Pay Resident" dialog.
|
||||
*/
|
||||
void pay();
|
||||
|
||||
/**
|
||||
* opens inventory and IM for sharing items
|
||||
*/
|
||||
void share();
|
||||
|
||||
/**
|
||||
* Add/remove resident to/from your block list.
|
||||
*/
|
||||
void toggleBlock();
|
||||
|
||||
void kick();
|
||||
void freeze();
|
||||
void unfreeze();
|
||||
void csr();
|
||||
|
||||
bool enableShowOnMap();
|
||||
bool enableBlock();
|
||||
bool enableUnblock();
|
||||
bool enableGod();
|
||||
|
||||
void onSeeProfileBtnClick();
|
||||
void onAddFriendButtonClick();
|
||||
void onIMButtonClick();
|
||||
void onCallButtonClick();
|
||||
void onTeleportButtonClick();
|
||||
void onShareButtonClick();
|
||||
|
||||
private:
|
||||
void got_full_name_callback( const LLUUID& id, const std::string& full_name, bool is_group );
|
||||
void onNameCache(const LLUUID& agent_id, const LLAvatarName& av_name);
|
||||
|
||||
typedef std::map< std::string,LLUUID> group_map_t;
|
||||
group_map_t mGroups;
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying own first and second life related info.
|
||||
*/
|
||||
class LLPanelMyProfile
|
||||
: public LLPanelAvatarProfile
|
||||
{
|
||||
public:
|
||||
LLPanelMyProfile();
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
protected:
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/*virtual*/ void processProfileProperties(const LLAvatarData* avatar_data);
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
protected:
|
||||
void onStatusMessageChanged();
|
||||
};
|
||||
|
||||
/**
|
||||
* Panel for displaying Avatar's notes and modifying friend's rights.
|
||||
*/
|
||||
class LLPanelAvatarNotes
|
||||
: public LLPanelProfileTab
|
||||
, public LLFriendObserver
|
||||
, public LLVoiceClientStatusObserver
|
||||
{
|
||||
public:
|
||||
LLPanelAvatarNotes();
|
||||
/*virtual*/ ~LLPanelAvatarNotes();
|
||||
|
||||
virtual void setAvatarId(const LLUUID& id);
|
||||
|
||||
/**
|
||||
* LLFriendObserver trigger
|
||||
*/
|
||||
virtual void changed(U32 mask);
|
||||
|
||||
// Implements LLVoiceClientStatusObserver::onChange() to enable the call
|
||||
// button when voice is available
|
||||
/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal);
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type);
|
||||
|
||||
/*virtual*/ void updateData();
|
||||
|
||||
protected:
|
||||
|
||||
/*virtual*/ void resetControls();
|
||||
|
||||
/*virtual*/ void resetData();
|
||||
|
||||
/**
|
||||
* Fills rights data for friends.
|
||||
*/
|
||||
void fillRightsData();
|
||||
|
||||
void rightsConfirmationCallback(const LLSD& notification,
|
||||
const LLSD& response, S32 rights);
|
||||
void confirmModifyRights(bool grant, S32 rights);
|
||||
void onCommitRights();
|
||||
void onCommitNotes();
|
||||
|
||||
void onAddFriendButtonClick();
|
||||
void onIMButtonClick();
|
||||
void onCallButtonClick();
|
||||
void onTeleportButtonClick();
|
||||
void onShareButtonClick();
|
||||
void enableCheckboxes(bool enable);
|
||||
};
|
||||
|
||||
#endif // LL_LLPANELAVATAR_H
|
||||
|
|
|
|||
|
|
@ -70,6 +70,111 @@ static const std::string CLASSIFIED_NAME("classified_name");
|
|||
|
||||
static LLRegisterPanelClassWrapper<LLPanelPicks> t_panel_picks("panel_picks");
|
||||
|
||||
class LLPickHandler : public LLCommandHandler,
|
||||
public LLAvatarPropertiesObserver
|
||||
{
|
||||
public:
|
||||
|
||||
std::set<LLUUID> mPickIds;
|
||||
|
||||
// requires trusted browser to trigger
|
||||
LLPickHandler() : LLCommandHandler("pick", UNTRUSTED_THROTTLE) { }
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map,
|
||||
LLMediaCtrl* web)
|
||||
{
|
||||
// handle app/classified/create urls first
|
||||
if (params.size() == 1 && params[0].asString() == "create")
|
||||
{
|
||||
createPick();
|
||||
return true;
|
||||
}
|
||||
|
||||
// then handle the general app/pick/{UUID}/{CMD} urls
|
||||
if (params.size() < 2)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
// get the ID for the pick_id
|
||||
LLUUID pick_id;
|
||||
if (!pick_id.set(params[0], FALSE))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
// edit the pick in the side tray.
|
||||
// need to ask the server for more info first though...
|
||||
const std::string verb = params[1].asString();
|
||||
if (verb == "edit")
|
||||
{
|
||||
mPickIds.insert(pick_id);
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver(LLUUID(), this);
|
||||
LLAvatarPropertiesProcessor::getInstance()->sendPickInfoRequest(gAgent.getID(),pick_id);
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
llwarns << "unknown verb " << verb << llendl;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
void createPick()
|
||||
{
|
||||
LLSD params;
|
||||
params["id"] = gAgent.getID();
|
||||
params["open_tab_name"] = "panel_picks";
|
||||
params["show_tab_panel"] = "create_pick";
|
||||
LLSideTray::getInstance()->showPanel("panel_me", params);
|
||||
}
|
||||
|
||||
void editPick(LLPickData* pick_info)
|
||||
{
|
||||
LLSD params;
|
||||
params["open_tab_name"] = "panel_picks";
|
||||
params["show_tab_panel"] = "edit_pick";
|
||||
params["pick_id"] = pick_info->pick_id;
|
||||
params["avatar_id"] = pick_info->creator_id;
|
||||
params["snapshot_id"] = pick_info->snapshot_id;
|
||||
params["pick_name"] = pick_info->name;
|
||||
params["pick_desc"] = pick_info->desc;
|
||||
|
||||
LLSideTray::getInstance()->showPanel("panel_me", params);
|
||||
}
|
||||
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type)
|
||||
{
|
||||
if (APT_PICK_INFO != type)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
// is this the pick that we asked for?
|
||||
LLPickData* pick_info = static_cast<LLPickData*>(data);
|
||||
if (!pick_info || mPickIds.find(pick_info->pick_id) == mPickIds.end())
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
// open the edit side tray for this pick
|
||||
if (pick_info->creator_id == gAgent.getID())
|
||||
{
|
||||
editPick(pick_info);
|
||||
}
|
||||
else
|
||||
{
|
||||
llwarns << "Can't edit a pick you did not create" << llendl;
|
||||
}
|
||||
|
||||
// remove our observer now that we're done
|
||||
mPickIds.erase(pick_info->pick_id);
|
||||
LLAvatarPropertiesProcessor::getInstance()->removeObserver(LLUUID(), this);
|
||||
}
|
||||
};
|
||||
|
||||
LLPickHandler gPickHandler;
|
||||
|
||||
class LLClassifiedHandler :
|
||||
public LLCommandHandler,
|
||||
public LLAvatarPropertiesObserver
|
||||
|
|
@ -80,6 +185,8 @@ public:
|
|||
|
||||
std::set<LLUUID> mClassifiedIds;
|
||||
|
||||
std::string mRequestVerb;
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map, LLMediaCtrl* web)
|
||||
{
|
||||
// handle app/classified/create urls first
|
||||
|
|
@ -107,6 +214,15 @@ public:
|
|||
const std::string verb = params[1].asString();
|
||||
if (verb == "about")
|
||||
{
|
||||
mRequestVerb = verb;
|
||||
mClassifiedIds.insert(classified_id);
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver(LLUUID(), this);
|
||||
LLAvatarPropertiesProcessor::getInstance()->sendClassifiedInfoRequest(classified_id);
|
||||
return true;
|
||||
}
|
||||
else if (verb == "edit")
|
||||
{
|
||||
mRequestVerb = verb;
|
||||
mClassifiedIds.insert(classified_id);
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver(LLUUID(), this);
|
||||
LLAvatarPropertiesProcessor::getInstance()->sendClassifiedInfoRequest(classified_id);
|
||||
|
|
@ -128,18 +244,39 @@ public:
|
|||
|
||||
void openClassified(LLAvatarClassifiedInfo* c_info)
|
||||
{
|
||||
// open the classified info panel on the Me > Picks sidetray
|
||||
LLSD params;
|
||||
params["id"] = c_info->creator_id;
|
||||
params["open_tab_name"] = "panel_picks";
|
||||
params["show_tab_panel"] = "classified_details";
|
||||
params["classified_id"] = c_info->classified_id;
|
||||
params["classified_creator_id"] = c_info->creator_id;
|
||||
params["classified_snapshot_id"] = c_info->snapshot_id;
|
||||
params["classified_name"] = c_info->name;
|
||||
params["classified_desc"] = c_info->description;
|
||||
params["from_search"] = true;
|
||||
LLSideTray::getInstance()->showPanel("panel_profile_view", params);
|
||||
if (mRequestVerb == "about")
|
||||
{
|
||||
// open the classified info panel on the Me > Picks sidetray
|
||||
LLSD params;
|
||||
params["id"] = c_info->creator_id;
|
||||
params["open_tab_name"] = "panel_picks";
|
||||
params["show_tab_panel"] = "classified_details";
|
||||
params["classified_id"] = c_info->classified_id;
|
||||
params["classified_creator_id"] = c_info->creator_id;
|
||||
params["classified_snapshot_id"] = c_info->snapshot_id;
|
||||
params["classified_name"] = c_info->name;
|
||||
params["classified_desc"] = c_info->description;
|
||||
params["from_search"] = true;
|
||||
LLSideTray::getInstance()->showPanel("panel_profile_view", params);
|
||||
}
|
||||
else if (mRequestVerb == "edit")
|
||||
{
|
||||
if (c_info->creator_id == gAgent.getID())
|
||||
{
|
||||
llwarns << "edit in progress" << llendl;
|
||||
// open the new classified panel on the Me > Picks sidetray
|
||||
LLSD params;
|
||||
params["id"] = gAgent.getID();
|
||||
params["open_tab_name"] = "panel_picks";
|
||||
params["show_tab_panel"] = "edit_classified";
|
||||
params["classified_id"] = c_info->classified_id;
|
||||
LLSideTray::getInstance()->showPanel("panel_me", params);
|
||||
}
|
||||
else
|
||||
{
|
||||
llwarns << "Can't edit a classified you did not create" << llendl;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*virtual*/ void processProperties(void* data, EAvatarProcessorType type)
|
||||
|
|
@ -299,7 +436,10 @@ void LLPanelPicks::processProperties(void* data, EAvatarProcessorType type)
|
|||
pick_value.insert(CLASSIFIED_ID, c_data.classified_id);
|
||||
pick_value.insert(CLASSIFIED_NAME, c_data.name);
|
||||
|
||||
mClassifiedsList->addItem(c_item, pick_value);
|
||||
if (!findClassifiedById(c_data.classified_id))
|
||||
{
|
||||
mClassifiedsList->addItem(c_item, pick_value);
|
||||
}
|
||||
|
||||
c_item->setDoubleClickCallback(boost::bind(&LLPanelPicks::onDoubleClickClassifiedItem, this, _1));
|
||||
c_item->setRightMouseUpCallback(boost::bind(&LLPanelPicks::onRightMouseUpItem, this, _1, _2, _3, _4));
|
||||
|
|
@ -776,6 +916,13 @@ void LLPanelPicks::openClassifiedInfo(const LLSD ¶ms)
|
|||
getProfilePanel()->openPanel(mPanelClassifiedInfo, params);
|
||||
}
|
||||
|
||||
void LLPanelPicks::openClassifiedEdit(const LLSD& params)
|
||||
{
|
||||
LLUUID classified_id = params["classified_id"].asUUID();;
|
||||
llinfos << "opening classified " << classified_id << " for edit" << llendl;
|
||||
editClassified(classified_id);
|
||||
}
|
||||
|
||||
void LLPanelPicks::showAccordion(const std::string& name, bool show)
|
||||
{
|
||||
LLAccordionCtrlTab* tab = getChild<LLAccordionCtrlTab>(name);
|
||||
|
|
@ -945,6 +1092,12 @@ void LLPanelPicks::createPickEditPanel()
|
|||
// getProfilePanel()->openPanel(mPanelPickInfo, params);
|
||||
// }
|
||||
|
||||
void LLPanelPicks::openPickEdit(const LLSD& params)
|
||||
{
|
||||
createPickEditPanel();
|
||||
getProfilePanel()->openPanel(mPanelPickEdit, params);
|
||||
}
|
||||
|
||||
void LLPanelPicks::onPanelPickEdit()
|
||||
{
|
||||
LLSD selected_value = mPicksList->getSelectedValue();
|
||||
|
|
@ -978,6 +1131,35 @@ void LLPanelPicks::onPanelClassifiedEdit()
|
|||
{
|
||||
return;
|
||||
}
|
||||
editClassified(c_item->getClassifiedId());
|
||||
}
|
||||
|
||||
LLClassifiedItem *LLPanelPicks::findClassifiedById(const LLUUID& classified_id)
|
||||
{
|
||||
// HACK - find item by classified id. Should be a better way.
|
||||
std::vector<LLPanel*> items;
|
||||
mClassifiedsList->getItems(items);
|
||||
LLClassifiedItem* c_item = NULL;
|
||||
for(std::vector<LLPanel*>::iterator it = items.begin(); it != items.end(); ++it)
|
||||
{
|
||||
LLClassifiedItem *test_item = dynamic_cast<LLClassifiedItem*>(*it);
|
||||
if (test_item && test_item->getClassifiedId() == classified_id)
|
||||
{
|
||||
c_item = test_item;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return c_item;
|
||||
}
|
||||
|
||||
void LLPanelPicks::editClassified(const LLUUID& classified_id)
|
||||
{
|
||||
LLClassifiedItem* c_item = findClassifiedById(classified_id);
|
||||
if (!c_item)
|
||||
{
|
||||
llwarns << "item not found for classified_id " << classified_id << llendl;
|
||||
return;
|
||||
}
|
||||
|
||||
LLSD params;
|
||||
params["classified_id"] = c_item->getClassifiedId();
|
||||
|
|
|
|||
|
|
@ -76,6 +76,7 @@ public:
|
|||
// returns the selected pick item
|
||||
LLPickItem* getSelectedPickItem();
|
||||
LLClassifiedItem* getSelectedClassifiedItem();
|
||||
LLClassifiedItem* findClassifiedById(const LLUUID& classified_id);
|
||||
|
||||
//*NOTE top down approch when panel toggling is done only by
|
||||
// parent panels failed to work (picks related code was in my profile panel)
|
||||
|
|
@ -106,8 +107,10 @@ private:
|
|||
void onPanelPickSave(LLPanel* panel);
|
||||
void onPanelClassifiedSave(LLPanelClassifiedEdit* panel);
|
||||
void onPanelClassifiedClose(LLPanelClassifiedInfo* panel);
|
||||
void openPickEdit(const LLSD& params);
|
||||
void onPanelPickEdit();
|
||||
void onPanelClassifiedEdit();
|
||||
void editClassified(const LLUUID& classified_id);
|
||||
void onClickMenuEdit();
|
||||
|
||||
bool onEnableMenuItem(const LLSD& user_data);
|
||||
|
|
@ -118,6 +121,7 @@ private:
|
|||
void openPickInfo();
|
||||
void openClassifiedInfo();
|
||||
void openClassifiedInfo(const LLSD& params);
|
||||
void openClassifiedEdit(const LLSD& params);
|
||||
friend class LLPanelProfile;
|
||||
|
||||
void showAccordion(const std::string& name, bool show);
|
||||
|
|
|
|||
|
|
@ -93,7 +93,8 @@ LLPanelPrimMediaControls::LLPanelPrimMediaControls() :
|
|||
mZoomObjectID(LLUUID::null),
|
||||
mZoomObjectFace(0),
|
||||
mVolumeSliderVisible(0),
|
||||
mWindowShade(NULL)
|
||||
mWindowShade(NULL),
|
||||
mHideImmediately(false)
|
||||
{
|
||||
mCommitCallbackRegistrar.add("MediaCtrl.Close", boost::bind(&LLPanelPrimMediaControls::onClickClose, this));
|
||||
mCommitCallbackRegistrar.add("MediaCtrl.Back", boost::bind(&LLPanelPrimMediaControls::onClickBack, this));
|
||||
|
|
@ -208,6 +209,8 @@ BOOL LLPanelPrimMediaControls::postBuild()
|
|||
|
||||
mMediaAddress->setFocusReceivedCallback(boost::bind(&LLPanelPrimMediaControls::onInputURL, _1, this ));
|
||||
|
||||
gAgent.setMouselookModeInCallback(boost::bind(&LLPanelPrimMediaControls::onMouselookModeIn, this));
|
||||
|
||||
LLWindowShade::Params window_shade_params;
|
||||
window_shade_params.name = "window_shade";
|
||||
|
||||
|
|
@ -725,26 +728,22 @@ void LLPanelPrimMediaControls::draw()
|
|||
}
|
||||
|
||||
F32 alpha = getDrawContext().mAlpha;
|
||||
if(mFadeTimer.getStarted())
|
||||
if(mHideImmediately)
|
||||
{
|
||||
//hide this panel
|
||||
clearFaceOnFade();
|
||||
|
||||
mHideImmediately = false;
|
||||
}
|
||||
else if(mFadeTimer.getStarted())
|
||||
{
|
||||
F32 time = mFadeTimer.getElapsedTimeF32();
|
||||
alpha *= llmax(lerp(1.0, 0.0, time / mControlFadeTime), 0.0f);
|
||||
|
||||
if(time >= mControlFadeTime)
|
||||
{
|
||||
if(mClearFaceOnFade)
|
||||
{
|
||||
// Hiding this object makes scroll events go missing after it fades out
|
||||
// (see DEV-41755 for a full description of the train wreck).
|
||||
// Only hide the controls when we're untargeting.
|
||||
setVisible(FALSE);
|
||||
|
||||
mClearFaceOnFade = false;
|
||||
mVolumeSliderVisible = 0;
|
||||
mTargetImplID = LLUUID::null;
|
||||
mTargetObjectID = LLUUID::null;
|
||||
mTargetObjectFace = 0;
|
||||
}
|
||||
//hide this panel
|
||||
clearFaceOnFade();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -1322,6 +1321,30 @@ bool LLPanelPrimMediaControls::shouldVolumeSliderBeVisible()
|
|||
return mVolumeSliderVisible > 0;
|
||||
}
|
||||
|
||||
|
||||
void LLPanelPrimMediaControls::clearFaceOnFade()
|
||||
{
|
||||
if(mClearFaceOnFade)
|
||||
{
|
||||
// Hiding this object makes scroll events go missing after it fades out
|
||||
// (see DEV-41755 for a full description of the train wreck).
|
||||
// Only hide the controls when we're untargeting.
|
||||
setVisible(FALSE);
|
||||
|
||||
mClearFaceOnFade = false;
|
||||
mVolumeSliderVisible = 0;
|
||||
mTargetImplID = LLUUID::null;
|
||||
mTargetObjectID = LLUUID::null;
|
||||
mTargetObjectFace = 0;
|
||||
}
|
||||
}
|
||||
|
||||
void LLPanelPrimMediaControls::onMouselookModeIn()
|
||||
{
|
||||
LLViewerMediaFocus::getInstance()->clearHover();
|
||||
mHideImmediately = true;
|
||||
}
|
||||
|
||||
void LLPanelPrimMediaControls::showNotification(LLNotificationPtr notify)
|
||||
{
|
||||
delete mWindowShade;
|
||||
|
|
|
|||
|
|
@ -59,6 +59,7 @@ public:
|
|||
void showNotification(LLNotificationPtr notify);
|
||||
void hideNotification();
|
||||
|
||||
|
||||
enum EZoomLevel
|
||||
{
|
||||
ZOOM_NONE = 0,
|
||||
|
|
@ -136,7 +137,11 @@ private:
|
|||
LLPluginClassMedia* getTargetMediaPlugin();
|
||||
|
||||
private:
|
||||
|
||||
|
||||
void clearFaceOnFade();
|
||||
|
||||
void onMouselookModeIn();
|
||||
|
||||
LLView *mMediaRegion;
|
||||
LLUICtrl *mBackCtrl;
|
||||
LLUICtrl *mFwdCtrl;
|
||||
|
|
@ -185,6 +190,7 @@ private:
|
|||
bool mPauseFadeout;
|
||||
bool mUpdateSlider;
|
||||
bool mClearFaceOnFade;
|
||||
bool mHideImmediately;
|
||||
|
||||
LLMatrix4 mLastCameraMat;
|
||||
EZoomLevel mCurrentZoom;
|
||||
|
|
|
|||
|
|
@ -33,10 +33,41 @@
|
|||
#include "llcommandhandler.h"
|
||||
#include "llpanelpicks.h"
|
||||
#include "lltabcontainer.h"
|
||||
#include "llviewercontrol.h"
|
||||
|
||||
static const std::string PANEL_PICKS = "panel_picks";
|
||||
static const std::string PANEL_PROFILE = "panel_profile";
|
||||
|
||||
std::string getProfileURL(const std::string& agent_name)
|
||||
{
|
||||
std::string url = gSavedSettings.getString("WebProfileURL");
|
||||
LLSD subs;
|
||||
subs["AGENT_NAME"] = agent_name;
|
||||
url = LLWeb::expandURLSubstitutions(url,subs);
|
||||
LLStringUtil::toLower(url);
|
||||
return url;
|
||||
}
|
||||
|
||||
class LLProfileHandler : public LLCommandHandler
|
||||
{
|
||||
public:
|
||||
// requires trusted browser to trigger
|
||||
LLProfileHandler() : LLCommandHandler("profile", UNTRUSTED_THROTTLE) { }
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map,
|
||||
LLMediaCtrl* web)
|
||||
{
|
||||
if (params.size() < 1) return false;
|
||||
std::string agent_name = params[0];
|
||||
llinfos << "Profile, agent_name " << agent_name << llendl;
|
||||
std::string url = getProfileURL(agent_name);
|
||||
LLWeb::loadWebURLInternal(url);
|
||||
|
||||
return true;
|
||||
}
|
||||
};
|
||||
LLProfileHandler gProfileHandler;
|
||||
|
||||
class LLAgentHandler : public LLCommandHandler
|
||||
{
|
||||
public:
|
||||
|
|
@ -281,6 +312,36 @@ void LLPanelProfile::onOpen(const LLSD& key)
|
|||
picks->openClassifiedInfo(params);
|
||||
}
|
||||
}
|
||||
else if (panel == "edit_classified")
|
||||
{
|
||||
LLPanelPicks* picks = dynamic_cast<LLPanelPicks *>(getTabContainer()[PANEL_PICKS]);
|
||||
if (picks)
|
||||
{
|
||||
LLSD params = key;
|
||||
params.erase("show_tab_panel");
|
||||
params.erase("open_tab_name");
|
||||
picks->openClassifiedEdit(params);
|
||||
}
|
||||
}
|
||||
else if (panel == "create_pick")
|
||||
{
|
||||
LLPanelPicks* picks = dynamic_cast<LLPanelPicks *>(getTabContainer()[PANEL_PICKS]);
|
||||
if (picks)
|
||||
{
|
||||
picks->createNewPick();
|
||||
}
|
||||
}
|
||||
else if (panel == "edit_pick")
|
||||
{
|
||||
LLPanelPicks* picks = dynamic_cast<LLPanelPicks *>(getTabContainer()[PANEL_PICKS]);
|
||||
if (picks)
|
||||
{
|
||||
LLSD params = key;
|
||||
params.erase("show_tab_panel");
|
||||
params.erase("open_tab_name");
|
||||
picks->openPickEdit(params);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -32,6 +32,8 @@
|
|||
|
||||
class LLTabContainer;
|
||||
|
||||
std::string getProfileURL(const std::string& agent_name);
|
||||
|
||||
/**
|
||||
* Base class for Profile View and My Profile.
|
||||
*/
|
||||
|
|
|
|||
|
|
@ -0,0 +1,59 @@
|
|||
/**
|
||||
* @file llshareavatarhandler.cpp
|
||||
* @brief slapp to handle sharing with an avatar
|
||||
*
|
||||
* $LicenseInfo:firstyear=2001&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$
|
||||
*/
|
||||
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
#include "llcommandhandler.h"
|
||||
#include "llavataractions.h"
|
||||
|
||||
class LLShareWithAvatarHandler : public LLCommandHandler
|
||||
{
|
||||
public:
|
||||
// requires trusted browser to trigger
|
||||
LLShareWithAvatarHandler() : LLCommandHandler("sharewithavatar", UNTRUSTED_THROTTLE)
|
||||
{
|
||||
}
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map, LLMediaCtrl* web)
|
||||
{
|
||||
//Make sure we have some parameters
|
||||
if (params.size() == 0)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
//Get the ID
|
||||
LLUUID id;
|
||||
if (!id.set( params[0], FALSE ))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
//instigate share with this avatar
|
||||
LLAvatarActions::share( id );
|
||||
return true;
|
||||
}
|
||||
};
|
||||
LLShareWithAvatarHandler gShareWithAvatar;
|
||||
|
|
@ -1120,17 +1120,17 @@ void LLSidepanelTaskInfo::updateVerbs()
|
|||
*/
|
||||
|
||||
LLSafeHandle<LLObjectSelection> object_selection = LLSelectMgr::getInstance()->getSelection();
|
||||
const BOOL multi_select = (object_selection->getNumNodes() > 1);
|
||||
const BOOL any_selected = (object_selection->getNumNodes() > 0);
|
||||
|
||||
mOpenBtn->setVisible(!multi_select);
|
||||
mPayBtn->setVisible(!multi_select);
|
||||
mBuyBtn->setVisible(!multi_select);
|
||||
mDetailsBtn->setVisible(multi_select);
|
||||
mDetailsBtn->setEnabled(multi_select);
|
||||
mOpenBtn->setVisible(true);
|
||||
mPayBtn->setVisible(true);
|
||||
mBuyBtn->setVisible(true);
|
||||
mDetailsBtn->setVisible(true);
|
||||
|
||||
mOpenBtn->setEnabled(enable_object_open());
|
||||
mPayBtn->setEnabled(enable_pay_object());
|
||||
mBuyBtn->setEnabled(enable_buy_object());
|
||||
mDetailsBtn->setEnabled(any_selected);
|
||||
}
|
||||
|
||||
void LLSidepanelTaskInfo::onOpenButtonClicked()
|
||||
|
|
|
|||
|
|
@ -59,6 +59,7 @@
|
|||
#include "llcommandhandler.h"
|
||||
#include "llviewermessage.h"
|
||||
#include "llsidepanelappearance.h"
|
||||
#include "llavataractions.h"
|
||||
|
||||
///----------------------------------------------------------------------------
|
||||
/// Helper class to store special inventory item names and their localized values.
|
||||
|
|
@ -211,6 +212,7 @@ public:
|
|||
};
|
||||
LLInventoryHandler gInventoryHandler;
|
||||
|
||||
|
||||
///----------------------------------------------------------------------------
|
||||
/// Class LLViewerInventoryItem
|
||||
///----------------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -0,0 +1,61 @@
|
|||
/**
|
||||
* @file llvoicecallhandler.cpp
|
||||
* @brief slapp to handle avatar to avatar voice call.
|
||||
*
|
||||
* $LicenseInfo:firstyear=2001&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$
|
||||
*/
|
||||
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
#include "llcommandhandler.h"
|
||||
#include "llavataractions.h"
|
||||
|
||||
class LLVoiceCallAvatarHandler : public LLCommandHandler
|
||||
{
|
||||
public:
|
||||
// requires trusted browser to trigger
|
||||
LLVoiceCallAvatarHandler() : LLCommandHandler("voicecallavatar", UNTRUSTED_THROTTLE)
|
||||
{
|
||||
}
|
||||
|
||||
bool handle(const LLSD& params, const LLSD& query_map, LLMediaCtrl* web)
|
||||
{
|
||||
//Make sure we have some parameters
|
||||
if (params.size() == 0)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
//Get the ID
|
||||
LLUUID id;
|
||||
if (!id.set( params[0], FALSE ))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
//instigate call with this avatar
|
||||
LLAvatarActions::startCall( id );
|
||||
return true;
|
||||
}
|
||||
};
|
||||
|
||||
LLVoiceCallAvatarHandler gVoiceCallAvatarHandler;
|
||||
|
||||
Binary file not shown.
|
After Width: | Height: | Size: 2.9 KiB |
|
|
@ -558,11 +558,11 @@ with the same filename but different name
|
|||
|
||||
<texture name="Wearables_Divider" file_name="windows/Wearables_Divider.png" preload="false" />
|
||||
|
||||
<texture name="Web_Profile_Off" file_name="icons/Web_Profile_Off.png" preload="false" />
|
||||
|
||||
<texture name="WellButton_Lit" file_name="bottomtray/WellButton_Lit.png" preload="true" scale.left="4" scale.top="19" scale.right="28" scale.bottom="4" />
|
||||
<texture name="WellButton_Lit_Selected" file_name="bottomtray/WellButton_Lit_Selected.png" preload="true" scale.left="4" scale.top="19" scale.right="28" scale.bottom="4" />
|
||||
|
||||
|
||||
|
||||
<texture name="Window_Background" file_name="windows/Window_Background.png" preload="true"
|
||||
scale.left="4" scale.top="24" scale.right="26" scale.bottom="4" />
|
||||
<texture name="Window_Foreground" file_name="windows/Window_Foreground.png" preload="true"
|
||||
|
|
|
|||
|
|
@ -134,7 +134,7 @@
|
|||
<button
|
||||
follows="right"
|
||||
height="20"
|
||||
image_overlay="ForwardArrow_Off"
|
||||
image_overlay="Web_Profile_Off"
|
||||
layout="topleft"
|
||||
left_pad="5"
|
||||
right="-28"
|
||||
|
|
|
|||
|
|
@ -328,17 +328,6 @@
|
|||
name="homepage_edit"
|
||||
width="272">
|
||||
</line_editor>
|
||||
<check_box
|
||||
follows="left|top"
|
||||
font="SansSerifSmall"
|
||||
label="Show me in Search results"
|
||||
layout="topleft"
|
||||
left="8"
|
||||
name="show_in_search_checkbox"
|
||||
height="15"
|
||||
label_text.text_color="white"
|
||||
top_pad="12"
|
||||
width="100" />
|
||||
<text
|
||||
follows="left|top"
|
||||
font="SansSerifSmall"
|
||||
|
|
|
|||
|
|
@ -63,7 +63,7 @@
|
|||
<button
|
||||
follows="right"
|
||||
height="20"
|
||||
image_overlay="ForwardArrow_Off"
|
||||
image_overlay="Web_Profile_Off"
|
||||
layout="topleft"
|
||||
left_pad="5"
|
||||
right="-3"
|
||||
|
|
|
|||
|
|
@ -31,10 +31,18 @@
|
|||
name="no_group_text"
|
||||
value="None" />
|
||||
<string
|
||||
name="RegisterDateFormat">
|
||||
[REG_DATE] ([AGE])
|
||||
</string>
|
||||
<layout_stack
|
||||
name="RegisterDateFormat">
|
||||
[REG_DATE] ([AGE])
|
||||
</string>
|
||||
<string
|
||||
name="name_text_args">
|
||||
[NAME]
|
||||
</string>
|
||||
<string
|
||||
name="display_name_text_args">
|
||||
[DISPLAY_NAME]
|
||||
</string>
|
||||
<layout_stack
|
||||
name="layout"
|
||||
orientation="vertical"
|
||||
follows="all"
|
||||
|
|
@ -79,63 +87,7 @@
|
|||
name="second_life_image_panel"
|
||||
top="0"
|
||||
width="297">
|
||||
<texture_picker
|
||||
allow_no_texture="true"
|
||||
default_image_name="None"
|
||||
enabled="false"
|
||||
fallback_image="Generic_Person_Large"
|
||||
follows="top|left"
|
||||
height="124"
|
||||
layout="topleft"
|
||||
left="3"
|
||||
name="2nd_life_pic"
|
||||
top="10"
|
||||
width="102" />
|
||||
<icon
|
||||
height="102"
|
||||
image_name="Blank"
|
||||
layout="topleft"
|
||||
name="2nd_life_edit_icon"
|
||||
label=""
|
||||
left="3"
|
||||
tool_tip="Click the Edit Profile button below to change image"
|
||||
top="10"
|
||||
width="102" />
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left_pad="10"
|
||||
name="title_sl_descr_text"
|
||||
text_color="white"
|
||||
top_delta="0"
|
||||
value="[SECOND_LIFE]:"
|
||||
width="180" />
|
||||
<expandable_text
|
||||
follows="left|top|right"
|
||||
height="95"
|
||||
layout="topleft"
|
||||
left="107"
|
||||
textbox.max_length="512"
|
||||
textbox.show_context_menu="true"
|
||||
name="sl_description_edit"
|
||||
top_pad="-3"
|
||||
translate="false"
|
||||
width="181"
|
||||
expanded_bg_visible="true"
|
||||
expanded_bg_color="DkGray">
|
||||
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet ipsum. adipiscing elit. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet ipsum. adipiscing elit. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet ipsum.
|
||||
</expandable_text>
|
||||
</panel>
|
||||
<panel
|
||||
follows="left|top|right"
|
||||
height="117"
|
||||
layout="topleft"
|
||||
top_pad="0"
|
||||
left="10"
|
||||
name="first_life_image_panel"
|
||||
width="297">
|
||||
|
||||
<texture_picker
|
||||
allow_no_texture="true"
|
||||
default_image_name="None"
|
||||
|
|
@ -145,204 +97,50 @@
|
|||
height="124"
|
||||
layout="topleft"
|
||||
left="3"
|
||||
name="real_world_pic"
|
||||
name="2nd_life_pic"
|
||||
top="10"
|
||||
width="102" />
|
||||
<icon
|
||||
height="102"
|
||||
image_name="Blank"
|
||||
layout="topleft"
|
||||
name="real_world_edit_icon"
|
||||
label=""
|
||||
left="3"
|
||||
tool_tip="Click the Edit Profile button below to change image"
|
||||
top="4"
|
||||
width="102" />
|
||||
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left_pad="10"
|
||||
name="title_rw_descr_text"
|
||||
text_color="white"
|
||||
top_delta="0"
|
||||
value="Real World:"
|
||||
width="180" />
|
||||
<expandable_text
|
||||
follows="left|top|right"
|
||||
height="95"
|
||||
layout="topleft"
|
||||
left="107"
|
||||
textbox.max_length="512"
|
||||
textbox.show_context_menu="true"
|
||||
name="fl_description_edit"
|
||||
top_pad="-3"
|
||||
translate="false"
|
||||
width="181"
|
||||
expanded_bg_visible="true"
|
||||
expanded_bg_color="DkGray">
|
||||
Lorem ipsum dolor sit amet, consectetur adlkjpiscing elit moose moose. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet. adipiscing elit. Aenean rigviverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet sorbet ipsum. adipiscing elit. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet ipsum.
|
||||
</expandable_text>
|
||||
</panel>
|
||||
<text
|
||||
follows="left|top|right"
|
||||
height="15"
|
||||
font.style="BOLD"
|
||||
font="SansSerifMedium"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="homepage_edit"
|
||||
top_pad="0"
|
||||
translate="false"
|
||||
value="http://librarianavengers.org"
|
||||
width="300"
|
||||
word_wrap="false"
|
||||
use_ellipses="true"
|
||||
/>
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="10"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="title_member_text"
|
||||
text_color="white"
|
||||
top_pad="10"
|
||||
value="Resident Since:"
|
||||
width="300" />
|
||||
<text_editor
|
||||
allow_scroll="false"
|
||||
bg_visible="false"
|
||||
follows="left|top|right"
|
||||
h_pad="0"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="register_date"
|
||||
read_only="true"
|
||||
translate="false"
|
||||
v_pad="0"
|
||||
value="05/31/2376"
|
||||
width="300"
|
||||
word_wrap="true" />
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="title_acc_status_text"
|
||||
text_color="white"
|
||||
top_pad="5"
|
||||
value="Account Status:"
|
||||
width="300" />
|
||||
<!-- <text
|
||||
type="string"
|
||||
follows="left|top"
|
||||
font="SansSerifSmall"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left_pad="10"
|
||||
name="my_account_link"
|
||||
top_delta="0"
|
||||
value="Go to Dashboard"
|
||||
width="100"/> -->
|
||||
<text_editor
|
||||
allow_scroll="false"
|
||||
bg_visible="false"
|
||||
follows="left|top|right"
|
||||
h_pad="0"
|
||||
height="28"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="acc_status_text"
|
||||
read_only="true"
|
||||
top_pad="0"
|
||||
translate="false"
|
||||
v_pad="0"
|
||||
width="300"
|
||||
word_wrap="true">
|
||||
Resident. No payment info on file.
|
||||
Linden.
|
||||
</text_editor>
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="title_partner_text"
|
||||
text_color="white"
|
||||
top_pad="3"
|
||||
value="Partner:"
|
||||
width="300" />
|
||||
<panel
|
||||
follows="left|top|right"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="partner_data_panel"
|
||||
top_pad="0"
|
||||
width="300">
|
||||
follows="left|top|right"
|
||||
font="SansSerifLarge"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left_pad="10"
|
||||
name="display_name_descr_text"
|
||||
text_color="0.7 0.7 0.7 1.0"
|
||||
top_delta="0"
|
||||
width="280" >
|
||||
User name
|
||||
</text>
|
||||
|
||||
<text
|
||||
follows="left|top|right"
|
||||
height="10"
|
||||
initial_value="(retrieving)"
|
||||
layout="topleft"
|
||||
left="0"
|
||||
link="true"
|
||||
name="partner_text"
|
||||
top="0"
|
||||
use_ellipses="true"
|
||||
width="300" />
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="15"
|
||||
layout="topleft"
|
||||
left_delta="0"
|
||||
name="name_descr_text"
|
||||
text_color="0.4 0.4 0.4 1.0"
|
||||
top_delta="20"
|
||||
width="280">
|
||||
Display Name
|
||||
</text>
|
||||
|
||||
<button
|
||||
follows="bottom"
|
||||
height="23"
|
||||
left_delta="0"
|
||||
top_delta="20"
|
||||
label="Profile"
|
||||
name="see_profile_btn"
|
||||
tool_tip="See profile for this avatar"
|
||||
width="120" />
|
||||
|
||||
</panel>
|
||||
<text
|
||||
follows="left|top|right"
|
||||
font.style="BOLD"
|
||||
height="13"
|
||||
layout="topleft"
|
||||
left="10"
|
||||
name="title_groups_text"
|
||||
text_color="white"
|
||||
top_pad="3"
|
||||
value="Groups:"
|
||||
width="300" />
|
||||
<expandable_text
|
||||
follows="all"
|
||||
height="113"
|
||||
layout="topleft"
|
||||
left="7"
|
||||
name="sl_groups"
|
||||
top_pad="0"
|
||||
translate="false"
|
||||
textbox.show_context_menu="true"
|
||||
width="298"
|
||||
expanded_bg_visible="true"
|
||||
expanded_bg_color="DkGray">
|
||||
Lorem ipsum dolor sit amet, consectetur adlkjpiscing elit moose moose. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet. adipiscing elit. Aenean rigviverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet sorbet ipsum. adipiscing elit. Aenean viverra orci et justo sagittis aliquet. Nullam malesuada mauris sit amet ipsum. Aenean viverra tulip moosetop. Slan de heelish marfnik tooplod. Sum sum to whop de wompam booster copm.
|
||||
</expandable_text>
|
||||
</panel>
|
||||
</scroll_container>
|
||||
</layout_panel>
|
||||
</layout_stack>
|
||||
<panel
|
||||
follows="bottom|left|right"
|
||||
height="23"
|
||||
layout="topleft"
|
||||
left="0"
|
||||
top_pad="1"
|
||||
name="profile_me_buttons_panel"
|
||||
visible="false"
|
||||
width="315">
|
||||
<button
|
||||
follows="bottom"
|
||||
height="23"
|
||||
left="6"
|
||||
top="1"
|
||||
label="Edit Profile"
|
||||
name="edit_profile_btn"
|
||||
tool_tip="Edit your personal information"
|
||||
width="152" />
|
||||
</panel>
|
||||
|
||||
</panel>
|
||||
|
|
|
|||
|
|
@ -40,6 +40,15 @@
|
|||
width="300">
|
||||
(Locations, images, web, search history)
|
||||
</text>
|
||||
<check_box
|
||||
height="16"
|
||||
enabled="true"
|
||||
label="Show me in Search results"
|
||||
layout="topleft"
|
||||
left="30"
|
||||
name="online_searchresults"
|
||||
top_pad="20"
|
||||
width="350" />
|
||||
<check_box
|
||||
height="16"
|
||||
enabled="false"
|
||||
|
|
|
|||
|
|
@ -533,7 +533,7 @@
|
|||
left="5"
|
||||
name="open_btn"
|
||||
top="0"
|
||||
width="100" />
|
||||
width="73" />
|
||||
<button
|
||||
follows="bottom|left"
|
||||
height="23"
|
||||
|
|
@ -542,7 +542,7 @@
|
|||
left_pad="5"
|
||||
name="pay_btn"
|
||||
top="0"
|
||||
width="100" />
|
||||
width="73" />
|
||||
<button
|
||||
follows="bottom|left"
|
||||
height="23"
|
||||
|
|
@ -551,17 +551,16 @@
|
|||
left_pad="5"
|
||||
name="buy_btn"
|
||||
top="0"
|
||||
width="100" />
|
||||
width="73" />
|
||||
<button
|
||||
follows="bottom|left"
|
||||
height="23"
|
||||
label="Details"
|
||||
layout="topleft"
|
||||
left="5"
|
||||
left_pad="5"
|
||||
name="details_btn"
|
||||
top="0"
|
||||
width="100"
|
||||
visible="false" />
|
||||
width="74" />
|
||||
|
||||
</panel>
|
||||
</panel>
|
||||
|
|
|
|||
Loading…
Reference in New Issue