eric6/WebBrowser/StatusBar/StatusBarIcon.py

changeset 6942
2602857055c5
parent 6645
ad476851d7e0
child 7229
53054eb5b15a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/eric6/WebBrowser/StatusBar/StatusBarIcon.py	Sun Apr 14 15:09:21 2019 +0200
@@ -0,0 +1,92 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2016 - 2019 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing the status bar icon base class.
+"""
+
+#
+# This is modelled after the code found in Qupzilla
+# Copyright (C) 2014  David Rosca <nowrep@gmail.com>
+#
+
+from __future__ import unicode_literals
+
+from E5Gui.E5ClickableLabel import E5ClickableLabel
+
+
+class StatusBarIcon(E5ClickableLabel):
+    """
+    Class implementing common methods for all status bar icons.
+    """
+    def __init__(self, window):
+        """
+        Constructor
+        
+        @param window reference to the web browser window
+        @type WebBrowserWindow
+        """
+        super(StatusBarIcon, self).__init__(window)
+        
+        self._window = window
+    
+    def _testCurrentPageWebAttribute(self, attr):
+        """
+        Protected method to test a web attribute on the current page.
+        
+        @param attr attribute to test
+        @type QWebEngineSettings.WebAttribute
+        @return flag indicating the attribute is set
+        @rtype bool
+        """
+        settings = self._currentPageSettings()
+        return settings is not None and settings.testAttribute(attr)
+    
+    def _setCurrentPageWebAttribute(self, attr, val):
+        """
+        Protected method to set a web attribute on the current page.
+        
+        @param attr attribute to sett
+        @type QWebEngineSettings.WebAttribute
+        @param val value to be set
+        @type bool
+        """
+        settings = self._currentPageSettings()
+        if settings is not None:
+            settings.setAttribute(attr, val)
+    
+    def _currentPageSettings(self):
+        """
+        Protected method to get a reference to the web settings of the
+        current page.
+        
+        @return reference to the web settings object
+        @rtype QWebEngineSettings
+        """
+        view = self._window.currentBrowser()
+        if view is None:
+            return None
+        
+        return view.page().settings()
+    
+    def _currentPage(self):
+        """
+        Protected method to get a reference to the current page.
+        
+        @return reference to the current page
+        @rtype WebBrowserPage
+        """
+        view = self._window.currentBrowser()
+        if view is None:
+            return None
+        
+        return view.page()
+    
+    def preferencesChanged(self):
+        """
+        Public method to handle changes of the settings.
+        """
+        # do nothing
+        pass

eric ide

mercurial