forked from openlp/openlp
267 lines
9.6 KiB
Python
267 lines
9.6 KiB
Python
# -*- coding: utf-8 -*-
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
|
|
|
##########################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# ---------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2019 OpenLP Developers #
|
|
# ---------------------------------------------------------------------- #
|
|
# This program is free software: you can redistribute it and/or modify #
|
|
# it under the terms of the GNU General Public License as published by #
|
|
# the Free Software Foundation, either version 3 of the License, or #
|
|
# (at your option) any later version. #
|
|
# #
|
|
# 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 General Public License for more details. #
|
|
# #
|
|
# You should have received a copy of the GNU General Public License #
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
|
##########################################################################
|
|
|
|
import logging
|
|
|
|
from PyQt5 import QtGui
|
|
|
|
from openlp.core.state import State
|
|
from openlp.core.api.http import register_endpoint
|
|
from openlp.core.common.actions import ActionList
|
|
from openlp.core.common.i18n import UiStrings, translate
|
|
from openlp.core.common.settings import Settings
|
|
from openlp.core.lib.db import Manager
|
|
from openlp.core.lib.plugin import Plugin, StringContent
|
|
from openlp.core.lib.theme import VerticalType
|
|
from openlp.core.lib.ui import create_action
|
|
from openlp.core.ui import AlertLocation
|
|
from openlp.core.ui.icons import UiIcons
|
|
from openlp.plugins.alerts.endpoint import api_alerts_endpoint, alerts_endpoint
|
|
from openlp.plugins.alerts.forms.alertform import AlertForm
|
|
from openlp.plugins.alerts.lib.alertsmanager import AlertsManager
|
|
from openlp.plugins.alerts.lib.alertstab import AlertsTab
|
|
from openlp.plugins.alerts.lib.db import init_schema
|
|
|
|
|
|
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.fontSize = size + "pt";
|
|
text.style.fontFamily = font;
|
|
text.style.color = color;
|
|
text.style.backgroundColor = bgcolor;
|
|
switch(align)
|
|
{
|
|
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;
|
|
}
|
|
}
|
|
"""
|
|
CSS = """
|
|
#alert {{
|
|
position: absolute;
|
|
left: 0px;
|
|
top: 0px;
|
|
z-index: 10;
|
|
width: 100%;
|
|
vertical-align: {vertical_align};
|
|
font-family: {font_family};
|
|
font-size: {font_size:d}pt;
|
|
color: {color};
|
|
background-color: {background_color};
|
|
word-wrap: break-word;
|
|
}}
|
|
"""
|
|
|
|
HTML = """
|
|
<div id="alert" style="visibility:hidden"></div>
|
|
"""
|
|
|
|
__default_settings__ = {
|
|
'alerts/font face': QtGui.QFont().family(),
|
|
'alerts/font size': 40,
|
|
'alerts/db type': 'sqlite',
|
|
'alerts/db username': '',
|
|
'alerts/db password': '',
|
|
'alerts/db hostname': '',
|
|
'alerts/db database': '',
|
|
'alerts/location': AlertLocation.Bottom,
|
|
'alerts/background color': '#660000',
|
|
'alerts/font color': '#ffffff',
|
|
'alerts/timeout': 5
|
|
}
|
|
|
|
|
|
class AlertsPlugin(Plugin):
|
|
"""
|
|
The Alerts Plugin Class
|
|
"""
|
|
log.info('Alerts Plugin loaded')
|
|
|
|
def __init__(self):
|
|
"""
|
|
Class __init__ method
|
|
"""
|
|
super(AlertsPlugin, self).__init__('alerts', __default_settings__, settings_tab_class=AlertsTab)
|
|
self.weight = -3
|
|
self.icon_path = UiIcons().alert
|
|
self.icon = self.icon_path
|
|
AlertsManager(self)
|
|
self.manager = Manager('alerts', init_schema)
|
|
self.alert_form = AlertForm(self)
|
|
register_endpoint(alerts_endpoint)
|
|
register_endpoint(api_alerts_endpoint)
|
|
State().add_service(self.name, self.weight, is_plugin=True)
|
|
State().update_pre_conditions(self.name, self.check_pre_conditions())
|
|
|
|
def add_tools_menu_item(self, tools_menu):
|
|
"""
|
|
Give the alerts plugin the opportunity to add items to the **Tools** menu.
|
|
|
|
:param tools_menu: The actual **Tools** menu item, so that your actions can use it as their parent.
|
|
"""
|
|
log.info('add tools menu')
|
|
self.tools_alert_item = create_action(tools_menu, 'toolsAlertItem',
|
|
text=translate('AlertsPlugin', '&Alert'),
|
|
icon=UiIcons().alert,
|
|
statustip=translate('AlertsPlugin', 'Show an alert message.'),
|
|
visible=False, can_shortcuts=True, triggers=self.on_alerts_trigger)
|
|
self.main_window.tools_menu.addAction(self.tools_alert_item)
|
|
|
|
def initialise(self):
|
|
"""
|
|
Initialise plugin
|
|
"""
|
|
log.info('Alerts Initialising')
|
|
super(AlertsPlugin, self).initialise()
|
|
self.tools_alert_item.setVisible(True)
|
|
action_list = ActionList.get_instance()
|
|
action_list.add_action(self.tools_alert_item, UiStrings().Tools)
|
|
|
|
def finalise(self):
|
|
"""
|
|
Tidy up on exit
|
|
"""
|
|
log.info('Alerts Finalising')
|
|
self.manager.finalise()
|
|
super(AlertsPlugin, self).finalise()
|
|
self.tools_alert_item.setVisible(False)
|
|
action_list = ActionList.get_instance()
|
|
action_list.remove_action(self.tools_alert_item, 'Tools')
|
|
|
|
def toggle_alerts_state(self):
|
|
"""
|
|
Switch the alerts state
|
|
"""
|
|
self.alerts_active = not self.alerts_active
|
|
Settings().setValue(self.settings_section + '/active', self.alerts_active)
|
|
|
|
def on_alerts_trigger(self):
|
|
"""
|
|
Start of the Alerts dialog triggered from the main menu.
|
|
"""
|
|
self.alert_form.load_list()
|
|
self.alert_form.exec()
|
|
|
|
@staticmethod
|
|
def about():
|
|
"""
|
|
Plugin Alerts about method
|
|
|
|
:return: text
|
|
"""
|
|
about_text = translate('AlertsPlugin', '<strong>Alerts Plugin</strong>'
|
|
'<br />The alert plugin controls the displaying of alerts on the display screen.')
|
|
return about_text
|
|
|
|
def set_plugin_text_strings(self):
|
|
"""
|
|
Called to define all translatable texts of the plugin
|
|
"""
|
|
# Name PluginList
|
|
self.text_strings[StringContent.Name] = {
|
|
'singular': translate('AlertsPlugin', 'Alert', 'name singular'),
|
|
'plural': translate('AlertsPlugin', 'Alerts', 'name plural')
|
|
}
|
|
# Name for MediaDockManager, SettingsManager
|
|
self.text_strings[StringContent.VisibleName] = {
|
|
'title': translate('AlertsPlugin', 'Alerts', 'container title')
|
|
}
|
|
|
|
@staticmethod
|
|
def get_display_javascript():
|
|
"""
|
|
Add Javascript to the main display.
|
|
"""
|
|
return JAVASCRIPT
|
|
|
|
def get_display_css(self):
|
|
"""
|
|
Add CSS to the main display.
|
|
"""
|
|
align = VerticalType.Names[self.settings_tab.location]
|
|
return CSS.format(vertical_align=align,
|
|
font_family=self.settings_tab.font_face,
|
|
font_size=self.settings_tab.font_size,
|
|
color=self.settings_tab.font_color,
|
|
background_color=self.settings_tab.background_color)
|
|
|
|
@staticmethod
|
|
def get_display_html():
|
|
"""
|
|
Add HTML to the main display.
|
|
"""
|
|
return HTML
|
|
|
|
def refresh_css(self, frame):
|
|
"""
|
|
Trigger an update of the CSS in the main display.
|
|
|
|
:param frame: The Web frame holding the page.
|
|
"""
|
|
align = VerticalType.Names[self.settings_tab.location]
|
|
frame.runJavaScript('update_css("{align}", "{face}", "{size}", "{color}", '
|
|
'"{background}")'.format(align=align,
|
|
face=self.settings_tab.font_face,
|
|
size=self.settings_tab.font_size,
|
|
color=self.settings_tab.font_color,
|
|
background=self.settings_tab.background_color))
|