ginebra2/SettingsToolbarSnippet.cpp
changeset 3 0954f5dd2cd0
child 12 afcd8e6d025b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ginebra2/SettingsToolbarSnippet.cpp	Tue Jun 29 00:46:29 2010 -0400
@@ -0,0 +1,131 @@
+/*
+ * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
+ * All rights reserved.
+ *
+ * This program 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.
+ *
+ * This program 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 program.  If not,
+ * see "http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html/".
+ *
+ * Description:
+ * This class extends ToolbarSnippet class to hold the
+ * windows view toolbar buttons
+ *
+ */
+
+#include "SettingsToolbarSnippet.h"
+#include "ToolbarChromeItem.h"
+#include "ViewStack.h"
+#include "GWebContentView.h"
+#include "webpagecontroller.h"
+#include <QDebug>
+
+namespace GVA {
+
+    SettingsToolbarSnippet::SettingsToolbarSnippet(const QString& elementId, ChromeWidget * chrome,
+                                                   const QWebElement & element)
+        : DualButtonToolbarSnippet(elementId, chrome, element),
+          m_action1(0), m_action2(0)
+    {      
+    }
+
+    SettingsToolbarSnippet::~SettingsToolbarSnippet()
+    {
+        if(m_action1)
+            delete m_action1;
+        if(m_action2)
+            delete m_action2;
+    }
+
+    SettingsToolbarSnippet * SettingsToolbarSnippet::instance(const QString& elementId, ChromeWidget * chrome, const QWebElement & element)
+    {
+        SettingsToolbarSnippet * that = new SettingsToolbarSnippet( elementId, chrome, element );
+        that->setChromeWidget( new ToolbarChromeItem( that ) );
+        return that;
+    }
+    
+    void SettingsToolbarSnippet::addChild(ChromeSnippet * child) {
+        WebChromeContainerSnippet * s =  dynamic_cast<WebChromeContainerSnippet* >(child);
+        if (!s) {
+            ToolbarActions_t* t = new ToolbarActions_t();
+            if (child->elementId() == "SettingsBackButton" ) {
+                t->actionId = SETTINGS_VIEW_ACTION_BACK;
+                t->actionName = SETTINGS_TOOLBAR_BACK;
+                t->normalImg = ":/chrome/bedrockchrome/toolbar.snippet/icons/icon_back.png";
+                t->disabledImg = "";
+                t->activeImg = ":/chrome/bedrockchrome/toolbar.snippet/icons/icon_back_pressed.png";
+            }
+            else if (child->elementId() == "SettingsFeedbackButton" ) {
+                t->actionId = SETTINGS_VIEW_ACTION_FEEDBACK;
+                t->actionName = SETTINGS_TOOLBAR_FEEDBACK;
+                t->normalImg = ":/chrome/bedrockchrome/toolbar.snippet/icons/icon_feedback.png";
+                t->disabledImg = "";
+                t->activeImg = ":/chrome/bedrockchrome/toolbar.snippet/icons/icon_feedback_pressed.png";
+            }
+            t->id = child->elementId();
+            m_actionInfo.append(t);
+        }
+
+        WebChromeContainerSnippet::addChild(child);
+    }
+
+    void SettingsToolbarSnippet::setAction(ChromeSnippet * s) {
+        ToolbarSnippet::setAction(s);
+
+        ActionButtonSnippet * button  = static_cast<ActionButtonSnippet*> (s);
+        int index = getIndex(s);
+
+        if (index != -1 ) {
+            ToolbarActions_t * t = m_actionInfo.at(index);
+            QAction * action =  button->getDefaultAction();
+            if (t->actionId == SETTINGS_VIEW_ACTION_BACK ) {
+                if( !action ) {
+                    action = new QAction(0);
+                    button->setDefaultAction(action);
+                    m_action1 = action;
+                }
+                connect(action, SIGNAL(triggered()), this, SLOT(handleBackButton()));
+            }
+            else if (t->actionId == SETTINGS_VIEW_ACTION_FEEDBACK) {
+                if( !action ) {
+                    action = new QAction(0);
+                    button->setDefaultAction(action);
+                    m_action2 = action;
+                }
+                connect(action, SIGNAL(triggered()), this, SLOT(handleFeedbackButton()));
+            }
+        }
+    }
+
+    void SettingsToolbarSnippet::handleBackButton() {
+        GWebContentView* webView = static_cast<GWebContentView*> (chrome()->getView("WebView"));
+        if(webView) {
+            // Reloading here because otherwise the settings won't collapse when leaving and
+            // re-entering the view. This fixes BR-3525. If there's a better way to do this in
+            // the future this can be removed.
+            webView->reload();
+            webView->showNormalPage();
+            webView->setGesturesEnabled(true);
+        }
+
+        ViewStack::getSingleton()->switchView( TOOLBAR_WEB_VIEW, TOOLBAR_SETTINGS_VIEW );
+    }
+
+    void SettingsToolbarSnippet::handleFeedbackButton() {
+        QString mailTo = "oss-browser.errors@nokia.com"; 
+        QString feedbackBody = "Enter your feedback here:"; 
+        WebPageController::getSingleton()->feedbackMail(mailTo, feedbackBody);
+    }
+
+
+} // end of namespace GVA
+
+