openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #12432
[Merge] lp:~trb143/openlp/plugin-changes into lp:openlp
Tim Bentley has proposed merging lp:~trb143/openlp/plugin-changes into lp:openlp.
Requested reviews:
Andreas Preikschat (googol)
For more details, see:
https://code.launchpad.net/~trb143/openlp/plugin-changes/+merge/79593
Fix bug 836897 to allow Alerts to be amended without changing the slide
Refactored the CSS,Javascript,Html load code for alerts and provided a framework for other things.
--
https://code.launchpad.net/~trb143/openlp/plugin-changes/+merge/79593
Your team OpenLP Core is subscribed to branch lp:openlp.
=== modified file 'openlp/core/lib/eventreceiver.py'
--- openlp/core/lib/eventreceiver.py 2011-10-03 18:51:32 +0000
+++ openlp/core/lib/eventreceiver.py 2011-10-17 18:11:27 +0000
@@ -219,6 +219,11 @@
``cursor_normal``
Resets the cursor to default
+
+ ``maindisplay_css_updated``
+ CSS has been updated which needs to be changed on the main display.
+
+
"""
def __init__(self):
"""
=== modified file 'openlp/core/lib/htmlbuilder.py'
--- openlp/core/lib/htmlbuilder.py 2011-09-26 18:48:47 +0000
+++ openlp/core/lib/htmlbuilder.py 2011-10-17 18:11:27 +0000
@@ -73,13 +73,7 @@
#video2 {
z-index: 3;
}
-#alert {
- position: absolute;
- left: 0px;
- top: 0px;
- z-index: 10;
- %s
-}
+%s
#footer {
position: absolute;
z-index: 6;
@@ -179,7 +173,7 @@
break;
}
}
-
+ %s
function show_image(src){
var img = document.getElementById('image');
img.src = src;
@@ -225,34 +219,6 @@
}
}
- function show_alert(alerttext, position){
- var text = document.getElementById('alert');
- text.innerHTML = alerttext;
- if(alerttext == '') {
- text.style.visibility = 'hidden';
- return 0;
- }
- if(position == ''){
- position = getComputedStyle(text, '').verticalAlign;
- }
- switch(position)
- {
- case 'top':
- text.style.top = '0px';
- break;
- case 'middle':
- text.style.top = ((window.innerHeight - text.clientHeight) / 2)
- + 'px';
- break;
- case 'bottom':
- text.style.top = (window.innerHeight - text.clientHeight)
- + 'px';
- break;
- }
- text.style.visibility = 'visible';
- return text.clientHeight;
- }
-
function show_footer(footertext){
document.getElementById('footer').innerHTML = footertext;
}
@@ -316,14 +282,15 @@
<video id="video2" class="size" style="visibility:hidden" autobuffer preload>
</video>
%s
+%s
<div id="footer" class="footer"></div>
<div id="black" class="size"></div>
-<div id="alert" style="visibility:hidden"></div>
</body>
</html>
"""
-def build_html(item, screen, alert, islive, background, image=None):
+def build_html(item, screen, islive, background, image=None,
+ plugins=None):
"""
Build the full web paged structure for display
@@ -333,9 +300,6 @@
``screen``
Current display information
- ``alert``
- Alert display display information
-
``islive``
Item is going live, rather than preview/theme building
@@ -344,6 +308,9 @@
``image``
Image media item - bytes
+
+ ``plugins``
+ The List of available plugins
"""
width = screen[u'size'].width()
height = screen[u'size'].height()
@@ -360,14 +327,24 @@
image_src = u'src="data:image/png;base64,%s"' % image
else:
image_src = u'style="display:none;"'
+ css_additions = u''
+ js_additions = u''
+ html_additions = u''
+ if plugins:
+ for plugin in plugins:
+ css_additions += plugin.getDisplayCss()
+ js_additions += plugin.getDisplayJavaScript()
+ html_additions += plugin.getDisplayHtml()
html = HTMLSRC % (build_background_css(item, width, height),
width, height,
- build_alert_css(alert, width),
+ css_additions,
build_footer_css(item, height),
build_lyrics_css(item, webkitvers),
u'true' if theme and theme.display_slide_transition and islive \
else u'false',
+ js_additions,
bgimage_src, image_src,
+ html_additions,
build_lyrics_html(item, webkitvers))
return html
=== modified file 'openlp/core/lib/plugin.py'
--- openlp/core/lib/plugin.py 2011-09-01 19:45:36 +0000
+++ openlp/core/lib/plugin.py 2011-10-17 18:11:27 +0000
@@ -369,3 +369,30 @@
"""
self.textStrings[name] = {u'title': title, u'tooltip': tooltip}
+ def getDisplayCss(self):
+ """
+ Add css style sheets to htmlbuilder.
+ """
+ return u''
+
+ def getDisplayJavaScript(self):
+ """
+ Add javascript functions to htmlbuilder.
+ """
+ return u''
+
+ def refreshCss(self, frame):
+ """
+ Allow plugins to refresh javascript on displayed screen.
+
+ ``frame``
+ The Web frame holding the page.
+ """
+ return u''
+
+ def getDisplayHtml(self):
+ """
+ Add html code to htmlbuilder.
+ """
+ return u''
+
=== modified file 'openlp/core/lib/pluginmanager.py'
--- openlp/core/lib/pluginmanager.py 2011-07-07 18:03:12 +0000
+++ openlp/core/lib/pluginmanager.py 2011-10-17 18:11:27 +0000
@@ -42,6 +42,13 @@
"""
log.info(u'Plugin manager loaded')
+ @staticmethod
+ def get_instance():
+ """
+ Obtain a single instance of class.
+ """
+ return PluginManager.instance
+
def __init__(self, plugin_dir):
"""
The constructor for the plugin manager. Passes the controllers on to
@@ -51,6 +58,7 @@
The directory to search for plugins.
"""
log.info(u'Plugin manager Initialising')
+ PluginManager.instance = self
if not plugin_dir in sys.path:
log.debug(u'Inserting %s into sys.path', plugin_dir)
sys.path.insert(0, plugin_dir)
=== modified file 'openlp/core/ui/maindisplay.py'
--- openlp/core/ui/maindisplay.py 2011-10-15 11:30:39 +0000
+++ openlp/core/ui/maindisplay.py 2011-10-17 18:11:27 +0000
@@ -35,7 +35,7 @@
from PyQt4.phonon import Phonon
from openlp.core.lib import Receiver, build_html, ServiceItem, image_to_byte, \
- translate
+ translate, PluginManager
from openlp.core.ui import HideMode, ScreenList
@@ -56,7 +56,8 @@
self.isLive = live
self.imageManager = imageManager
self.screens = ScreenList.get_instance()
- self.alertTab = None
+ self.plugins = PluginManager.get_instance().plugins
+ self.rebuildCSS = False
self.hideMode = None
self.videoHide = False
self.override = {}
@@ -80,6 +81,26 @@
QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'openlp_phonon_creation'),
self.createMediaObject)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'maindisplay_css_updated'), self.cssChanged)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'config_updated'), self.configChanged)
+
+ def cssChanged(self):
+ """
+ We may need to rebuild the CSS on the live display.
+ """
+ self.rebuildCSS = True
+
+ def configChanged(self):
+ """
+ Call the plugins to rebuild the Live display CSS as the screen has
+ not been rebuild on exit of config.
+ """
+ if self.rebuildCSS and self.plugins:
+ for plugin in self.plugins:
+ plugin.refreshCss(self.frame)
+ self.rebuildCSS = False
def retranslateUi(self):
"""
@@ -111,6 +132,9 @@
self.screen[u'size'].width(), self.screen[u'size'].height())
self.page = self.webView.page()
self.frame = self.page.mainFrame()
+ if self.isLive and log.getEffectiveLevel() == logging.DEBUG:
+ self.webView.settings().setAttribute(
+ QtWebKit.QWebSettings.DeveloperExtrasEnabled, True)
QtCore.QObject.connect(self.webView,
QtCore.SIGNAL(u'loadFinished(bool)'), self.isWebLoaded)
self.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff)
@@ -153,7 +177,7 @@
serviceItem = ServiceItem()
serviceItem.bg_image_bytes = image_to_byte(self.initialFrame)
self.webView.setHtml(build_html(serviceItem, self.screen,
- self.alertTab, self.isLive, None))
+ self.isLive, None))
self.__hideMouse()
# To display or not to display?
if not self.screen[u'primary']:
@@ -492,8 +516,8 @@
image_bytes = self.imageManager.get_image_bytes(image)
else:
image_bytes = None
- html = build_html(self.serviceItem, self.screen, self.alertTab,
- self.isLive, background, image_bytes)
+ html = build_html(self.serviceItem, self.screen, self.isLive,
+ background, image_bytes, self.plugins)
log.debug(u'buildHtml - pre setHtml')
self.webView.setHtml(html)
log.debug(u'buildHtml - post setHtml')
=== modified file 'openlp/core/ui/settingsform.py'
--- openlp/core/ui/settingsform.py 2011-07-07 18:03:12 +0000
+++ openlp/core/ui/settingsform.py 2011-10-17 18:11:27 +0000
@@ -58,7 +58,7 @@
# load all the settings
self.settingListWidget.clear()
for tabIndex in range(0, self.stackedLayout.count() + 1):
- # take at 0 and the rest shuffell up.
+ # take at 0 and the rest shuffle up.
self.stackedLayout.takeAt(0)
self.insertTab(self.generalTab, 0, PluginStatus.Active)
self.insertTab(self.themesTab, 1, PluginStatus.Active)
=== modified file 'openlp/core/ui/slidecontroller.py'
--- openlp/core/ui/slidecontroller.py 2011-10-05 17:04:59 +0000
+++ openlp/core/ui/slidecontroller.py 2011-10-17 18:11:27 +0000
@@ -79,7 +79,6 @@
self.songEdit = False
self.selectedRow = 0
self.serviceItem = None
- self.alertTab = None
self.panel = QtGui.QWidget(parent.controlSplitter)
self.slideList = {}
# Layout for holding panel
@@ -423,7 +422,6 @@
if self.display:
self.display.close()
self.display = MainDisplay(self, self.imageManager, self.isLive)
- self.display.alertTab = self.alertTab
self.display.setup()
if self.isLive:
self.__addActionsToWidget(self.display)
=== modified file 'openlp/plugins/alerts/alertsplugin.py'
--- openlp/plugins/alerts/alertsplugin.py 2011-07-23 21:29:24 +0000
+++ openlp/plugins/alerts/alertsplugin.py 2011-10-17 18:11:27 +0000
@@ -32,6 +32,7 @@
from openlp.core.lib import Plugin, StringContent, build_icon, translate
from openlp.core.lib.db import Manager
from openlp.core.lib.ui import icon_action, UiStrings
+from openlp.core.lib.theme import VerticalType
from openlp.core.utils.actions import ActionList
from openlp.plugins.alerts.lib import AlertsManager, AlertsTab
from openlp.plugins.alerts.lib.db import init_schema
@@ -39,6 +40,63 @@
log = logging.getLogger(__name__)
+JAVASCRIPT = """
+ function show_alert(alerttext, position){
+ var text = document.getElementById('alert');
+ text.innerHTML = alerttext;
+ if(alerttext == '') {
+ text.style.visibility = 'hidden';
+ return 0;
+ }
+ if(position == ''){
+ position = getComputedStyle(text, '').verticalAlign;
+ }
+ switch(position)
+ {
+ case 'top':
+ text.style.top = '0px';
+ break;
+ case 'middle':
+ text.style.top = ((window.innerHeight - text.clientHeight) / 2)
+ + 'px';
+ break;
+ case 'bottom':
+ text.style.top = (window.innerHeight - text.clientHeight)
+ + 'px';
+ break;
+ }
+ text.style.visibility = 'visible';
+ return text.clientHeight;
+ }
+
+ function update_css(align, font, size, color, bgcolor){
+ var text = document.getElementById('alert');
+ text.style.verticalAlign = align;
+ text.style.fontSize = size + "pt";
+ text.style.fontFamily = font;
+ text.style.color = color;
+ text.style.backgroundColor = bgcolor;
+ }
+"""
+CSS = """
+ #alert {
+ position: absolute;
+ left: 0px;
+ top: 0px;
+ z-index: 10;
+ width: 100%%;
+ vertical-align: %s;
+ font-family: %s;
+ font-size: %spt;
+ color: %s;
+ background-color: %s;
+ }
+"""
+
+HTML = """
+ <div id="alert" style="visibility:hidden"></div>
+"""
+
class AlertsPlugin(Plugin):
log.info(u'Alerts Plugin loaded')
@@ -79,7 +137,6 @@
self.toolsAlertItem.setVisible(True)
action_list = ActionList.get_instance()
action_list.add_action(self.toolsAlertItem, UiStrings().Tools)
- self.liveController.alertTab = self.settings_tab
def finalise(self):
"""
@@ -121,3 +178,35 @@
u'title': translate('AlertsPlugin', 'Alerts', 'container title')
}
+ def getDisplayJavaScript(self):
+ """
+ Add Javascript to the main display.
+ """
+ return JAVASCRIPT
+
+ def getDisplayCss(self):
+ """
+ Add CSS to the main display.
+ """
+ align = VerticalType.Names[self.settings_tab.location]
+ return CSS % (align, self.settings_tab.font_face,
+ self.settings_tab.font_size, self.settings_tab.font_color,
+ self.settings_tab.bg_color)
+
+ def getDisplayHtml(self):
+ """
+ Add HTML to the main display.
+ """
+ return HTML
+
+ def refreshCss(self, frame):
+ """
+ Trigger an update of the CSS in the maindisplay.
+
+ ``frame``
+ The Web frame holding the page.
+ """
+ align = VerticalType.Names[self.settings_tab.location]
+ frame.evaluateJavaScript(u'update_css("%s", "%s", "%s", "%s", "%s")' %
+ (align, self.settings_tab.font_face, self.settings_tab.font_size,
+ self.settings_tab.font_color, self.settings_tab.bg_color))
=== modified file 'openlp/plugins/alerts/lib/alertstab.py'
--- openlp/plugins/alerts/lib/alertstab.py 2011-08-17 16:16:43 +0000
+++ openlp/plugins/alerts/lib/alertstab.py 2011-10-17 18:11:27 +0000
@@ -27,7 +27,7 @@
from PyQt4 import QtCore, QtGui
-from openlp.core.lib import SettingsTab, translate
+from openlp.core.lib import SettingsTab, translate, Receiver
from openlp.core.lib.ui import UiStrings, create_valign_combo
class AlertsTab(SettingsTab):
@@ -140,6 +140,7 @@
def onTimeoutSpinBoxChanged(self):
self.timeout = self.timeoutSpinBox.value()
+ self.changed = True
def onFontSizeSpinBoxChanged(self):
self.font_size = self.fontSizeSpinBox.value()
@@ -171,10 +172,15 @@
font.setFamily(self.font_face)
self.fontComboBox.setCurrentFont(font)
self.updateDisplay()
+ self.changed = False
def save(self):
settings = QtCore.QSettings()
settings.beginGroup(self.settingsSection)
+ # Check value has changed as no event handles this field
+ if settings.value(u'location', QtCore.QVariant(1)).toInt()[0] != \
+ self.verticalComboBox.currentIndex():
+ self.changed = True
settings.setValue(u'background color', QtCore.QVariant(self.bg_color))
settings.setValue(u'font color', QtCore.QVariant(self.font_color))
settings.setValue(u'font size', QtCore.QVariant(self.font_size))
@@ -184,6 +190,9 @@
self.location = self.verticalComboBox.currentIndex()
settings.setValue(u'location', QtCore.QVariant(self.location))
settings.endGroup()
+ if self.changed:
+ Receiver.send_message(u'maindisplay_css_updated')
+ self.changed = False
def updateDisplay(self):
font = QtGui.QFont()
@@ -193,4 +202,5 @@
self.fontPreview.setFont(font)
self.fontPreview.setStyleSheet(u'background-color: %s; color: %s' %
(self.bg_color, self.font_color))
+ self.changed = True