diff options
26 files changed, 162 insertions, 213 deletions
| diff --git a/indra/llcommon/llprocessor.cpp b/indra/llcommon/llprocessor.cpp index 98c9eabcd6..d3ba215751 100644 --- a/indra/llcommon/llprocessor.cpp +++ b/indra/llcommon/llprocessor.cpp @@ -41,7 +41,11 @@  #	define WIN32_LEAN_AND_MEAN  #	include <winsock2.h>  #	include <windows.h> -#   include <intrin.h> +#	define _interlockedbittestandset _renamed_interlockedbittestandset +#	define _interlockedbittestandreset _renamed_interlockedbittestandreset +#	include <intrin.h> +#	undef _interlockedbittestandset +#	undef _interlockedbittestandreset  #endif  #include "llsd.h" diff --git a/indra/newview/llfloaterbuy.cpp b/indra/newview/llfloaterbuy.cpp index 46b3695511..d359856443 100644 --- a/indra/newview/llfloaterbuy.cpp +++ b/indra/newview/llfloaterbuy.cpp @@ -254,7 +254,6 @@ void LLFloaterBuy::inventoryChanged(LLViewerObject* obj,  		std::string icon_name = LLInventoryIcon::getIconName(inv_item->getType(),   							 inv_item->getInventoryType(), -							 inv_item->getIsLinkType(),  							 inv_item->getFlags(),  							 item_is_multi);  		row["columns"][0]["column"] = "icon"; diff --git a/indra/newview/llfloaterbuycontents.cpp b/indra/newview/llfloaterbuycontents.cpp index c35653178a..9bde3b1dac 100644 --- a/indra/newview/llfloaterbuycontents.cpp +++ b/indra/newview/llfloaterbuycontents.cpp @@ -223,7 +223,6 @@ void LLFloaterBuyContents::inventoryChanged(LLViewerObject* obj,  		std::string icon_name = LLInventoryIcon::getIconName(inv_item->getType(),   								 inv_item->getInventoryType(), -								 inv_item->getIsLinkType(),  								 inv_item->getFlags(),  								 item_is_multi);  		row["columns"][0]["column"] = "icon"; diff --git a/indra/newview/llfloaterbuycurrencyhtml.cpp b/indra/newview/llfloaterbuycurrencyhtml.cpp index 5815df36d1..7f41a64064 100644 --- a/indra/newview/llfloaterbuycurrencyhtml.cpp +++ b/indra/newview/llfloaterbuycurrencyhtml.cpp @@ -87,6 +87,9 @@ void LLFloaterBuyCurrencyHTML::navigateToFinalURL()  	replace[ "[MSG]" ] = LLURI::escape( mMessage );  	LLStringUtil::format( buy_currency_url, replace ); +	// write final URL to debug console +	llinfos << "Buy currency HTML prased URL is " << buy_currency_url << llendl; +  	// kick off the navigation  	mBrowser->navigateTo( buy_currency_url );  } @@ -98,6 +101,9 @@ void LLFloaterBuyCurrencyHTML::handleMediaEvent( LLPluginClassMedia* self, EMedi  	// placeholder for now - just in case we want to catch media events  	if ( LLPluginClassMediaOwner::MEDIA_EVENT_NAVIGATE_COMPLETE == event )  	{ +		// update currency after we complete a navigation since there are many ways  +		// this can result in a different L$ balance +		LLStatusBar::sendMoneyBalanceRequest();  	};  } @@ -105,6 +111,9 @@ void LLFloaterBuyCurrencyHTML::handleMediaEvent( LLPluginClassMedia* self, EMedi  //  void LLFloaterBuyCurrencyHTML::onClose( bool app_quitting )  { +	// update L$ balanace one more time +	LLStatusBar::sendMoneyBalanceRequest(); +  	destroy();  } diff --git a/indra/newview/llfolderviewitem.cpp b/indra/newview/llfolderviewitem.cpp index 54e9bd5383..0c437cf035 100644 --- a/indra/newview/llfolderviewitem.cpp +++ b/indra/newview/llfolderviewitem.cpp @@ -96,6 +96,7 @@ void LLFolderViewItem::cleanupClass()  LLFolderViewItem::Params::Params()  :	icon(),  	icon_open(), +	icon_overlay(),  	root(),  	listener(),  	folder_arrow_image("folder_arrow_image"), @@ -133,6 +134,7 @@ LLFolderViewItem::LLFolderViewItem(const LLFolderViewItem::Params& p)  	mCreationDate(p.creation_date),  	mIcon(p.icon),  	mIconOpen(p.icon_open), +	mIconOverlay(p.icon_overlay),  	mListener(p.listener),  	mHidden(false),  	mShowLoadStatus(false) @@ -617,6 +619,7 @@ const std::string& LLFolderViewItem::getSearchableLabel() const  LLViewerInventoryItem * LLFolderViewItem::getInventoryItem(void)  { +	if (!getListener()) return NULL;  	return gInventory.getItem(getListener()->getUUID());  } @@ -948,7 +951,8 @@ void LLFolderViewItem::draw()  		mDragAndDropTarget = FALSE;  	} -	 +	const LLViewerInventoryItem *item = getInventoryItem(); +	const BOOL highlight_link = mIconOverlay && item && item->getIsLinkType();  	//--------------------------------------------------------------------------------//  	// Draw open icon  	// @@ -962,6 +966,10 @@ void LLFolderViewItem::draw()   		mIcon->draw(icon_x, getRect().getHeight() - mIcon->getHeight() - TOP_PAD + 1);   	} +	if (highlight_link) +	{ +		mIconOverlay->draw(icon_x, getRect().getHeight() - mIcon->getHeight() - TOP_PAD + 1); +	}  	//--------------------------------------------------------------------------------//  	// Exit if no label to draw @@ -972,8 +980,7 @@ void LLFolderViewItem::draw()  	}  	LLColor4 color = (mIsSelected && filled) ? sHighlightFgColor : sFgColor; -	const LLViewerInventoryItem *item = getInventoryItem(); -	if (item && item->getIsLinkType()) color = sLinkColor; +	if (highlight_link) color = sLinkColor;  	if (in_library) color = sLibraryColor;  	F32 right_x  = 0; diff --git a/indra/newview/llfolderviewitem.h b/indra/newview/llfolderviewitem.h index 57c722afa4..d6e4b2f556 100644 --- a/indra/newview/llfolderviewitem.h +++ b/indra/newview/llfolderviewitem.h @@ -97,6 +97,7 @@ public:  	{  		Optional<LLUIImage*>					icon;  		Optional<LLUIImage*>					icon_open;  // used for folders +		Optional<LLUIImage*>					icon_overlay;  // for links  		Optional<LLFolderView*>					root;  		Optional<LLFolderViewEventListener*>	listener; @@ -147,6 +148,7 @@ protected:  	LLUIImagePtr				mIcon;  	std::string					mStatusText;  	LLUIImagePtr				mIconOpen; +	LLUIImagePtr				mIconOverlay;  	BOOL						mHasVisibleChildren;  	S32							mIndentation;  	S32							mItemHeight; diff --git a/indra/newview/llinventorybridge.cpp b/indra/newview/llinventorybridge.cpp index 94d421f61c..7ce96a6ac1 100644 --- a/indra/newview/llinventorybridge.cpp +++ b/indra/newview/llinventorybridge.cpp @@ -65,6 +65,7 @@  #include "llsidetray.h"  #include "lltrans.h"  #include "llviewerassettype.h" +#include "llviewerfoldertype.h"  #include "llviewermenu.h"  #include "llviewermessage.h"  #include "llviewerobjectlist.h" @@ -2249,58 +2250,14 @@ LLUIImagePtr LLFolderBridge::getIcon() const  }  // static -LLUIImagePtr LLFolderBridge::getIcon(LLFolderType::EType preferred_type, BOOL is_link) +LLUIImagePtr LLFolderBridge::getIcon(LLFolderType::EType preferred_type)  { -	// Bypassing LLViewerFolderType::lookup() since -	// we aren't using different system folder icons -	if (is_link) -	{ -		if (preferred_type == LLFolderType::FT_OUTFIT) -			return LLUI::getUIImage("Inv_LookFolderClosed_Link"); -		else  -			return LLUI::getUIImage("Inv_FolderClosed_Link"); -	} - -	switch (preferred_type) -	{ -	case LLFolderType::FT_OUTFIT: -		return LLUI::getUIImage("Inv_LookFolderClosed"); -	case LLFolderType::FT_LOST_AND_FOUND: -		return LLUI::getUIImage("Inv_LostClosed"); -	case LLFolderType::FT_TRASH: -		return LLUI::getUIImage("Inv_TrashClosed"); -	case LLFolderType::FT_NONE: -		return LLUI::getUIImage("Inv_FolderClosed"); -	default: -		return LLUI::getUIImage("Inv_SysClosed"); -	} +	return LLUI::getUIImage(LLViewerFolderType::lookupIconName(preferred_type, FALSE));  }  LLUIImagePtr LLFolderBridge::getOpenIcon() const  { -	// Bypassing LLViewerFolderType::lookup() since -	// we aren't using different system folder icons -	if (isLink()) -	{ -		if (getPreferredType() == LLFolderType::FT_OUTFIT) -			return LLUI::getUIImage("Inv_LookFolderOpen_Link"); -		else  -			return LLUI::getUIImage("Inv_FolderOpen_Link"); -	} - -	switch (getPreferredType()) -	{ -	case LLFolderType::FT_OUTFIT: -		return LLUI::getUIImage("Inv_LookFolderOpen"); -	case LLFolderType::FT_LOST_AND_FOUND: -		return LLUI::getUIImage("Inv_LostOpen"); -	case LLFolderType::FT_TRASH: -		return LLUI::getUIImage("Inv_TrashOpen"); -	case LLFolderType::FT_NONE: -		return LLUI::getUIImage("Inv_FolderOpen"); -	default: -		return LLUI::getUIImage("Inv_SysOpen"); -	} +	return LLUI::getUIImage(LLViewerFolderType::lookupIconName(getPreferredType(), TRUE));  } @@ -3170,7 +3127,7 @@ BOOL LLFolderBridge::dragItemIntoFolder(LLInventoryItem* inv_item,  LLUIImagePtr LLTextureBridge::getIcon() const  { -	return LLInventoryIcon::getIcon(LLAssetType::AT_TEXTURE, mInvType, mIsLink); +	return LLInventoryIcon::getIcon(LLAssetType::AT_TEXTURE, mInvType);  }  void LLTextureBridge::openItem() @@ -3322,7 +3279,7 @@ LLLandmarkBridge::LLLandmarkBridge(LLInventoryPanel* inventory,  LLUIImagePtr LLLandmarkBridge::getIcon() const  { -	return LLInventoryIcon::getIcon(LLAssetType::AT_LANDMARK, LLInventoryType::IT_LANDMARK, mIsLink, mVisited, FALSE); +	return LLInventoryIcon::getIcon(LLAssetType::AT_LANDMARK, LLInventoryType::IT_LANDMARK, mVisited, FALSE);  }  void LLLandmarkBridge::buildContextMenu(LLMenuGL& menu, U32 flags) @@ -3514,7 +3471,7 @@ LLUIImagePtr LLCallingCardBridge::getIcon() const  	{  		online = LLAvatarTracker::instance().isBuddyOnline(item->getCreatorUUID());  	} -	return LLInventoryIcon::getIcon(LLAssetType::AT_CALLINGCARD, LLInventoryType::IT_CALLINGCARD, mIsLink, online, FALSE); +	return LLInventoryIcon::getIcon(LLAssetType::AT_CALLINGCARD, LLInventoryType::IT_CALLINGCARD, online, FALSE);  }  std::string LLCallingCardBridge::getLabelSuffix() const @@ -3953,7 +3910,7 @@ LLObjectBridge::LLObjectBridge(LLInventoryPanel* inventory,  LLUIImagePtr LLObjectBridge::getIcon() const  { -	return LLInventoryIcon::getIcon(LLAssetType::AT_OBJECT, mInvType, mIsLink, mAttachPt, mIsMultiObject); +	return LLInventoryIcon::getIcon(LLAssetType::AT_OBJECT, mInvType, mAttachPt, mIsMultiObject);  }  LLInventoryObject* LLObjectBridge::getObject() const @@ -4420,7 +4377,7 @@ std::string LLWearableBridge::getLabelSuffix() const  LLUIImagePtr LLWearableBridge::getIcon() const  { -	return LLInventoryIcon::getIcon(mAssetType, mInvType, mIsLink, mWearableType, FALSE); +	return LLInventoryIcon::getIcon(mAssetType, mInvType, mWearableType, FALSE);  }  // virtual @@ -4845,7 +4802,7 @@ LLUIImagePtr LLLinkFolderBridge::getIcon() const  			}  		}  	} -	return LLFolderBridge::getIcon(folder_type, TRUE); +	return LLFolderBridge::getIcon(folder_type);  }  void LLLinkFolderBridge::buildContextMenu(LLMenuGL& menu, U32 flags) diff --git a/indra/newview/llinventorybridge.h b/indra/newview/llinventorybridge.h index a342a2da14..d97dfd535e 100644 --- a/indra/newview/llinventorybridge.h +++ b/indra/newview/llinventorybridge.h @@ -245,7 +245,7 @@ public:  	virtual LLFolderType::EType getPreferredType() const;  	virtual LLUIImagePtr getIcon() const;  	virtual LLUIImagePtr getOpenIcon() const; -	static LLUIImagePtr getIcon(LLFolderType::EType preferred_type, BOOL is_link = FALSE); +	static LLUIImagePtr getIcon(LLFolderType::EType preferred_type);  	virtual BOOL renameItem(const std::string& new_name); diff --git a/indra/newview/llinventoryicon.cpp b/indra/newview/llinventoryicon.cpp index 2fb55f4c1f..3090371a73 100644 --- a/indra/newview/llinventoryicon.cpp +++ b/indra/newview/llinventoryicon.cpp @@ -40,13 +40,10 @@  struct IconEntry : public LLDictionaryEntry  { -	IconEntry(const std::string &item_name, -			  const std::string &link_name) +	IconEntry(const std::string &item_name)  		: -		LLDictionaryEntry(item_name), -		mLinkName(link_name) +		LLDictionaryEntry(item_name)  	{} -	const std::string mLinkName;  };  class LLIconDictionary : public LLSingleton<LLIconDictionary>, @@ -58,52 +55,51 @@ public:  LLIconDictionary::LLIconDictionary()  { -	addEntry(LLInventoryIcon::ICONNAME_TEXTURE, 				new IconEntry("Inv_Texture", 		"Inv_Texture_Link")); -	addEntry(LLInventoryIcon::ICONNAME_SOUND, 					new IconEntry("Inv_Texture", 		"Inv_Texture_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CALLINGCARD_ONLINE, 		new IconEntry("Inv_CallingCard", 	"Inv_CallingCard_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CALLINGCARD_OFFLINE, 	new IconEntry("Inv_CallingCard", 	"Inv_CallingCard_Link")); -	addEntry(LLInventoryIcon::ICONNAME_LANDMARK, 				new IconEntry("Inv_Landmark", 		"Inv_Landmark_Link")); -	addEntry(LLInventoryIcon::ICONNAME_LANDMARK_VISITED, 		new IconEntry("Inv_Landmark", 		"Inv_Landmark_Link")); -	addEntry(LLInventoryIcon::ICONNAME_SCRIPT, 					new IconEntry("Inv_Script", 		"Inv_Script_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING, 				new IconEntry("Inv_Clothing", 		"Inv_Clothing_Link")); -	addEntry(LLInventoryIcon::ICONNAME_OBJECT, 					new IconEntry("Inv_Object", 		"Inv_Object_Link")); -	addEntry(LLInventoryIcon::ICONNAME_OBJECT_MULTI, 			new IconEntry("Inv_Object_Multi", 	"Inv_Object_Multi_Link")); -	addEntry(LLInventoryIcon::ICONNAME_NOTECARD, 				new IconEntry("Inv_Notecard", 		"Inv_Notecard_Link")); -	addEntry(LLInventoryIcon::ICONNAME_BODYPART, 				new IconEntry("Inv_Skin", 			"Inv_Skin_Link")); -	addEntry(LLInventoryIcon::ICONNAME_SNAPSHOT, 				new IconEntry("Inv_Snapshot", 		"Inv_Snapshot_Link")); +	addEntry(LLInventoryIcon::ICONNAME_TEXTURE, 				new IconEntry("Inv_Texture")); +	addEntry(LLInventoryIcon::ICONNAME_SOUND, 					new IconEntry("Inv_Texture")); +	addEntry(LLInventoryIcon::ICONNAME_CALLINGCARD_ONLINE, 		new IconEntry("Inv_CallingCard")); +	addEntry(LLInventoryIcon::ICONNAME_CALLINGCARD_OFFLINE, 	new IconEntry("Inv_CallingCard")); +	addEntry(LLInventoryIcon::ICONNAME_LANDMARK, 				new IconEntry("Inv_Landmark")); +	addEntry(LLInventoryIcon::ICONNAME_LANDMARK_VISITED, 		new IconEntry("Inv_Landmark")); +	addEntry(LLInventoryIcon::ICONNAME_SCRIPT, 					new IconEntry("Inv_Script")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING, 				new IconEntry("Inv_Clothing")); +	addEntry(LLInventoryIcon::ICONNAME_OBJECT, 					new IconEntry("Inv_Object")); +	addEntry(LLInventoryIcon::ICONNAME_OBJECT_MULTI, 			new IconEntry("Inv_Object_Multi")); +	addEntry(LLInventoryIcon::ICONNAME_NOTECARD, 				new IconEntry("Inv_Notecard")); +	addEntry(LLInventoryIcon::ICONNAME_BODYPART, 				new IconEntry("Inv_Skin")); +	addEntry(LLInventoryIcon::ICONNAME_SNAPSHOT, 				new IconEntry("Inv_Snapshot")); -	addEntry(LLInventoryIcon::ICONNAME_BODYPART_SHAPE, 			new IconEntry("Inv_BodyShape", 		"Inv_BodyShape_Link")); -	addEntry(LLInventoryIcon::ICONNAME_BODYPART_SKIN, 			new IconEntry("Inv_Skin", 			"Inv_Skin_Link")); -	addEntry(LLInventoryIcon::ICONNAME_BODYPART_HAIR, 			new IconEntry("Inv_Hair", 			"Inv_Hair_Link")); -	addEntry(LLInventoryIcon::ICONNAME_BODYPART_EYES, 			new IconEntry("Inv_Eye", 			"Inv_Eye_Link")); +	addEntry(LLInventoryIcon::ICONNAME_BODYPART_SHAPE, 			new IconEntry("Inv_BodyShape")); +	addEntry(LLInventoryIcon::ICONNAME_BODYPART_SKIN, 			new IconEntry("Inv_Skin")); +	addEntry(LLInventoryIcon::ICONNAME_BODYPART_HAIR, 			new IconEntry("Inv_Hair")); +	addEntry(LLInventoryIcon::ICONNAME_BODYPART_EYES, 			new IconEntry("Inv_Eye")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SHIRT, 			new IconEntry("Inv_Shirt", 			"Inv_Shirt_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_PANTS, 			new IconEntry("Inv_Pants", 			"Inv_Pants_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SHOES, 			new IconEntry("Inv_Shoe", 			"Inv_Shoe_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SOCKS, 			new IconEntry("Inv_Socks", 			"Inv_Socks_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_JACKET, 		new IconEntry("Inv_Jacket", 		"Inv_Jacket_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_GLOVES, 		new IconEntry("Inv_Gloves", 		"Inv_Gloves_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_UNDERSHIRT, 	new IconEntry("Inv_Undershirt", 	"Inv_Undershirt_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_UNDERPANTS, 	new IconEntry("Inv_Underpants", 	"Inv_Underpants_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SKIRT, 			new IconEntry("Inv_Skirt", 			"Inv_Skirt_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_ALPHA, 			new IconEntry("Inv_Alpha", 			"Inv_Alpha_Link")); -	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_TATTOO, 		new IconEntry("Inv_Tattoo", 		"Inv_Tattoo_Link")); -	addEntry(LLInventoryIcon::ICONNAME_ANIMATION, 				new IconEntry("Inv_Animation", 		"Inv_Animation_Link")); -	addEntry(LLInventoryIcon::ICONNAME_GESTURE, 				new IconEntry("Inv_Gesture", 		"Inv_Gesture_Link")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SHIRT, 			new IconEntry("Inv_Shirt")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_PANTS, 			new IconEntry("Inv_Pants")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SHOES, 			new IconEntry("Inv_Shoe")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SOCKS, 			new IconEntry("Inv_Socks")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_JACKET, 		new IconEntry("Inv_Jacket")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_GLOVES, 		new IconEntry("Inv_Gloves")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_UNDERSHIRT, 	new IconEntry("Inv_Undershirt")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_UNDERPANTS, 	new IconEntry("Inv_Underpants")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_SKIRT, 			new IconEntry("Inv_Skirt")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_ALPHA, 			new IconEntry("Inv_Alpha")); +	addEntry(LLInventoryIcon::ICONNAME_CLOTHING_TATTOO, 		new IconEntry("Inv_Tattoo")); +	addEntry(LLInventoryIcon::ICONNAME_ANIMATION, 				new IconEntry("Inv_Animation")); +	addEntry(LLInventoryIcon::ICONNAME_GESTURE, 				new IconEntry("Inv_Gesture")); -	addEntry(LLInventoryIcon::ICONNAME_LINKITEM, 				new IconEntry("Inv_LinkItem", 		"Inv_LinkItem")); -	addEntry(LLInventoryIcon::ICONNAME_LINKFOLDER, 				new IconEntry("Inv_LinkItem", 		"Inv_LinkItem")); +	addEntry(LLInventoryIcon::ICONNAME_LINKITEM, 				new IconEntry("Inv_LinkItem")); +	addEntry(LLInventoryIcon::ICONNAME_LINKFOLDER, 				new IconEntry("Inv_LinkItem")); -	addEntry(LLInventoryIcon::ICONNAME_NONE, 					new IconEntry("NONE", 				"NONE")); +	addEntry(LLInventoryIcon::ICONNAME_NONE, 					new IconEntry("NONE"));  }  LLUIImagePtr LLInventoryIcon::getIcon(LLAssetType::EType asset_type,  									  LLInventoryType::EType inventory_type, -									  BOOL item_is_link,  									  U32 misc_flag,  									  BOOL item_is_multi)  { -	const std::string& icon_name = getIconName(asset_type, inventory_type, item_is_link, misc_flag, item_is_multi); +	const std::string& icon_name = getIconName(asset_type, inventory_type, misc_flag, item_is_multi);  	return LLUI::getUIImage(icon_name);  } @@ -114,7 +110,6 @@ LLUIImagePtr LLInventoryIcon::getIcon(EIconName idx)  const std::string& LLInventoryIcon::getIconName(LLAssetType::EType asset_type,  												LLInventoryType::EType inventory_type, -												BOOL item_is_link,  												U32 misc_flag,  												BOOL item_is_multi)  { @@ -169,14 +164,13 @@ const std::string& LLInventoryIcon::getIconName(LLAssetType::EType asset_type,  			break;  	} -	return getIconName(idx, item_is_link); +	return getIconName(idx);  } -const std::string& LLInventoryIcon::getIconName(EIconName idx, BOOL item_is_link) +const std::string& LLInventoryIcon::getIconName(EIconName idx)  {  	const IconEntry *entry = LLIconDictionary::instance().lookup(idx); -	if (item_is_link) return entry->mLinkName;  	return entry->mName;  } diff --git a/indra/newview/llinventoryicon.h b/indra/newview/llinventoryicon.h index 4cb7a123c4..6e29012c4c 100644 --- a/indra/newview/llinventoryicon.h +++ b/indra/newview/llinventoryicon.h @@ -86,15 +86,12 @@ public:  	static const std::string& getIconName(LLAssetType::EType asset_type,  										  LLInventoryType::EType inventory_type = LLInventoryType::IT_NONE, -										  BOOL item_is_link = FALSE,  										  U32 misc_flag = 0, // different meanings depending on item type  										  BOOL item_is_multi = FALSE); -	static const std::string& getIconName(EIconName idx,  -										  BOOL item_is_link = FALSE); +	static const std::string& getIconName(EIconName idx);  	static LLUIImagePtr getIcon(LLAssetType::EType asset_type,  								LLInventoryType::EType inventory_type = LLInventoryType::IT_NONE, -								BOOL item_is_link = FALSE,  								U32 misc_flag = 0, // different meanings depending on item type  								BOOL item_is_multi = FALSE);  	static LLUIImagePtr getIcon(EIconName idx); diff --git a/indra/newview/llinventoryitemslist.cpp b/indra/newview/llinventoryitemslist.cpp index a9814a1b9a..55cb2619cf 100644 --- a/indra/newview/llinventoryitemslist.cpp +++ b/indra/newview/llinventoryitemslist.cpp @@ -140,8 +140,7 @@ BOOL LLPanelInventoryListItemBase::postBuild()  	setIconCtrl(getChild<LLIconCtrl>("item_icon"));  	setTitleCtrl(getChild<LLTextBox>("item_name")); -	BOOL show_links = mForceNoLinksOnIcons ? FALSE : mItem->getIsLinkType(); -	mIconImage = LLInventoryIcon::getIcon(mItem->getType(), mItem->getInventoryType(), show_links, mItem->getFlags(), FALSE); +	mIconImage = LLInventoryIcon::getIcon(mItem->getType(), mItem->getInventoryType(), mItem->getFlags(), FALSE);  	setNeedsRefresh(true); @@ -207,7 +206,6 @@ LLPanelInventoryListItemBase::LLPanelInventoryListItemBase(LLViewerInventoryItem  , mLeftWidgetsWidth(0)  , mRightWidgetsWidth(0)  , mNeedsRefresh(false) -, mForceNoLinksOnIcons(false)  {  } diff --git a/indra/newview/llinventoryitemslist.h b/indra/newview/llinventoryitemslist.h index 2c60d38cb5..c1b1a6f281 100644 --- a/indra/newview/llinventoryitemslist.h +++ b/indra/newview/llinventoryitemslist.h @@ -182,9 +182,6 @@ protected:  	LLViewerInventoryItem* mItem; -	// force not showing link icon on item's icon -	bool mForceNoLinksOnIcons; -  private:  	/** reshape left side widgets diff --git a/indra/newview/llinventorypanel.cpp b/indra/newview/llinventorypanel.cpp index bb3f34dde2..7d81cf18aa 100644 --- a/indra/newview/llinventorypanel.cpp +++ b/indra/newview/llinventorypanel.cpp @@ -87,6 +87,7 @@ LLInventoryPanel::LLInventoryPanel(const LLInventoryPanel::Params& p) :  	mSortOrderSetting(p.sort_order_setting),  	mInventory(p.inventory),  	mAllowMultiSelect(p.allow_multi_select), +	mShowItemLinkOverlays(p.show_item_link_overlays),  	mViewsInitialized(false),  	mStartFolderString(p.start_folder),	  	mBuildDefaultHierarchy(true), @@ -522,6 +523,10 @@ void LLInventoryPanel::buildNewViews(const LLUUID& id)  				params.name = new_listener->getDisplayName();  				params.icon = new_listener->getIcon();  				params.icon_open = new_listener->getOpenIcon(); +				if (mShowItemLinkOverlays) // if false, then links show up just like normal items +				{ +					params.icon_overlay = LLUI::getUIImage("Inv_Link"); +				}  				params.root = mFolderRoot;  				params.listener = new_listener;  				params.tool_tip = params.name; @@ -560,6 +565,10 @@ void LLInventoryPanel::buildNewViews(const LLUUID& id)  				params.name = new_listener->getDisplayName();  				params.icon = new_listener->getIcon();  				params.icon_open = new_listener->getOpenIcon(); +				if (mShowItemLinkOverlays) // if false, then links show up just like normal items +				{ +					params.icon_overlay = LLUI::getUIImage("Inv_Link"); +				}  				params.creation_date = new_listener->getCreationDate();  				params.root = mFolderRoot;  				params.listener = new_listener; diff --git a/indra/newview/llinventorypanel.h b/indra/newview/llinventorypanel.h index 4373cedf66..67c8904868 100644 --- a/indra/newview/llinventorypanel.h +++ b/indra/newview/llinventorypanel.h @@ -84,6 +84,7 @@ public:  		Optional<std::string>				sort_order_setting;  		Optional<LLInventoryModel*>			inventory;  		Optional<bool>						allow_multi_select; +		Optional<bool>						show_item_link_overlays;  		Optional<Filter>					filter;  		Optional<std::string>               start_folder; @@ -91,6 +92,7 @@ public:  		:	sort_order_setting("sort_order_setting"),  			inventory("", &gInventory),  			allow_multi_select("allow_multi_select", true), +			show_item_link_overlays("show_item_link_overlays", false),  			filter("filter"),  			start_folder("start_folder")  		{} @@ -177,6 +179,7 @@ protected:  	LLInventoryModel*			mInventory;  	LLInventoryObserver*		mInventoryObserver;  	BOOL 						mAllowMultiSelect; +	BOOL 						mShowItemLinkOverlays; // Shows link graphic over inventory item icons  	LLFolderView*				mFolderRoot;  	LLScrollContainer*			mScroller; diff --git a/indra/newview/llpanelgroupnotices.cpp b/indra/newview/llpanelgroupnotices.cpp index 42ff514f09..ba50081fb2 100644 --- a/indra/newview/llpanelgroupnotices.cpp +++ b/indra/newview/llpanelgroupnotices.cpp @@ -338,7 +338,6 @@ void LLPanelGroupNotices::setItem(LLPointer<LLInventoryItem> inv_item)  	std::string icon_name = LLInventoryIcon::getIconName(inv_item->getType(),  										inv_item->getInventoryType(),  										inv_item->getFlags(), -										inv_item->getIsLinkType(),  										item_is_multi );  	mCreateInventoryIcon->setValue(icon_name); diff --git a/indra/newview/llpanelobjectinventory.cpp b/indra/newview/llpanelobjectinventory.cpp index c557e9b85d..ad3a5c2380 100644 --- a/indra/newview/llpanelobjectinventory.cpp +++ b/indra/newview/llpanelobjectinventory.cpp @@ -351,7 +351,7 @@ LLUIImagePtr LLTaskInvFVBridge::getIcon() const  {  	const BOOL item_is_multi = (mFlags & LLInventoryItemFlags::II_FLAGS_OBJECT_HAS_MULTIPLE_ITEMS); -	return LLInventoryIcon::getIcon(mAssetType, mInventoryType, FALSE, 0, item_is_multi ); +	return LLInventoryIcon::getIcon(mAssetType, mInventoryType, 0, item_is_multi );  }  void LLTaskInvFVBridge::openItem() @@ -1236,7 +1236,7 @@ public:  LLUIImagePtr LLTaskWearableBridge::getIcon() const  { -	return LLInventoryIcon::getIcon(mAssetType, mInventoryType, FALSE, mFlags, FALSE ); +	return LLInventoryIcon::getIcon(mAssetType, mInventoryType, mFlags, FALSE );  } diff --git a/indra/newview/llviewerfoldertype.cpp b/indra/newview/llviewerfoldertype.cpp index 033d35d80a..2859dabfba 100644 --- a/indra/newview/llviewerfoldertype.cpp +++ b/indra/newview/llviewerfoldertype.cpp @@ -43,13 +43,15 @@ struct ViewerFolderEntry : public LLDictionaryEntry  {  	// Constructor for non-ensembles  	ViewerFolderEntry(const std::string &new_category_name, // default name when creating a new category of this type -					  const std::string &icon_name,			// name of the folder icon +					  const std::string &icon_name_open,	// name of the folder icon +					  const std::string &icon_name_closed,  					  BOOL is_quiet							// folder doesn't need a UI update when changed  		)   		:  		LLDictionaryEntry(empty_string), // no reverse lookup needed on non-ensembles, so just leave this blank -		mIconName(icon_name),  		mNewCategoryName(new_category_name), +		mIconNameOpen(icon_name_open), +		mIconNameClosed(icon_name_closed),  		mIsQuiet(is_quiet)  	{  		mAllowedNames.clear(); @@ -63,7 +65,8 @@ struct ViewerFolderEntry : public LLDictionaryEntry  		)   		:  		LLDictionaryEntry(xui_name), -		mIconName(icon_name), +		mIconNameOpen(icon_name), +		mIconNameClosed(icon_name),  		mNewCategoryName(new_category_name),  		mIsQuiet(FALSE)  	{ @@ -84,7 +87,8 @@ struct ViewerFolderEntry : public LLDictionaryEntry  		}  		return false;  	} -	const std::string mIconName; +	const std::string mIconNameOpen; +	const std::string mIconNameClosed;  	const std::string mNewCategoryName;  	typedef std::vector<std::string> name_vec_t;  	name_vec_t mAllowedNames; @@ -104,31 +108,31 @@ LLViewerFolderDictionary::LLViewerFolderDictionary()  {  	initEnsemblesFromFile(); -	//       													    	  NEW CATEGORY NAME         FOLDER ICON NAME                QUIET? -	//      												  		     |-------------------------|-------------------------------|-----------| -	addEntry(LLFolderType::FT_TEXTURE, 				new ViewerFolderEntry("Textures",				"inv_folder_texture.tga",		FALSE)); -	addEntry(LLFolderType::FT_SOUND, 				new ViewerFolderEntry("Sounds",					"inv_folder_sound.tga",			FALSE)); -	addEntry(LLFolderType::FT_CALLINGCARD, 			new ViewerFolderEntry("Calling Cards",			"inv_folder_callingcard.tga",	FALSE)); -	addEntry(LLFolderType::FT_LANDMARK, 			new ViewerFolderEntry("Landmarks",				"inv_folder_landmark.tga",		FALSE)); -	addEntry(LLFolderType::FT_CLOTHING, 			new ViewerFolderEntry("Clothing",				"inv_folder_clothing.tga",		FALSE)); -	addEntry(LLFolderType::FT_OBJECT, 				new ViewerFolderEntry("Objects",				"inv_folder_object.tga",		FALSE)); -	addEntry(LLFolderType::FT_NOTECARD, 			new ViewerFolderEntry("Notecards",				"inv_folder_notecard.tga",		FALSE)); -	addEntry(LLFolderType::FT_ROOT_INVENTORY, 		new ViewerFolderEntry("My Inventory",			"",								FALSE)); -	addEntry(LLFolderType::FT_LSL_TEXT, 			new ViewerFolderEntry("Scripts",				"inv_folder_script.tga",		FALSE)); -	addEntry(LLFolderType::FT_BODYPART, 			new ViewerFolderEntry("Body Parts",				"inv_folder_bodypart.tga",		FALSE)); -	addEntry(LLFolderType::FT_TRASH, 				new ViewerFolderEntry("Trash",					"inv_folder_trash.tga",			TRUE)); -	addEntry(LLFolderType::FT_SNAPSHOT_CATEGORY, 	new ViewerFolderEntry("Photo Album",			"inv_folder_snapshot.tga",		FALSE)); -	addEntry(LLFolderType::FT_LOST_AND_FOUND, 		new ViewerFolderEntry("Lost And Found",	   		"inv_folder_lostandfound.tga",	TRUE)); -	addEntry(LLFolderType::FT_ANIMATION, 			new ViewerFolderEntry("Animations",				"inv_folder_animation.tga",		FALSE)); -	addEntry(LLFolderType::FT_GESTURE, 				new ViewerFolderEntry("Gestures",				"inv_folder_gesture.tga",		FALSE)); -	addEntry(LLFolderType::FT_FAVORITE, 			new ViewerFolderEntry("Favorites",				"inv_folder_plain_closed.tga",	FALSE)); +	//       													    	  NEW CATEGORY NAME         FOLDER OPEN             FOLDER CLOSED          QUIET? +	//      												  		     |-------------------------|-----------------------|----------------------|-----------| +	addEntry(LLFolderType::FT_TEXTURE, 				new ViewerFolderEntry("Textures",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_SOUND, 				new ViewerFolderEntry("Sounds",					"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_CALLINGCARD, 			new ViewerFolderEntry("Calling Cards",			"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_LANDMARK, 			new ViewerFolderEntry("Landmarks",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_CLOTHING, 			new ViewerFolderEntry("Clothing",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_OBJECT, 				new ViewerFolderEntry("Objects",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_NOTECARD, 			new ViewerFolderEntry("Notecards",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_ROOT_INVENTORY, 		new ViewerFolderEntry("My Inventory",			"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_LSL_TEXT, 			new ViewerFolderEntry("Scripts",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_BODYPART, 			new ViewerFolderEntry("Body Parts",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_TRASH, 				new ViewerFolderEntry("Trash",					"Inv_TrashOpen",		"Inv_TrashClosed",		TRUE)); +	addEntry(LLFolderType::FT_SNAPSHOT_CATEGORY, 	new ViewerFolderEntry("Photo Album",			"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_LOST_AND_FOUND, 		new ViewerFolderEntry("Lost And Found",	   		"Inv_LostOpen",			"Inv_LostClosed",		TRUE)); +	addEntry(LLFolderType::FT_ANIMATION, 			new ViewerFolderEntry("Animations",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_GESTURE, 				new ViewerFolderEntry("Gestures",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); +	addEntry(LLFolderType::FT_FAVORITE, 			new ViewerFolderEntry("Favorites",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); -	addEntry(LLFolderType::FT_CURRENT_OUTFIT, 		new ViewerFolderEntry("Current Outfit",			"inv_folder_current_outfit.tga",TRUE)); -	addEntry(LLFolderType::FT_OUTFIT, 				new ViewerFolderEntry("New Outfit",				"inv_folder_outfit.tga",		TRUE)); -	addEntry(LLFolderType::FT_MY_OUTFITS, 			new ViewerFolderEntry("My Outfits",				"inv_folder_my_outfits.tga",	TRUE)); -	addEntry(LLFolderType::FT_INBOX, 				new ViewerFolderEntry("Inbox",					"inv_folder_inbox.tga",			FALSE)); +	addEntry(LLFolderType::FT_CURRENT_OUTFIT, 		new ViewerFolderEntry("Current Outfit",			"Inv_SysOpen",			"Inv_SysClosed",		TRUE)); +	addEntry(LLFolderType::FT_OUTFIT, 				new ViewerFolderEntry("New Outfit",				"Inv_LookFolderOpen",	"Inv_LookFolderClosed",	TRUE)); +	addEntry(LLFolderType::FT_MY_OUTFITS, 			new ViewerFolderEntry("My Outfits",				"Inv_SysOpen",			"Inv_SysClosed",		TRUE)); +	addEntry(LLFolderType::FT_INBOX, 				new ViewerFolderEntry("Inbox",					"Inv_SysOpen",			"Inv_SysClosed",		FALSE)); -	addEntry(LLFolderType::FT_NONE, 				new ViewerFolderEntry("New Folder",				"inv_folder_plain_closed.tga",	FALSE)); +	addEntry(LLFolderType::FT_NONE, 				new ViewerFolderEntry("New Folder",				"Inv_SysOpen",			"Inv_SysClosed",		FALSE));  }  bool LLViewerFolderDictionary::initEnsemblesFromFile() @@ -213,12 +217,15 @@ LLFolderType::EType LLViewerFolderType::lookupTypeFromXUIName(const std::string  	return LLViewerFolderDictionary::getInstance()->lookup(name);  } -const std::string &LLViewerFolderType::lookupIconName(LLFolderType::EType folder_type) +const std::string &LLViewerFolderType::lookupIconName(LLFolderType::EType folder_type, BOOL is_open)  {  	const ViewerFolderEntry *entry = LLViewerFolderDictionary::getInstance()->lookup(folder_type);  	if (entry)  	{ -		return entry->mIconName; +		if (is_open) +			return entry->mIconNameOpen; +		else +			return entry->mIconNameClosed;  	}  	return badLookup();  } diff --git a/indra/newview/llviewerfoldertype.h b/indra/newview/llviewerfoldertype.h index dd9360da90..3744ac20f8 100644 --- a/indra/newview/llviewerfoldertype.h +++ b/indra/newview/llviewerfoldertype.h @@ -44,7 +44,7 @@ public:  	static const std::string&   lookupXUIName(EType folder_type); // name used by the UI  	static LLFolderType::EType 	lookupTypeFromXUIName(const std::string& name); -	static const std::string&   lookupIconName(EType folder_type); // folder icon name +	static const std::string&   lookupIconName(EType folder_type, BOOL is_open = FALSE); // folder icon name  	static BOOL					lookupIsQuietType(EType folder_type); // folder doesn't require UI update when changes have occured  	static const std::string&	lookupNewCategoryName(EType folder_type); // default name when creating new category  	static LLFolderType::EType	lookupTypeFromNewCategoryName(const std::string& name); // default name when creating new category diff --git a/indra/newview/llwearableitemslist.cpp b/indra/newview/llwearableitemslist.cpp index abcc442170..54695e9d40 100644 --- a/indra/newview/llwearableitemslist.cpp +++ b/indra/newview/llwearableitemslist.cpp @@ -88,8 +88,6 @@ void LLPanelWearableListItem::onMouseLeave(S32 x, S32 y, MASK mask)  LLPanelWearableListItem::LLPanelWearableListItem(LLViewerInventoryItem* item)  : LLPanelInventoryListItemBase(item)  { -	// icons should not be shown for this type of items (EXT-7511) -	mForceNoLinksOnIcons = true;  }  ////////////////////////////////////////////////////////////////////////// @@ -308,7 +306,7 @@ BOOL LLPanelDummyClothingListItem::postBuild()  	addWidgetToRightSide("btn_add_panel"); -	setIconImage(LLInventoryIcon::getIcon(LLAssetType::AT_CLOTHING, LLInventoryType::IT_NONE, FALSE, mWearableType, FALSE)); +	setIconImage(LLInventoryIcon::getIcon(LLAssetType::AT_CLOTHING, LLInventoryType::IT_NONE, mWearableType, FALSE));  	updateItem();  	// Make it look loke clothing item - reserve space for 'delete' button diff --git a/indra/newview/llxmlrpctransaction.cpp b/indra/newview/llxmlrpctransaction.cpp index a8ac0c0c90..1d10ec7b28 100644 --- a/indra/newview/llxmlrpctransaction.cpp +++ b/indra/newview/llxmlrpctransaction.cpp @@ -513,7 +513,7 @@ void LLXMLRPCTransaction::Impl::setStatus(EStatus status,  				// Usually this means that there's a problem with the login server,  				// not with the client.  Direct user to status page.  				mStatusMessage = LLTrans::getString("server_is_down"); -				mStatusURI = "http://secondlife.com/status/"; +				mStatusURI = "http://status.secondlifegrid.net/";  		}  	}  } diff --git a/indra/newview/skins/default/textures/icons/Inv_Link.png b/indra/newview/skins/default/textures/icons/Inv_Link.pngBinary files differ new file mode 100644 index 0000000000..c1543dacb5 --- /dev/null +++ b/indra/newview/skins/default/textures/icons/Inv_Link.png diff --git a/indra/newview/skins/default/textures/textures.xml b/indra/newview/skins/default/textures/textures.xml index 85ccf0f564..c02bf5741e 100644 --- a/indra/newview/skins/default/textures/textures.xml +++ b/indra/newview/skins/default/textures/textures.xml @@ -228,39 +228,7 @@ with the same filename but different name    <texture name="Inv_TrashOpen" file_name="icons/Inv_TrashOpen.png" preload="false" />    <texture name="Inv_Underpants" file_name="icons/Inv_Underpants.png" preload="false" />    <texture name="Inv_Undershirt" file_name="icons/Inv_Undershirt.png" preload="false" /> - -  <texture name="Inv_Alpha_Link" file_name="icons/Inv_Alpha_Link.png" preload="false" /> -  <texture name="Inv_Animation_Link" file_name="icons/Inv_Animation_Link.png" preload="false" /> -  <texture name="Inv_BodyShape_Link" file_name="icons/Inv_BodyShape_Link.png" preload="false" /> -  <texture name="Inv_CallingCard_Link" file_name="icons/Inv_CallingCard_Link.png" preload="false" /> -  <texture name="Inv_Clothing_Link" file_name="icons/Inv_Clothing_Link.png" preload="false" /> -  <texture name="Inv_Eye_Link" file_name="icons/Inv_Eye_Link.png" preload="false" /> -  <texture name="Inv_FolderClosed_Link" file_name="icons/Inv_FolderClosed_Link.png" preload="false" /> -  <texture name="Inv_FolderOpen_Link" file_name="icons/Inv_FolderOpen_Link.png" preload="false" /> -  <texture name="Inv_Gesture_Link" file_name="icons/Inv_Gesture_Link.png" preload="false" /> -  <texture name="Inv_Gloves_Link" file_name="icons/Inv_Gloves_Link.png" preload="false" /> -  <texture name="Inv_Hair_Link" file_name="icons/Inv_Hair_Link.png" preload="false" /> -  <texture name="Inv_LinkFolder_Link" file_name="icons/Inv_LinkFolder_Link.png" preload="false" /> -  <texture name="Inv_Jacket_Link" file_name="icons/Inv_Jacket_Link.png" preload="false" /> -  <texture name="Inv_LookFolderOpen_Link" file_name="icons/Inv_LookFolderOpen_Link.png" preload="false" /> -  <texture name="Inv_LookFolderClosed_Link" file_name="icons/Inv_LookFolderClosed_Link.png" preload="false" /> -  <texture name="Inv_Landmark_Link" file_name="icons/Inv_Landmark_Link.png" preload="false" /> -  <texture name="Inv_Notecard_Link" file_name="icons/Inv_Notecard_Link.png" preload="false" /> -  <texture name="Inv_Object_Link" file_name="icons/Inv_Object_Link.png" preload="false" /> -  <texture name="Inv_Object_Multi_Link" file_name="icons/Inv_Object_Multi_Link.png" preload="false" /> -  <texture name="Inv_Pants_Link" file_name="icons/Inv_Pants_Link.png" preload="false" /> -  <texture name="Inv_Script_Link" file_name="icons/Inv_Script_Link.png" preload="false" /> -  <texture name="Inv_Shirt_Link" file_name="icons/Inv_Shirt_Link.png" preload="false" /> -  <texture name="Inv_Shoe_Link" file_name="icons/Inv_Shoe_Link.png" preload="false" /> -  <texture name="Inv_Skin_Link" file_name="icons/Inv_Skin_Link.png" preload="false" /> -  <texture name="Inv_Skirt_Link" file_name="icons/Inv_Skirt_Link.png" preload="false" /> -  <texture name="Inv_Snapshot_Link" file_name="icons/Inv_Snapshot_Link.png" preload="false" /> -  <texture name="Inv_Socks_Link" file_name="icons/Inv_Socks_Link.png" preload="false" /> -  <texture name="Inv_Sound_Link" file_name="icons/Inv_Sound_Link.png" preload="false" /> -  <texture name="Inv_Tattoo_Link" file_name="icons/Inv_Tattoo_Link.png" preload="false" /> -  <texture name="Inv_Texture_Link" file_name="icons/Inv_Texture_Link.png" preload="false" /> -  <texture name="Inv_Underpants_Link" file_name="icons/Inv_Underpants_Link.png" preload="false" /> -  <texture name="Inv_Undershirt_Link" file_name="icons/Inv_Undershirt_Link.png" preload="false" /> +  <texture name="Inv_Link" file_name="icons/Inv_Link.png" preload="false" />    <texture name="Linden_Dollar_Alert" file_name="widgets/Linden_Dollar_Alert.png"/>    <texture name="Linden_Dollar_Background" file_name="widgets/Linden_Dollar_Background.png"/> diff --git a/indra/newview/skins/default/xui/en/floater_buy_currency_html.xml b/indra/newview/skins/default/xui/en/floater_buy_currency_html.xml index 4643f66bd8..4b990fa566 100644 --- a/indra/newview/skins/default/xui/en/floater_buy_currency_html.xml +++ b/indra/newview/skins/default/xui/en/floater_buy_currency_html.xml @@ -1,27 +1,27 @@  <?xml version="1.0" encoding="utf-8" standalone="yes" ?>  <floater - legacy_header_height="18"   can_resize="false" - height="280" + can_close="true" + width="422" + height="202"   layout="topleft" - min_height="280" - min_width="450"   name="floater_buy_currency_html"   help_topic="floater_buy_currency_html"   save_rect="true"   single_instance="true"   title="BUY CURRENCY" - width="452"> - <floater.string -      name="buy_currency_url" translate="false"> -        https://quick-buy-www.jeff.ooze.lindenlab.com/en/display - </floater.string> -    <web_browser -     bottom="278" -     follows="left|right|top|bottom" -     layout="topleft" -     left="2" -     name="browser" -     top="18" -     width="450" /> +> +  <floater.string +    name="buy_currency_url" translate="false"> +    https://quick-buy.secondlife.com/[LANGUAGE]/display/?sa=[SPECIFIC_AMOUNT]&sum=[SUM]&msg=[MSG]&bal=[BAL] +  </floater.string> +  <web_browser +    follows="all" +    layout="topleft" +    left="1" +    right="-1"  +    top="1" +    bottom="-1"  +    ignore_ui_scale="false" +    name="browser"/>  </floater> diff --git a/indra/newview/skins/default/xui/en/panel_main_inventory.xml b/indra/newview/skins/default/xui/en/panel_main_inventory.xml index d65b86f007..2a53b3e2fa 100644 --- a/indra/newview/skins/default/xui/en/panel_main_inventory.xml +++ b/indra/newview/skins/default/xui/en/panel_main_inventory.xml @@ -42,7 +42,7 @@    <filter_editor     text_pad_left="10"     follows="left|top|right" - height="23" +   height="23"     label="Filter Inventory"     layout="topleft"     left="10" @@ -68,10 +68,10 @@       top_pad="10"       width="312">      <inventory_panel -        bg_opaque_color="DkGray2" -   bg_alpha_color="DkGray2" -   background_visible="true" -   background_opaque="true" +     bg_opaque_color="DkGray2" +     bg_alpha_color="DkGray2" +     background_visible="true" +     background_opaque="true"       border="false"       bevel_style="none"       follows="all" @@ -82,13 +82,14 @@       left="0"       name="All Items"       sort_order_setting="InventorySortOrder" +	 show_item_link_overlays="true"       top="16"       width="288" />      <recent_inventory_panel -        bg_opaque_color="DkGray2" -   bg_alpha_color="DkGray2" -   background_visible="true" -   background_opaque="true" +     bg_opaque_color="DkGray2" +     bg_alpha_color="DkGray2" +     background_visible="true" +     background_opaque="true"       border="false"       bevel_style="none"       follows="all" @@ -98,6 +99,7 @@       layout="topleft"       left_delta="0"       name="Recent Items" +	 show_item_link_overlays="true"       width="290" />    </tab_container>    <layout_stack diff --git a/indra/newview/skins/default/xui/en/strings.xml b/indra/newview/skins/default/xui/en/strings.xml index 361af0e8fb..294267d43b 100644 --- a/indra/newview/skins/default/xui/en/strings.xml +++ b/indra/newview/skins/default/xui/en/strings.xml @@ -3186,7 +3186,7 @@ Abuse Report</string>    <string name="server_is_down">  	Despite our best efforts, something unexpected has gone wrong. -	Please check secondlife.com/status to see if there is a known problem with the service.   +	Please check status.secondlifegrid.net to see if there is a known problem with the service.            If you continue to experience problems, please check your network and firewall setup.    </string> diff --git a/install.xml b/install.xml index 8387372400..80641d29e6 100644 --- a/install.xml +++ b/install.xml @@ -962,9 +962,9 @@ anguage Infrstructure (CLI) international standard</string>            <key>windows</key>            <map>              <key>md5sum</key> -            <string>1d9697fed57084eea7b3dc250e9c66f7</string> +            <string>d682ed6232193b4eab3170657a54ebf9</string>              <key>url</key> -            <uri>http://s3.amazonaws.com/viewer-source-downloads/install_pkgs/llqtwebkit-windows-qt4.6-20100525.tar.bz2</uri> +            <uri>http://s3.amazonaws.com/viewer-source-downloads/install_pkgs/llqtwebkit-windows-qt4.6-20100519.tar.bz2</uri>            </map>          </map>        </map> | 
