diff options
| -rw-r--r-- | indra/newview/llbrowsernotification.cpp | 18 | ||||
| -rw-r--r-- | indra/newview/llfloatermediabrowser.cpp | 95 | ||||
| -rw-r--r-- | indra/newview/llfloatermediabrowser.h | 6 | ||||
| -rw-r--r-- | indra/newview/llfloaterpreference.cpp | 10 | ||||
| -rw-r--r-- | indra/newview/llmediactrl.cpp | 216 | ||||
| -rw-r--r-- | indra/newview/llmediactrl.h | 8 | ||||
| -rw-r--r-- | indra/newview/skins/default/xui/en/floater_media_browser.xml | 70 | ||||
| -rw-r--r-- | indra/newview/skins/default/xui/en/notifications.xml | 5 | ||||
| -rw-r--r-- | indra/newview/skins/default/xui/en/panel_preferences_setup.xml | 14 | 
9 files changed, 231 insertions, 211 deletions
diff --git a/indra/newview/llbrowsernotification.cpp b/indra/newview/llbrowsernotification.cpp index e162527e23..cc54d10944 100644 --- a/indra/newview/llbrowsernotification.cpp +++ b/indra/newview/llbrowsernotification.cpp @@ -36,22 +36,6 @@ using namespace LLNotificationsUI;  bool LLBrowserNotification::processNotification(const LLSD& notify)  { -	LLNotificationPtr notification = LLNotifications::instance().find(notify["id"].asUUID()); - -	if (notification) -	{ -		LLFloaterMediaBrowser* browserp = dynamic_cast<LLFloaterMediaBrowser*>(LLFloaterReg::findInstance("media_browser", notification->getPayload()["source"])); -		if (notify["sigtype"].asString() == "add" || notify["sigtype"].asString() == "load") -		{ -			if (browserp) -			{ -				browserp->showNotification(notification); -			} -		} -		else if (notify["sigtype"].asString() == "delete") -		{ -			browserp->hideNotification(); -		} -	} +	// browser notifications are currently handled directly by the LLMediaCtrl instance that spawned them  	return false;  } diff --git a/indra/newview/llfloatermediabrowser.cpp b/indra/newview/llfloatermediabrowser.cpp index ba8128e902..3e99b27f7f 100644 --- a/indra/newview/llfloatermediabrowser.cpp +++ b/indra/newview/llfloatermediabrowser.cpp @@ -144,16 +144,12 @@ void LLFloaterMediaBrowser::draw()  BOOL LLFloaterMediaBrowser::postBuild()  {  	mBrowser = getChild<LLMediaCtrl>("browser"); -	mBrowser->setMediaID(mKey);  	mBrowser->addObserver(this);  	mAddressCombo = getChild<LLComboBox>("address");  	mAddressCombo->setCommitCallback(onEnterAddress, this);  	mAddressCombo->sortByName(); -	LLButton& notification_close = getChildRef<LLButton>("close_notification"); -	notification_close.setClickedCallback(boost::bind(&LLFloaterMediaBrowser::onCloseNotification, this), NULL); -  	childSetAction("back", onClickBack, this);  	childSetAction("forward", onClickForward, this);  	childSetAction("reload", onClickRefresh, this); @@ -250,73 +246,6 @@ void LLFloaterMediaBrowser::setCurrentURL(const std::string& url)  	getChildView("reload")->setEnabled(TRUE);  } -void LLFloaterMediaBrowser::showNotification(LLNotificationPtr notify) -{ -	mCurNotification = notify; - -	// add popup here -	LLSD payload = notify->getPayload(); - -	LLNotificationFormPtr formp = notify->getForm(); -	LLLayoutPanel& panel = getChildRef<LLLayoutPanel>("notification_area"); -	panel.setVisible(true); -	panel.getChild<LLUICtrl>("notification_icon")->setValue(notify->getIcon()); -	panel.getChild<LLUICtrl>("notification_text")->setValue(notify->getMessage()); -	panel.getChild<LLUICtrl>("notification_text")->setToolTip(notify->getMessage()); -	LLNotificationForm::EIgnoreType ignore_type = formp->getIgnoreType();  -	LLLayoutPanel& form_elements = panel.getChildRef<LLLayoutPanel>("form_elements"); - -	const S32 FORM_PADDING_HORIZONTAL = 10; -	const S32 FORM_PADDING_VERTICAL = 5; -	S32 cur_x = FORM_PADDING_HORIZONTAL; - -	if (ignore_type != LLNotificationForm::IGNORE_NO) -	{ -		LLCheckBoxCtrl::Params checkbox_p; -		checkbox_p.name = "ignore_check"; -		checkbox_p.rect = LLRect(cur_x, form_elements.getRect().getHeight() - FORM_PADDING_VERTICAL, cur_x, FORM_PADDING_VERTICAL); -		checkbox_p.label = formp->getIgnoreMessage(); -		checkbox_p.label_text.text_color = LLColor4::black; -		checkbox_p.commit_callback.function = boost::bind(&LLFloaterMediaBrowser::onClickIgnore, this, _1); - -		LLCheckBoxCtrl* check = LLUICtrlFactory::create<LLCheckBoxCtrl>(checkbox_p); -		check->setRect(check->getBoundingRect()); -		form_elements.addChild(check); -		cur_x = check->getRect().mRight + FORM_PADDING_HORIZONTAL; -	} - -	for (S32 i = 0; i < formp->getNumElements(); i++) -	{ -		LLSD form_element = formp->getElement(i); -		if (form_element["type"].asString() == "button") -		{ -			LLButton::Params button_p; -			button_p.name = form_element["name"]; -			button_p.label = form_element["text"]; -			button_p.rect = LLRect(cur_x, form_elements.getRect().getHeight() - FORM_PADDING_VERTICAL, cur_x, FORM_PADDING_VERTICAL); -			button_p.commit_callback.function = boost::bind(&LLFloaterMediaBrowser::onClickNotificationButton, this, form_element["name"].asString()); -			button_p.auto_resize = true; - -			LLButton* button = LLUICtrlFactory::create<LLButton>(button_p); -			button->autoResize(); -			form_elements.addChild(button); - -			cur_x = button->getRect().mRight + FORM_PADDING_HORIZONTAL; -		} -	} - - -	form_elements.reshape(cur_x, form_elements.getRect().getHeight()); - -	//LLWeb::loadURL(payload["url"], payload["target"]); -} - -void LLFloaterMediaBrowser::hideNotification() -{ -	LLLayoutPanel& panel = getChildRef<LLLayoutPanel>("notification_area"); -	panel.setVisible(FALSE); -} -  //static   void LLFloaterMediaBrowser::onEnterAddress(LLUICtrl* ctrl, void* user_data)  { @@ -449,28 +378,4 @@ void LLFloaterMediaBrowser::openMedia(const std::string& media_url)  	setCurrentURL(media_url);  } -void LLFloaterMediaBrowser::onCloseNotification() -{ -	LLNotifications::instance().cancel(mCurNotification); -} - -void LLFloaterMediaBrowser::onClickIgnore(LLUICtrl* ctrl) -{ -	bool check = ctrl->getValue().asBoolean(); -	if (mCurNotification && mCurNotification->getForm()->getIgnoreType() == LLNotificationForm::IGNORE_SHOW_AGAIN) -	{ -		// question was "show again" so invert value to get "ignore" -		check = !check; -	} -	mCurNotification->setIgnored(check); -} -void LLFloaterMediaBrowser::onClickNotificationButton(const std::string& name) -{ -	if (!mCurNotification) return; - -	LLSD response = mCurNotification->getResponseTemplate(); -	response[name] = true; - -	mCurNotification->respond(response);  -} diff --git a/indra/newview/llfloatermediabrowser.h b/indra/newview/llfloatermediabrowser.h index e6511c6e85..6498e28045 100644 --- a/indra/newview/llfloatermediabrowser.h +++ b/indra/newview/llfloatermediabrowser.h @@ -56,8 +56,6 @@ public:  	void buildURLHistory();  	std::string getSupportURL();  	void setCurrentURL(const std::string& url); -	void showNotification(boost::shared_ptr<LLNotification> notify); -	void hideNotification();  	static void onEnterAddress(LLUICtrl* ctrl, void* user_data);  	static void onClickRefresh(void* user_data); @@ -73,10 +71,6 @@ public:  	static void onClickSeek(void* user_data);  private: -	void onCloseNotification(); -	void onClickIgnore(LLUICtrl* ctrl); -	void onClickNotificationButton(const std::string& name); -  	LLMediaCtrl* mBrowser;  	LLComboBox* mAddressCombo;  	std::string mCurrentURL; diff --git a/indra/newview/llfloaterpreference.cpp b/indra/newview/llfloaterpreference.cpp index 50aacc6458..cba91d7e7e 100644 --- a/indra/newview/llfloaterpreference.cpp +++ b/indra/newview/llfloaterpreference.cpp @@ -798,7 +798,7 @@ void LLFloaterPreference::buildPopupLists()  		LLScrollListItem* item = NULL; -		bool show_popup = LLUI::sSettingGroups["ignores"]->getBOOL(templatep->mName); +		bool show_popup = formp->getIgnored();  		if (!show_popup)  		{  			if (ignore == LLNotificationForm::IGNORE_WITH_LAST_RESPONSE) @@ -1150,9 +1150,7 @@ void LLFloaterPreference::onClickDisablePopup()  	for (itor = items.begin(); itor != items.end(); ++itor)  	{  		LLNotificationTemplatePtr templatep = LLNotifications::instance().getTemplate(*(std::string*)((*itor)->getUserdata())); -		//gSavedSettings.setWarning(templatep->mName, TRUE); -		std::string notification_name = templatep->mName; -		LLUI::sSettingGroups["ignores"]->setBOOL(notification_name, FALSE); +		templatep->mForm->setIgnored(false);  	}  	buildPopupLists(); @@ -1166,7 +1164,7 @@ void LLFloaterPreference::resetAllIgnored()  	{  		if (iter->second->mForm->getIgnoreType() != LLNotificationForm::IGNORE_NO)  		{ -			LLUI::sSettingGroups["ignores"]->setBOOL(iter->first, TRUE); +			iter->second->mForm->setIgnored(true);  		}  	}  } @@ -1179,7 +1177,7 @@ void LLFloaterPreference::setAllIgnored()  	{  		if (iter->second->mForm->getIgnoreType() != LLNotificationForm::IGNORE_NO)  		{ -			LLUI::sSettingGroups["ignores"]->setBOOL(iter->first, FALSE); +			iter->second->mForm->setIgnored(false);  		}  	}  } diff --git a/indra/newview/llmediactrl.cpp b/indra/newview/llmediactrl.cpp index 16519bc0d5..a2c809884b 100644 --- a/indra/newview/llmediactrl.cpp +++ b/indra/newview/llmediactrl.cpp @@ -38,7 +38,6 @@  #include "llviewermedia.h"  #include "llviewertexture.h"  #include "llviewerwindow.h" -#include "llnotificationsutil.h"  #include "llweb.h"  #include "llrender.h"  #include "llpluginclassmedia.h" @@ -49,6 +48,12 @@  // linden library includes  #include "llfocusmgr.h"  #include "llsdutil.h" +#include "lllayoutstack.h" +#include "lliconctrl.h" +#include "lltextbox.h" +#include "llbutton.h" +#include "llcheckboxctrl.h" +#include "llnotifications.h"  extern BOOL gRestoreGL; @@ -90,7 +95,6 @@ LLMediaCtrl::LLMediaCtrl( const Params& p) :  	mTextureWidth ( 1024 ),  	mTextureHeight ( 1024 ),  	mClearCache(false), -	mMediaID(p.media_id),  	mHomePageMimeType(p.initial_mime_type)  {  	{ @@ -177,6 +181,7 @@ void LLMediaCtrl::setTrusted( bool valIn )  //  BOOL LLMediaCtrl::handleHover( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleHover(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -192,6 +197,7 @@ BOOL LLMediaCtrl::handleHover( S32 x, S32 y, MASK mask )  //  BOOL LLMediaCtrl::handleScrollWheel( S32 x, S32 y, S32 clicks )  { +	if (LLPanel::handleScrollWheel(x, y, clicks)) return TRUE;  	if (mMediaSource && mMediaSource->hasMedia())  		mMediaSource->getMediaPlugin()->scrollEvent(0, clicks, gKeyboard->currentMask(TRUE)); @@ -202,6 +208,7 @@ BOOL LLMediaCtrl::handleScrollWheel( S32 x, S32 y, S32 clicks )  //  BOOL LLMediaCtrl::handleMouseUp( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleMouseUp(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -226,6 +233,7 @@ BOOL LLMediaCtrl::handleMouseUp( S32 x, S32 y, MASK mask )  //  BOOL LLMediaCtrl::handleMouseDown( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleMouseDown(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -245,6 +253,7 @@ BOOL LLMediaCtrl::handleMouseDown( S32 x, S32 y, MASK mask )  //  BOOL LLMediaCtrl::handleRightMouseUp( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleRightMouseUp(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -269,6 +278,7 @@ BOOL LLMediaCtrl::handleRightMouseUp( S32 x, S32 y, MASK mask )  //  BOOL LLMediaCtrl::handleRightMouseDown( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleRightMouseDown(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -288,6 +298,7 @@ BOOL LLMediaCtrl::handleRightMouseDown( S32 x, S32 y, MASK mask )  //  BOOL LLMediaCtrl::handleDoubleClick( S32 x, S32 y, MASK mask )  { +	if (LLPanel::handleDoubleClick(x, y, mask)) return TRUE;  	convertInputCoords(x, y);  	if (mMediaSource) @@ -342,6 +353,85 @@ void LLMediaCtrl::onFocusLost()  //  BOOL LLMediaCtrl::postBuild ()  { +	LLLayoutStack::Params layout_p; +	layout_p.name = "notification_stack"; +	layout_p.rect = LLRect(0,getLocalRect().mTop,getLocalRect().mRight, 30); +	layout_p.follows.flags = FOLLOWS_ALL; +	layout_p.mouse_opaque = false; +	layout_p.orientation = "vertical"; + +	LLLayoutStack* stackp = LLUICtrlFactory::create<LLLayoutStack>(layout_p); +	addChild(stackp); + +	LLLayoutPanel::Params panel_p; +	panel_p.rect = LLRect(0, 30, 800, 0); +	panel_p.min_height = 30; +	panel_p.name = "notification_area"; +	panel_p.visible = false; +	panel_p.user_resize = false; +	panel_p.background_visible = true; +	panel_p.bg_alpha_image.name = "Yellow_Gradient"; +	panel_p.auto_resize = false; +	LLLayoutPanel* notification_panel = LLUICtrlFactory::create<LLLayoutPanel>(panel_p); +	stackp->addChild(notification_panel); + +	panel_p = LLUICtrlFactory::getDefaultParams<LLLayoutPanel>(); +	panel_p.auto_resize = true; +	panel_p.mouse_opaque = false; +	LLLayoutPanel* dummy_panel = LLUICtrlFactory::create<LLLayoutPanel>(panel_p); +	stackp->addChild(dummy_panel); + +	layout_p = LLUICtrlFactory::getDefaultParams<LLLayoutStack>(); +	layout_p.rect = LLRect(0, 30, 800, 0); +	layout_p.follows.flags = FOLLOWS_ALL; +	layout_p.orientation = "horizontal"; +	stackp = LLUICtrlFactory::create<LLLayoutStack>(layout_p); +	notification_panel->addChild(stackp); + +	panel_p = LLUICtrlFactory::getDefaultParams<LLLayoutPanel>(); +	panel_p.rect.height = 30; +	LLLayoutPanel* panel = LLUICtrlFactory::create<LLLayoutPanel>(panel_p); +	stackp->addChild(panel); + +	LLIconCtrl::Params icon_p; +	icon_p.name = "notification_icon"; +	icon_p.rect = LLRect(5, 23, 21, 8); +	panel->addChild(LLUICtrlFactory::create<LLIconCtrl>(icon_p)); + +	LLTextBox::Params text_p; +	text_p.rect = LLRect(31, 20, 430, 0); +	text_p.text_color = LLColor4::black; +	text_p.font = LLFontGL::getFontSansSerif(); +	text_p.font.style = "BOLD"; +	text_p.name = "notification_text"; +	text_p.use_ellipses = true; +	panel->addChild(LLUICtrlFactory::create<LLTextBox>(text_p)); + +	panel_p = LLUICtrlFactory::getDefaultParams<LLLayoutPanel>(); +	panel_p.auto_resize = false; +	panel_p.user_resize = false; +	panel_p.name="form_elements"; +	panel_p.rect = LLRect(0, 30, 130, 0); +	LLLayoutPanel* form_elements_panel = LLUICtrlFactory::create<LLLayoutPanel>(panel_p); +	stackp->addChild(form_elements_panel); + +	panel_p = LLUICtrlFactory::getDefaultParams<LLLayoutPanel>(); +	panel_p.auto_resize = false; +	panel_p.user_resize = false; +	panel_p.rect = LLRect(0, 30, 25, 0); +	LLLayoutPanel* close_panel = LLUICtrlFactory::create<LLLayoutPanel>(panel_p); +	stackp->addChild(close_panel); + +	LLButton::Params button_p; +	button_p.name = "close_notification"; +	button_p.rect = LLRect(5, 23, 21, 7); +	button_p.image_color=LLUIColorTable::instance().getColor("DkGray_66"); +    button_p.image_unselected.name="Icon_Close_Foreground"; +	button_p.image_selected.name="Icon_Close_Press"; +	button_p.click_callback.function = boost::bind(&LLMediaCtrl::onCloseNotification, this); + +	close_panel->addChild(LLUICtrlFactory::create<LLButton>(button_p)); +  	setVisibleCallback(boost::bind(&LLMediaCtrl::onVisibilityChange, this, _2));  	return TRUE;  } @@ -350,6 +440,7 @@ BOOL LLMediaCtrl::postBuild ()  //  BOOL LLMediaCtrl::handleKeyHere( KEY key, MASK mask )  { +	if (LLPanel::handleKeyHere(key, mask)) return TRUE;  	BOOL result = FALSE;  	if (mMediaSource) @@ -375,6 +466,7 @@ void LLMediaCtrl::handleVisibilityChange ( BOOL new_visibility )  //  BOOL LLMediaCtrl::handleUnicodeCharHere(llwchar uni_char)  { +	if (LLPanel::handleUnicodeCharHere(uni_char)) return TRUE;  	BOOL result = FALSE;  	if (mMediaSource) @@ -827,7 +919,15 @@ void LLMediaCtrl::draw()  	if ( mBorder && mBorder->getVisible() )  		mBorder->setKeyboardFocusHighlight( gFocusMgr.childHasKeyboardFocus( this ) ); -	 +	if (mCurNotification) +	{ +		if (mCurNotification->isCancelled() || mCurNotification->isExpired()) +		{ +			hideNotification(); +		} +	} + +  	LLPanel::draw();  	// Restore the previous values @@ -938,14 +1038,11 @@ void LLMediaCtrl::handleMediaEvent(LLPluginClassMedia* self, EMediaEvent event)  				// ignore this click and let media plugin handle it  				break;  			default: -				if(gSavedSettings.getBOOL("MediaEnablePopups")) -				{ - -					LLNotificationsUtil::add("PopupAttempt",  -						LLSD(),  -						LLSD().with("source", mMediaID).with("target", target).with("url", url), -						boost::bind(&LLMediaCtrl::onPopup, this, _1, _2)); -				} +				LLNotificationPtr popup_notify = LLNotifications::instance().add("PopupAttempt",  +					LLSD(),  +					LLSD().with("target", target).with("url", url), +					boost::bind(&LLMediaCtrl::onPopup, this, _1, _2)); +				showNotification(popup_notify);  				break;  			}  		}; @@ -1005,3 +1102,100 @@ void LLMediaCtrl::onPopup(const LLSD& notification, const LLSD& response)  		LLWeb::loadURL(notification["payload"]["url"], notification["payload"]["target"]);  	}  } + +void LLMediaCtrl::onCloseNotification() +{ +	LLNotifications::instance().cancel(mCurNotification); +} + +void LLMediaCtrl::onClickIgnore(LLUICtrl* ctrl) +{ +	bool check = ctrl->getValue().asBoolean(); +	if (mCurNotification && mCurNotification->getForm()->getIgnoreType() == LLNotificationForm::IGNORE_SHOW_AGAIN) +	{ +		// question was "show again" so invert value to get "ignore" +		check = !check; +	} +	mCurNotification->setIgnored(check); +} + +void LLMediaCtrl::onClickNotificationButton(const std::string& name) +{ +	if (!mCurNotification) return; + +	LLSD response = mCurNotification->getResponseTemplate(); +	response[name] = true; + +	mCurNotification->respond(response);  +} + +void LLMediaCtrl::showNotification(LLNotificationPtr notify) +{ +	mCurNotification = notify; + +	// add popup here +	LLSD payload = notify->getPayload(); + +	LLNotificationFormPtr formp = notify->getForm(); +	LLLayoutPanel& panel = getChildRef<LLLayoutPanel>("notification_area"); +	panel.setVisible(true); +	panel.getChild<LLUICtrl>("notification_icon")->setValue(notify->getIcon()); +	panel.getChild<LLUICtrl>("notification_text")->setValue(notify->getMessage()); +	panel.getChild<LLUICtrl>("notification_text")->setToolTip(notify->getMessage()); +	LLNotificationForm::EIgnoreType ignore_type = formp->getIgnoreType();  +	LLLayoutPanel& form_elements = panel.getChildRef<LLLayoutPanel>("form_elements"); +	form_elements.deleteAllChildren(); + +	const S32 FORM_PADDING_HORIZONTAL = 10; +	const S32 FORM_PADDING_VERTICAL = 3; +	S32 cur_x = FORM_PADDING_HORIZONTAL; + +	if (ignore_type != LLNotificationForm::IGNORE_NO) +	{ +		LLCheckBoxCtrl::Params checkbox_p; +		checkbox_p.name = "ignore_check"; +		checkbox_p.rect = LLRect(cur_x, form_elements.getRect().getHeight() - FORM_PADDING_VERTICAL, cur_x, FORM_PADDING_VERTICAL); +		checkbox_p.label = formp->getIgnoreMessage(); +		checkbox_p.label_text.text_color = LLColor4::black; +		checkbox_p.commit_callback.function = boost::bind(&LLMediaCtrl::onClickIgnore, this, _1); +		checkbox_p.initial_value = formp->getIgnored(); + +		LLCheckBoxCtrl* check = LLUICtrlFactory::create<LLCheckBoxCtrl>(checkbox_p); +		check->setRect(check->getBoundingRect()); +		form_elements.addChild(check); +		cur_x = check->getRect().mRight + FORM_PADDING_HORIZONTAL; +	} + +	for (S32 i = 0; i < formp->getNumElements(); i++) +	{ +		LLSD form_element = formp->getElement(i); +		if (form_element["type"].asString() == "button") +		{ +			LLButton::Params button_p; +			button_p.name = form_element["name"]; +			button_p.label = form_element["text"]; +			button_p.rect = LLRect(cur_x, form_elements.getRect().getHeight() - FORM_PADDING_VERTICAL, cur_x, FORM_PADDING_VERTICAL); +			button_p.click_callback.function = boost::bind(&LLMediaCtrl::onClickNotificationButton, this, form_element["name"].asString()); +			button_p.auto_resize = true; + +			LLButton* button = LLUICtrlFactory::create<LLButton>(button_p); +			button->autoResize(); +			form_elements.addChild(button); + +			cur_x = button->getRect().mRight + FORM_PADDING_HORIZONTAL; +		} +	} + + +	form_elements.reshape(cur_x, form_elements.getRect().getHeight()); + +	//LLWeb::loadURL(payload["url"], payload["target"]); +} + +void LLMediaCtrl::hideNotification() +{ +	LLLayoutPanel& panel = getChildRef<LLLayoutPanel>("notification_area"); +	panel.setVisible(FALSE); + +	mCurNotification.reset(); +} diff --git a/indra/newview/llmediactrl.h b/indra/newview/llmediactrl.h index 3ba2904003..7008fa893e 100644 --- a/indra/newview/llmediactrl.h +++ b/indra/newview/llmediactrl.h @@ -140,8 +140,9 @@ public:  		bool getDecoupleTextureSize() { return mDecoupleTextureSize; }  		void setTextureSize(S32 width, S32 height); -		void setMediaID(const std::string& id) { mMediaID = id; } +		void showNotification(boost::shared_ptr<class LLNotification> notify); +		void hideNotification();  		// over-rides  		virtual BOOL handleKeyHere( KEY key, MASK mask); @@ -164,6 +165,9 @@ public:  	private:  		void onVisibilityChange ( const LLSD& new_visibility );  		void onPopup(const LLSD& notification, const LLSD& response); +		void onCloseNotification(); +		void onClickNotificationButton(const std::string& name); +		void onClickIgnore(LLUICtrl* ctrl);  		const S32 mTextureDepthBytes;  		LLUUID mMediaTextureID; @@ -185,8 +189,8 @@ public:  		bool mDecoupleTextureSize;  		S32 mTextureWidth;  		S32 mTextureHeight; -		std::string mMediaID;  		bool mClearCache; +		boost::shared_ptr<class LLNotification> mCurNotification;  };  #endif // LL_LLMediaCtrl_H diff --git a/indra/newview/skins/default/xui/en/floater_media_browser.xml b/indra/newview/skins/default/xui/en/floater_media_browser.xml index c220124f46..1cb8613eb4 100644 --- a/indra/newview/skins/default/xui/en/floater_media_browser.xml +++ b/indra/newview/skins/default/xui/en/floater_media_browser.xml @@ -200,76 +200,6 @@               name="browser"               top="0"               width="540" /> -          <layout_stack  -            name="notification_stack" -            left="0" -            top="0" -            width="540" -            bottom="-30" -            follows="all" -            mouse_opaque="false" -            orientation="vertical"> -            <layout_panel -              height="30" -              min_height="30"  -              layout="topleft" -              name="notification_area" -              visible="false" -              user_resize="false" -              background_visible="true" -              bg_alpha_image="Yellow_Gradient" -              auto_resize="false" -              width="800"> -              <layout_stack -                top="0" -                height="30" -                width="800" -                left="0" -                follows="bottom|left|right" -                orientation="horizontal"> -                <layout_panel -                  height="30"> -                  <icon name="notification_icon" -                        left="5" -                        top="7" -                        width="16" -                        height="15"/> -                  <text left_pad="8" -                        top="10" -                        height="25" -                        width="400" -                        text_color="black" -                        font="SansSerifSmall" -                        font.style="BOLD" -                        name="notification_text" -                        value="Notification text here"/> -                </layout_panel> -                <layout_panel -                  height="30" -                  width="130" -                  auto_resize="false" -                  user_resize="false" -                  name="form_elements"/> -                <layout_panel -                  height="30" -                  width="25" -                  auto_resize="false" -                  name="close_panel"> -                  <button left="5" -                          name="close_notification" -                          width="16" -                          height="16" -                          top="8" -                          image_color="DkGray_66" -                          image_unselected="Icon_Close_Foreground" -                          image_selected="Icon_Close_Press"/> -                </layout_panel> -              </layout_stack> -            </layout_panel> -            <layout_panel -              mouse_opaque="false"  -              auto_resize="true"/> -          </layout_stack>              <button               follows="bottom|left"               height="20" diff --git a/indra/newview/skins/default/xui/en/notifications.xml b/indra/newview/skins/default/xui/en/notifications.xml index 59fcd3513e..a2a5015d06 100644 --- a/indra/newview/skins/default/xui/en/notifications.xml +++ b/indra/newview/skins/default/xui/en/notifications.xml @@ -6461,14 +6461,13 @@ Mute everyone?      <unique/>      <form name="form">        <ignore name="ignore" -       text="Enable all pop-ups"/> +              control="MediaEnablePopups"  +              text="Enable all pop-ups"/>        <button default="true"                index="0"                name="open"                text="Open pop-up window"/>      </form> - -    </notification> diff --git a/indra/newview/skins/default/xui/en/panel_preferences_setup.xml b/indra/newview/skins/default/xui/en/panel_preferences_setup.xml index 2c6ceeef2e..879781f746 100644 --- a/indra/newview/skins/default/xui/en/panel_preferences_setup.xml +++ b/indra/newview/skins/default/xui/en/panel_preferences_setup.xml @@ -320,7 +320,19 @@      radio_style="false"      width="400"      top_pad="5"/> - +  <check_box +    top_delta="4" +    enabled="true" +    follows="left|top" +    height="14" +    initial_value="false" +    control_name="MediaEnablePopups" +    label="Enable media browser pop-ups" +    left_delta="0" +    mouse_opaque="true" +    name="media_popup_enabled" +    width="400"            +    top_pad="5"/>    <check_box      top_delta="4"      enabled="true"  | 
