diff options
Diffstat (limited to 'indra/newview')
| -rw-r--r-- | indra/newview/lloutfitslist.cpp | 16 | ||||
| -rw-r--r-- | indra/newview/llsidepaneliteminfo.cpp | 69 | ||||
| -rw-r--r-- | indra/newview/llsidepaneliteminfo.h | 5 | 
3 files changed, 89 insertions, 1 deletions
| diff --git a/indra/newview/lloutfitslist.cpp b/indra/newview/lloutfitslist.cpp index 33b8f950ad..c0f7fa4abf 100644 --- a/indra/newview/lloutfitslist.cpp +++ b/indra/newview/lloutfitslist.cpp @@ -85,7 +85,7 @@ public:  		registrar.add("Gear.WearAdd", boost::bind(&LLOutfitListGearMenu::onAdd, this)); -		enable_registrar.add("Gear.OnEnable", boost::bind(&LLOutfitsList::isActionEnabled, mOutfitList, _2)); +		enable_registrar.add("Gear.OnEnable", boost::bind(&LLOutfitListGearMenu::onEnable, this, _2));  		enable_registrar.add("Gear.OnVisible", boost::bind(&LLOutfitListGearMenu::onVisible, this, _2));  		mMenu = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>( @@ -193,6 +193,20 @@ private:  		LLAgentWearables::createWearable(type, true);  	} +	bool onEnable(LLSD::String param) +	{ +		// Handle the "Wear - Replace Current Outfit" menu option specially +		// because LLOutfitList::isActionEnabled() checks whether it's allowed +		// to wear selected outfit OR selected items, while we're only +		// interested in the outfit (STORM-183). +		if ("wear" == param) +		{ +			return LLAppearanceMgr::instance().getCanReplaceCOF(mOutfitList->getSelectedOutfitUUID()); +		} + +		return mOutfitList->isActionEnabled(param); +	} +  	bool onVisible(LLSD::String param)  	{  		const LLUUID& selected_outfit_id = getSelectedOutfitID(); diff --git a/indra/newview/llsidepaneliteminfo.cpp b/indra/newview/llsidepaneliteminfo.cpp index 731079fb5d..e41bbe43df 100644 --- a/indra/newview/llsidepaneliteminfo.cpp +++ b/indra/newview/llsidepaneliteminfo.cpp @@ -75,7 +75,40 @@ void LLItemPropertiesObserver::changed(U32 mask)  	}  } +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +// Class LLObjectInventoryObserver +// +// Helper class to watch for changes in an object inventory. +// Used to update item properties in LLSidepanelItemInfo. +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +class LLObjectInventoryObserver : public LLVOInventoryListener +{ +public: +	LLObjectInventoryObserver(LLSidepanelItemInfo* floater, LLViewerObject* object) +		: mFloater(floater) +	{ +		registerVOInventoryListener(object, NULL); +	} +	virtual ~LLObjectInventoryObserver() +	{ +		removeVOInventoryListener(); +	} +	/*virtual*/ void inventoryChanged(LLViewerObject* object, +									  LLInventoryObject::object_list_t* inventory, +									  S32 serial_num, +									  void* user_data); +private: +	LLSidepanelItemInfo* mFloater; +}; +/*virtual*/ +void LLObjectInventoryObserver::inventoryChanged(LLViewerObject* object, +												 LLInventoryObject::object_list_t* inventory, +												 S32 serial_num, +												 void* user_data) +{ +	mFloater->dirty(); +}  ///----------------------------------------------------------------------------  /// Class LLSidepanelItemInfo @@ -86,6 +119,7 @@ static LLRegisterPanelClassWrapper<LLSidepanelItemInfo> t_item_info("sidepanel_i  // Default constructor  LLSidepanelItemInfo::LLSidepanelItemInfo()    : mItemID(LLUUID::null) +  , mObjectInventoryObserver(NULL)  {  	mPropertiesObserver = new LLItemPropertiesObserver(this); @@ -97,6 +131,8 @@ LLSidepanelItemInfo::~LLSidepanelItemInfo()  {  	delete mPropertiesObserver;  	mPropertiesObserver = NULL; + +	stopObjectInventoryObserver();  }  // virtual @@ -134,6 +170,10 @@ BOOL LLSidepanelItemInfo::postBuild()  void LLSidepanelItemInfo::setObjectID(const LLUUID& object_id)  {  	mObjectID = object_id; + +	// Start monitoring changes in the object inventory to update +	// selected inventory item properties in Item Profile panel. See STORM-148. +	startObjectInventoryObserver();  }  void LLSidepanelItemInfo::setItemID(const LLUUID& item_id) @@ -147,6 +187,8 @@ void LLSidepanelItemInfo::reset()  	mObjectID = LLUUID::null;  	mItemID = LLUUID::null; + +	stopObjectInventoryObserver();  }  void LLSidepanelItemInfo::refresh() @@ -600,6 +642,33 @@ void LLSidepanelItemInfo::refreshFromItem(LLViewerInventoryItem* item)  	}  } +void LLSidepanelItemInfo::startObjectInventoryObserver() +{ +	if (!mObjectInventoryObserver) +	{ +		stopObjectInventoryObserver(); + +		// Previous object observer should be removed before starting to observe a new object. +		llassert(mObjectInventoryObserver == NULL); +	} + +	if (mObjectID.isNull()) +	{ +		llwarns << "Empty object id passed to inventory observer" << llendl; +		return; +	} + +	LLViewerObject* object = gObjectList.findObject(mObjectID); + +	mObjectInventoryObserver = new LLObjectInventoryObserver(this, object); +} + +void LLSidepanelItemInfo::stopObjectInventoryObserver() +{ +	delete mObjectInventoryObserver; +	mObjectInventoryObserver = NULL; +} +  void LLSidepanelItemInfo::onClickCreator()  {  	LLViewerInventoryItem* item = findItem(); diff --git a/indra/newview/llsidepaneliteminfo.h b/indra/newview/llsidepaneliteminfo.h index 82ebbfa7ec..10e93dd7de 100644 --- a/indra/newview/llsidepaneliteminfo.h +++ b/indra/newview/llsidepaneliteminfo.h @@ -37,6 +37,7 @@  class LLButton;  class LLViewerInventoryItem;  class LLItemPropertiesObserver; +class LLObjectInventoryObserver;  class LLViewerObject;  class LLPermissions; @@ -63,9 +64,13 @@ protected:  	void refreshFromItem(LLViewerInventoryItem* item);  private: +	void startObjectInventoryObserver(); +	void stopObjectInventoryObserver(); +  	LLUUID mItemID; 	// inventory UUID for the inventory item.  	LLUUID mObjectID; 	// in-world task UUID, or null if in agent inventory.  	LLItemPropertiesObserver* mPropertiesObserver; // for syncing changes to item +	LLObjectInventoryObserver* mObjectInventoryObserver; // for syncing changes to items inside an object  	//  	// UI Elements | 
