/** * @file llfloaterhtmlhelp.cpp * @brief HTML Help floater - uses embedded web browser control * * Copyright (c) 2006-2007, Linden Research, Inc. * * Second Life Viewer Source Code * The source code in this file ("Source Code") is provided by Linden Lab * to you under the terms of the GNU General Public License, version 2.0 * ("GPL"), unless you have obtained a separate licensing agreement * ("Other License"), formally executed by you and Linden Lab. Terms of * the GPL can be found in doc/GPL-license.txt in this distribution, or * online at http://secondlife.com/developers/opensource/gplv2 * * There are special exceptions to the terms and conditions of the GPL as * it is applied to this Source Code. View the full text of the exception * in the file doc/FLOSS-exception.txt in this software distribution, or * online at http://secondlife.com/developers/opensource/flossexception * * By copying, modifying or distributing this software, you acknowledge * that you have read and understood your obligations described above, * and agree to abide by those obligations. * * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, * COMPLETENESS OR PERFORMANCE. */ #include "llviewerprecompiledheaders.h" #include "llfloaterhtmlhelp.h" #include "llvieweruictrlfactory.h" #include "llwebbrowserctrl.h" #include "llviewerwindow.h" #include "llviewercontrol.h" #if LL_LIBXUL_ENABLED LLViewerHtmlHelp gViewerHtmlHelp; class LLFloaterHtmlHelp : public LLFloater, public LLWebBrowserCtrlObserver { public: LLFloaterHtmlHelp(std::string start_url = ""); virtual ~LLFloaterHtmlHelp(); virtual void onClose( bool app_quitting ); virtual void draw(); static void show(); static void show(std::string url); static void onClickBack( void* data ); static void onClickHome( void* data ); static void onClickForward( void* data ); static void onClickClose( void* data ); // browser observer impls virtual void onStatusTextChange( const EventType& eventIn ); virtual void onLocationChange( const EventType& eventIn ); // used for some stats logging - will be removed at some point static BOOL sFloaterOpened; protected: LLWebBrowserCtrl* mWebBrowser; static LLFloaterHtmlHelp* sInstance; LLButton* mBackButton; LLButton* mForwardButton; LLButton* mCloseButton; LLTextBox* mStatusText; LLString mStatusTextContents; LLString mCurrentUrl; }; LLFloaterHtmlHelp* LLFloaterHtmlHelp::sInstance = 0; BOOL LLFloaterHtmlHelp::sFloaterOpened = FALSE; //////////////////////////////////////////////////////////////////////////////// // LLFloaterHtmlHelp::LLFloaterHtmlHelp(std::string start_url) : LLFloater( "HTML Help" ), mWebBrowser( 0 ), mStatusTextContents( "" ), mCurrentUrl( "" ) { sInstance = this; // create floater from its XML definition gUICtrlFactory->buildFloater( this, "floater_html_help.xml" ); childSetAction("back_btn", onClickBack, this); childSetAction("home_btn", onClickHome, this); childSetAction("forward_btn", onClickForward, this); childSetAction("close_btn", onClickClose, this); setDefaultBtn("close_btn"); mWebBrowser = LLViewerUICtrlFactory::getWebBrowserByName(this, "html_help_browser" ); if ( mWebBrowser ) { // observe browser control events mWebBrowser->addObserver( this ); if (start_url != "") { mWebBrowser->navigateTo( start_url ); } else { // if the last page we were at before the client was closed is valid, go there and // override what is in the XML file // (not when the window was closed - it's only ever hidden - not closed) LLString lastPageUrl = gSavedSettings.getString( "HtmlHelpLastPage" ); if ( lastPageUrl != "" ) { mWebBrowser->navigateTo( lastPageUrl ); }; } }; } //////////////////////////////////////////////////////////////////////////////// // LLFloaterHtmlHelp::~LLFloaterHtmlHelp() { // stop observing browser events if ( mWebBrowser ) { mWebBrowser->remObserver( this ); }; // save position of floater gSavedSettings.setRect( "HtmlHelpRect", mRect ); // save the location we were at when SL closed gSavedSettings.setString( "HtmlHelpLastPage", mCurrentUrl ); sInstance = 0; } //////////////////////////////////////////////////////////////////////////////// // virtual void LLFloaterHtmlHelp::draw() { // enable/disable buttons depending on state if ( mWebBrowser ) { bool enable_back = mWebBrowser->canNavigateBack(); childSetEnabled( "back_btn", enable_back ); bool enable_forward = mWebBrowser->canNavigateForward(); childSetEnabled( "forward_btn", enable_forward ); }; LLFloater::draw(); } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::show(std::string url) { sFloaterOpened = true; if ( sInstance ) { if (sInstance->mWebBrowser) { sInstance->mWebBrowser->navigateTo(url); } sInstance->setVisibleAndFrontmost(); return; } LLFloaterHtmlHelp* self = new LLFloaterHtmlHelp(url); // reposition floater from saved settings LLRect rect = gSavedSettings.getRect( "HtmlHelpRect" ); self->reshape( rect.getWidth(), rect.getHeight(), FALSE ); self->setRect( rect ); } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onClose( bool app_quitting ) { setVisible( false ); } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onClickClose( void* data ) { LLFloaterHtmlHelp* self = ( LLFloaterHtmlHelp* )data; self->setVisible( false ); } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onClickBack( void* data ) { LLFloaterHtmlHelp* self = ( LLFloaterHtmlHelp* )data; if ( self ) { if ( self->mWebBrowser ) { self->mWebBrowser->navigateBack(); }; }; } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onClickHome( void* data ) { LLFloaterHtmlHelp* self = ( LLFloaterHtmlHelp* )data; if ( self ) { // get the home page URL (which can differ from the start URL) from XML and go there LLWebBrowserCtrl* web_browser = LLUICtrlFactory::getWebBrowserCtrlByName( self, "html_help_browser" ); if ( web_browser ) { web_browser->navigateHome(); }; }; } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onClickForward( void* data ) { LLFloaterHtmlHelp* self = ( LLFloaterHtmlHelp* )data; if ( self ) { if ( self->mWebBrowser ) { self->mWebBrowser->navigateForward(); }; }; } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onStatusTextChange( const EventType& eventIn ) { mStatusTextContents = LLString( eventIn.getStringValue() ); childSetText("status_text", mStatusTextContents); } //////////////////////////////////////////////////////////////////////////////// // void LLFloaterHtmlHelp::onLocationChange( const EventType& eventIn ) { llinfos << "MOZ> Location changed to " << eventIn.getStringValue() << llendl; mCurrentUrl = LLString( eventIn.getStringValue() ); } //////////////////////////////////////////////////////////////////////////////// // LLViewerHtmlHelp::LLViewerHtmlHelp() { LLUI::setHtmlHelp(this); } LLViewerHtmlHelp::~LLViewerHtmlHelp() { LLUI::setHtmlHelp(NULL); } void LLViewerHtmlHelp::show(std::string url) { LLFloaterHtmlHelp::show(url); } BOOL LLViewerHtmlHelp::getFloaterOpened() { return LLFloaterHtmlHelp::sFloaterOpened; } #endif // LL_LIBXUL_ENABLED