From 989b922ab94115377160ff3e6a58944fa8d9e2a1 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 28 Apr 2013 20:06:49 +0200 Subject: [PATCH 01/23] added shortcut to jump to the search fields --- openlp/core/lib/settings.py | 1 + openlp/core/ui/mainwindow.py | 34 ++++++++++++++++++++-------------- 2 files changed, 21 insertions(+), 14 deletions(-) diff --git a/openlp/core/lib/settings.py b/openlp/core/lib/settings.py index 49cd8f6d5..440017f72 100644 --- a/openlp/core/lib/settings.py +++ b/openlp/core/lib/settings.py @@ -244,6 +244,7 @@ class Settings(QtCore.QSettings): u'shortcuts/printServiceItem': [QtGui.QKeySequence(u'Ctrl+P')], u'shortcuts/songExportItem': [], u'shortcuts/songUsageStatus': [QtGui.QKeySequence(QtCore.Qt.Key_F4)], + u'shortcuts/searchShortcut': [QtGui.QKeySequence(u'Ctrl+F')], u'shortcuts/settingsShortcutsItem': [], u'shortcuts/settingsImportItem': [], u'shortcuts/settingsPluginListItem': [QtGui.QKeySequence(u'Alt+F7')], diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 2afbb4eb0..c96176986 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -310,6 +310,10 @@ class Ui_MainWindow(object): can_shortcuts=True, category=UiStrings().Help, triggers=self.on_online_help_clicked) self.web_site_item = create_action(main_window, u'webSiteItem', can_shortcuts=True, category=UiStrings().Help) + # Some shortcuts not connected to buttons or menu entires. + self.search_shortcut_action = create_action(main_window, + u'searchShortcut', can_shortcuts=True, category=UiStrings().File, + triggers=self.on_search_shortcut_triggered) add_actions(self.file_import_menu, (self.settings_import_item, None, self.import_theme_item, self.import_language_item)) add_actions(self.file_export_menu, (self.settings_export_item, None, self.export_theme_item, @@ -344,6 +348,7 @@ class Ui_MainWindow(object): add_actions(self.help_menu, (self.on_line_help_item, None, self.web_site_item, self.about_item)) add_actions(self.menuBar, (self.file_menu.menuAction(), self.view_menu.menuAction(), self.tools_menu.menuAction(), self.settings_menu.menuAction(), self.help_menu.menuAction())) + add_actions(self, [self.search_shortcut_action]) # Initialise the translation self.retranslateUi(main_window) self.media_tool_box.setCurrentIndex(0) @@ -467,8 +472,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def __init__(self): """ - This constructor sets up the interface, the various managers, and the - plugins. + This constructor sets up the interface, the various managers, and the plugins. """ QtGui.QMainWindow.__init__(self) Registry().register(u'main_window', self) @@ -545,6 +549,14 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): # Reset the cursor self.application.set_normal_cursor() + def on_search_shortcut_triggered(self): + """ + Called when the search shotcut has been pressed. + """ + widget = self.media_tool_box.currentWidget() + if widget: + widget.on_focus() + def setAutoLanguage(self, value): """ Set the language to automatic. @@ -966,8 +978,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): """ self.setViewMode(False, True, False, False, True, u'live') - def setViewMode(self, media=True, service=True, theme=True, preview=True, - live=True, mode=u''): + def setViewMode(self, media=True, service=True, theme=True, preview=True, live=True, mode=u''): """ Set OpenLP to a different view mode. """ @@ -982,8 +993,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def screen_changed(self): """ - The screen has changed so we have to update components such as the - renderer. + The screen has changed so we have to update components such as the renderer. """ log.debug(u'screen_changed') self.application.set_busy_cursor() @@ -1089,8 +1099,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def set_service_modified(self, modified, fileName): """ - This method is called from the ServiceManager to set the title of the - main window. + This method is called from the ServiceManager to set the title of the main window. ``modified`` Whether or not this service has been modified. @@ -1137,8 +1146,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def set_preview_panel_visibility(self, visible): """ - Sets the visibility of the preview panel including saving the setting - and updating the menu. + Sets the visibility of the preview panel including saving the setting and updating the menu. ``visible`` A bool giving the state to set the panel to @@ -1175,8 +1183,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def set_live_panel_visibility(self, visible): """ - Sets the visibility of the live panel including saving the setting and - updating the menu. + Sets the visibility of the live panel including saving the setting and updating the menu. ``visible`` A bool giving the state to set the panel to @@ -1231,8 +1238,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def update_recent_files_menu(self): """ - Updates the recent file menu with the latest list of service files - accessed. + Updates the recent file menu with the latest list of service files accessed. """ recent_file_count = Settings().value(u'advanced/recent file count') existing_recent_files = [recentFile for recentFile in self.recent_files From 02603eaad5e1b6bead2444a31a82dd9df2e2b953 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 28 Apr 2013 20:22:36 +0200 Subject: [PATCH 02/23] display tool tip in shortcut dialog --- openlp/core/ui/mainwindow.py | 5 ++++- openlp/core/ui/shortcutlistform.py | 17 ++++++++++++----- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index c96176986..5e7aa4ce2 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -310,7 +310,7 @@ class Ui_MainWindow(object): can_shortcuts=True, category=UiStrings().Help, triggers=self.on_online_help_clicked) self.web_site_item = create_action(main_window, u'webSiteItem', can_shortcuts=True, category=UiStrings().Help) - # Some shortcuts not connected to buttons or menu entires. + # Shortcuts not connected to buttons or menu entires. self.search_shortcut_action = create_action(main_window, u'searchShortcut', can_shortcuts=True, category=UiStrings().File, triggers=self.on_search_shortcut_triggered) @@ -438,6 +438,9 @@ class Ui_MainWindow(object): if os.name == u'nt': self.offlineHelpItem.setText(translate('OpenLP.MainWindow', '&User Guide')) self.on_line_help_item.setText(translate('OpenLP.MainWindow', '&Online Help')) + self.search_shortcut_action.setText(UiStrings().Search) + self.search_shortcut_action.setToolTip( + translate('OpenLP.MainWindow', 'Jump to the search box of the current active plugin.')) self.web_site_item.setText(translate('OpenLP.MainWindow', '&Web Site')) for item in self.language_group.actions(): item.setText(item.objectName()) diff --git a/openlp/core/ui/shortcutlistform.py b/openlp/core/ui/shortcutlistform.py index 1b128396f..95a591e6d 100644 --- a/openlp/core/ui/shortcutlistform.py +++ b/openlp/core/ui/shortcutlistform.py @@ -129,11 +129,18 @@ class ShortcutListForm(QtGui.QDialog, Ui_ShortcutListDialog): continue item = QtGui.QTreeWidgetItem([category.name]) for action in category.actions: - actionText = REMOVE_AMPERSAND.sub('', action.text()) - actionItem = QtGui.QTreeWidgetItem([actionText]) - actionItem.setIcon(0, action.icon()) - actionItem.setData(0, QtCore.Qt.UserRole, action) - item.addChild(actionItem) + action_text = REMOVE_AMPERSAND.sub('', action.text()) + action_item = QtGui.QTreeWidgetItem([action_text]) + action_item.setIcon(0, action.icon()) + action_item.setData(0, QtCore.Qt.UserRole, action) + tool_tip_text = action.toolTip() + # Only display tool tips if they are helpful. + if tool_tip_text != action_text: + # Display the tool tip in all three colums. + action_item.setToolTip(0, tool_tip_text) + action_item.setToolTip(1, tool_tip_text) + action_item.setToolTip(2, tool_tip_text) + item.addChild(action_item) self.treeWidget.addTopLevelItem(item) item.setExpanded(True) self.refreshShortcutList() From 92d5fd8e197a9bdde94b9212657d96c87a27e3a4 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 28 Apr 2013 20:31:48 +0200 Subject: [PATCH 03/23] removed dead code; fixed attribute names; fixed regression --- openlp/core/ui/firsttimeform.py | 15 +++++++++------ openlp/core/ui/mainwindow.py | 22 +++++++--------------- 2 files changed, 16 insertions(+), 21 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 0f3f3cc18..4486f8dc5 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -97,6 +97,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.config.readfp(io.BytesIO(files)) self.update_screen_list_combo() self.was_download_cancelled = False + self.theme_screenshot_thread = None self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading %s...') self.cancelButton.clicked.connect(self.onCancelButtonClicked) self.noInternetFinishButton.clicked.connect(self.onNoInternetFinishButtonClicked) @@ -146,8 +147,8 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable) self.biblesTreeWidget.expandAll() # Download the theme screenshots. - self.themeScreenshotThread = ThemeScreenshotThread(self) - self.themeScreenshotThread.start() + self.theme_screenshot_thread = ThemeScreenshotThread(self) + self.theme_screenshot_thread.start() self.application.set_normal_cursor() def nextId(self): @@ -166,7 +167,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): return FirstTimePage.Progress elif self.currentId() == FirstTimePage.Themes: self.application.set_busy_cursor() - while not self.themeScreenshotThread.isFinished(): + while not self.theme_screenshot_thread.isFinished(): time.sleep(0.1) self.application.process_events() # Build the screenshot icons, as this can not be done in the thread. @@ -240,9 +241,11 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): if self.lastId == FirstTimePage.NoInternet or (self.lastId <= FirstTimePage.Plugins and not self.hasRunWizard): QtCore.QCoreApplication.exit() sys.exit() - self.was_download_cancelled = True - while self.themeScreenshotThread.isRunning(): - time.sleep(0.1) + self.was_download_cancelled = True() + # Was the thread created. + if self.theme_screenshot_thread: + while self.theme_screenshot_thread.isRunning(): + time.sleep(0.1) self.application.set_normal_cursor() def onNoInternetFinishButtonClicked(self): diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 5e7aa4ce2..9c03dc2b2 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -237,7 +237,7 @@ class Ui_MainWindow(object): self.view_live_panel = create_action(main_window, u'viewLivePanel', can_shortcuts=True, checked=live_visible, category=UiStrings().View, triggers=self.set_live_panel_visibility) - self.lockPanel = create_action(main_window, u'lockPanel', + self.lock_panel = create_action(main_window, u'lockPanel', can_shortcuts=True, checked=panel_locked, category=UiStrings().View, triggers=self.set_lock_panel) @@ -325,7 +325,7 @@ class Ui_MainWindow(object): add_actions(self.view_modeMenu, (self.mode_default_Item, self.mode_setup_item, self.mode_live_item)) add_actions(self.view_menu, (self.view_modeMenu.menuAction(), None, self.view_media_manager_item, self.view_service_manager_item, self.view_theme_manager_item, None, self.view_preview_panel, - self.view_live_panel, None, self.lockPanel)) + self.view_live_panel, None, self.lock_panel)) # i18n add Language Actions add_actions(self.settings_language_menu, (self.auto_language_item, None)) add_actions(self.settings_language_menu, self.language_group.actions()) @@ -361,12 +361,12 @@ class Ui_MainWindow(object): self.set_lock_panel(panel_locked) self.settingsImported = False - def retranslateUi(self, mainWindow): + def retranslateUi(self, main_window): """ Set up the translation system """ - mainWindow.mainTitle = UiStrings().OLPV2x - mainWindow.setWindowTitle(mainWindow.mainTitle) + main_window.mainTitle = UiStrings().OLPV2x + main_window.setWindowTitle(main_window.mainTitle) self.file_menu.setTitle(translate('OpenLP.MainWindow', '&File')) self.file_import_menu.setTitle(translate('OpenLP.MainWindow', '&Import')) self.file_export_menu.setTitle(translate('OpenLP.MainWindow', '&Export')) @@ -428,8 +428,8 @@ class Ui_MainWindow(object): translate('OpenLP.MainWindow', 'Toggle the visibility of the preview panel.')) self.view_live_panel.setText(translate('OpenLP.MainWindow', '&Live Panel')) self.view_live_panel.setToolTip(translate('OpenLP.MainWindow', 'Toggle Live Panel')) - self.lockPanel.setText(translate('OpenLP.MainWindow', 'L&ock Panels')) - self.lockPanel.setStatusTip(translate('OpenLP.MainWindow', 'Prevent the panels being moved.')) + self.lock_panel.setText(translate('OpenLP.MainWindow', 'L&ock Panels')) + self.lock_panel.setStatusTip(translate('OpenLP.MainWindow', 'Prevent the panels being moved.')) self.view_live_panel.setStatusTip(translate('OpenLP.MainWindow', 'Toggle the visibility of the live panel.')) self.settingsPluginListItem.setText(translate('OpenLP.MainWindow', '&Plugin List')) self.settingsPluginListItem.setStatusTip(translate('OpenLP.MainWindow', 'List the Plugins')) @@ -560,14 +560,6 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): if widget: widget.on_focus() - def setAutoLanguage(self, value): - """ - Set the language to automatic. - """ - self.language_group.setDisabled(value) - LanguageManager.auto_language = value - LanguageManager.set_language(self.language_group.checkedAction()) - def on_media_tool_box_changed(self, index): """ Focus a widget when the media toolbox changes. From f396e07feb565ace16d6e570bd0901b1daa4d541 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 28 Apr 2013 20:34:04 +0200 Subject: [PATCH 04/23] fixed regression --- openlp/core/ui/firsttimeform.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 4486f8dc5..cc95abc68 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -241,7 +241,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): if self.lastId == FirstTimePage.NoInternet or (self.lastId <= FirstTimePage.Plugins and not self.hasRunWizard): QtCore.QCoreApplication.exit() sys.exit() - self.was_download_cancelled = True() + self.was_download_cancelled = True # Was the thread created. if self.theme_screenshot_thread: while self.theme_screenshot_thread.isRunning(): From eae143d23236d3241f2acda64029f1ba71b21333 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Mon, 29 Apr 2013 20:42:29 +0200 Subject: [PATCH 05/23] name fixes --- openlp/core/ui/firsttimeform.py | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index cc95abc68..087b9a103 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -220,7 +220,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.application.process_events() # Try to give the wizard a chance to redraw itself time.sleep(0.2) - self._preWizard() + self._pre_wizard() self._performWizard() self._post_wizard() self.application.set_normal_cursor() @@ -313,10 +313,10 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): Calculate and display the download progress. """ increment = (count * block_size) - self.previous_size - self._incrementProgressBar(None, increment) + self._increment_progress_bar(None, increment) self.previous_size = count * block_size - def _incrementProgressBar(self, status_text, increment=1): + def _increment_progress_bar(self, status_text, increment=1): """ Update the wizard progress page. @@ -332,7 +332,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.progressBar.setValue(self.progressBar.value() + increment) self.application.process_events() - def _preWizard(self): + def _pre_wizard(self): """ Prepare the UI for the process. """ @@ -413,7 +413,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): Run the tasks in the wizard. """ # Set plugin states - self._incrementProgressBar(translate('OpenLP.FirstTimeWizard', 'Enabling selected plugins...')) + self._increment_progress_bar(translate('OpenLP.FirstTimeWizard', 'Enabling selected plugins...')) self._setPluginStatus(self.songsCheckBox, u'songs/status') self._setPluginStatus(self.bibleCheckBox, u'bibles/status') # TODO Presentation plugin is not yet working on Mac OS X. @@ -437,7 +437,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): item = self.songsListWidget.item(i) if item.checkState() == QtCore.Qt.Checked: filename = item.data(QtCore.Qt.UserRole) - self._incrementProgressBar(self.downloading % filename, 0) + self._increment_progress_bar(self.downloading % filename, 0) self.previous_size = 0 destination = os.path.join(songs_destination, unicode(filename)) self.urlGetFile(u'%s%s' % (self.web, filename), destination) @@ -448,7 +448,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): item = bibles_iterator.value() if item.parent() and item.checkState(0) == QtCore.Qt.Checked: bible = item.data(0, QtCore.Qt.UserRole) - self._incrementProgressBar(self.downloading % bible, 0) + self._increment_progress_bar(self.downloading % bible, 0) self.previous_size = 0 self.urlGetFile(u'%s%s' % (self.web, bible), os.path.join(bibles_destination, bible)) bibles_iterator += 1 @@ -457,7 +457,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): item = self.themesListWidget.item(i) if item.checkState() == QtCore.Qt.Checked: theme = item.data(QtCore.Qt.UserRole) - self._incrementProgressBar(self.downloading % theme, 0) + self._increment_progress_bar(self.downloading % theme, 0) self.previous_size = 0 self.urlGetFile(u'%s%s' % (self.web, theme), os.path.join(themes_destination, theme)) # Set Default Display From 9a068f5144ec160aa5dd22a4da13fb53fec54fca Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Mon, 6 May 2013 09:43:19 +0200 Subject: [PATCH 06/23] started with test --- .../openlp_core_ui/test_mainwindow.py | 45 +++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 tests/interfaces/openlp_core_ui/test_mainwindow.py diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py new file mode 100644 index 000000000..e2f523ee0 --- /dev/null +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -0,0 +1,45 @@ +""" +Package to test the openlp.core.ui.mainwindow package. +""" +from unittest import TestCase +from mock import MagicMock, patch + +from PyQt4 import QtCore, QtGui, QtTest + +from openlp.core.lib import Registry, ScreenList +from openlp.core.ui.mainwindow import MainWindow + + +class TestMainWindow(TestCase): + + def setUp(self): + """ + Create the UI + """ + Registry.create() + self.registry = Registry() + ScreenList.create(MagicMock()) + self.app = QtGui.QApplication([]) + self.app.args =[] + Registry().register(u'application', self.app) + self.main_window = MainWindow() + Registry().register(u'main_window', self.main_window) + + def tearDown(self): + """ + Delete all the C++ objects at the end so that we don't have a segfault + """ + del self.main_window + del self.app + + def on_search_shortcut_triggered_test(self): + """ + """ + # GIVEN: Mocked mehtod. + mocked_current_widget = MagicMock() + self.main_window.media_tool_box.currentWidget = mocked_current_widget + + # WHEN: Press the shortcut + + # THEN: The on_focus method should have been called. + mocked_current_widget.on_focus.assert_called_with() From 7e41362ca2deb404f28d9337ad52be6649ace6a8 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Wed, 8 May 2013 22:05:54 +0200 Subject: [PATCH 07/23] completed test --- openlp/core/ui/mainwindow.py | 16 ++++++++---- .../openlp_core_ui/test_mainwindow.py | 25 ++++++++++++++----- 2 files changed, 30 insertions(+), 11 deletions(-) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 9c03dc2b2..f28d4996d 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -543,15 +543,21 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): Registry().register_function(u'theme_update_global', self.default_theme_changed) Registry().register_function(u'openlp_version_check', self.version_notice) Registry().register_function(u'config_screen_changed', self.screen_changed) + Registry().register_function(u'bootstrap_post_set_up', self.restore_current_media_manager_item) self.renderer = Renderer() - log.info(u'Load data from Settings') - if Settings().value(u'advanced/save current plugin'): - savedPlugin = Settings().value(u'advanced/current media plugin') - if savedPlugin != -1: - self.media_tool_box.setCurrentIndex(savedPlugin) # Reset the cursor self.application.set_normal_cursor() + def restore_current_media_manager_item(self): + """ + + """ + log.info(u'Load data from Settings') + if Settings().value(u'advanced/save current plugin'): + saved_plugin = Settings().value(u'advanced/current media plugin') + if saved_plugin != -1: + self.media_tool_box.setCurrentIndex(saved_plugin) + def on_search_shortcut_triggered(self): """ Called when the search shotcut has been pressed. diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index e2f523ee0..821c6f980 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -6,7 +6,7 @@ from mock import MagicMock, patch from PyQt4 import QtCore, QtGui, QtTest -from openlp.core.lib import Registry, ScreenList +from openlp.core.lib import Registry from openlp.core.ui.mainwindow import MainWindow @@ -18,12 +18,22 @@ class TestMainWindow(TestCase): """ Registry.create() self.registry = Registry() - ScreenList.create(MagicMock()) self.app = QtGui.QApplication([]) + # Mock cursor busy/normal methods. + self.app.set_busy_cursor = MagicMock() + self.app.set_normal_cursor = MagicMock() self.app.args =[] Registry().register(u'application', self.app) - self.main_window = MainWindow() - Registry().register(u'main_window', self.main_window) + # Mock classes and methods used by mainwindow. + with patch(u'openlp.core.ui.mainwindow.ImageManager') as mocked_image_manager, \ + patch(u'openlp.core.ui.mainwindow.SlideController') as mocked_slide_controller, \ + patch(u'openlp.core.ui.mainwindow.OpenLPDockWidget') as mocked_dock_widget, \ + patch(u'openlp.core.ui.mainwindow.QtGui.QToolBox') as mocked_q_tool_box_class, \ + patch(u'openlp.core.ui.mainwindow.QtGui.QMainWindow.addDockWidget') as mocked_add_dock_method, \ + patch(u'openlp.core.ui.mainwindow.ServiceManager') as mocked_slervice_manager, \ + patch(u'openlp.core.ui.mainwindow.ThemeManager') as mocked_theme_manager, \ + patch(u'openlp.core.ui.mainwindow.Renderer') as mocked_renderer: + self.main_window = MainWindow() def tearDown(self): """ @@ -34,12 +44,15 @@ class TestMainWindow(TestCase): def on_search_shortcut_triggered_test(self): """ + Test if the search edit has focus after CTRL+F has been pressed. """ - # GIVEN: Mocked mehtod. + # GIVEN: Mocked widget. mocked_current_widget = MagicMock() self.main_window.media_tool_box.currentWidget = mocked_current_widget - # WHEN: Press the shortcut + # WHEN: Press the shortcut. + QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) + QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) # THEN: The on_focus method should have been called. mocked_current_widget.on_focus.assert_called_with() From 4ee6d014ffc20a350fb547bfeb0dd547ba58ffd2 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Wed, 8 May 2013 22:13:33 +0200 Subject: [PATCH 08/23] release the key --- tests/interfaces/openlp_core_ui/test_mainwindow.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index 821c6f980..6d3450a4c 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -52,7 +52,7 @@ class TestMainWindow(TestCase): # WHEN: Press the shortcut. QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) - QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) + QtTest.QTest.keyRelease(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) # THEN: The on_focus method should have been called. mocked_current_widget.on_focus.assert_called_with() From 32957eca0c4f3aad98ec7278a66015cbd462648a Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Thu, 9 May 2013 21:38:57 +0200 Subject: [PATCH 09/23] removed dead code --- openlp/core/ui/mainwindow.py | 34 +++---------------- .../openlp_core_ui/test_mainwindow.py | 6 ++-- 2 files changed, 8 insertions(+), 32 deletions(-) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index f28d4996d..95b065baf 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -365,8 +365,7 @@ class Ui_MainWindow(object): """ Set up the translation system """ - main_window.mainTitle = UiStrings().OLPV2x - main_window.setWindowTitle(main_window.mainTitle) + main_window.setWindowTitle(UiStrings().OLPV2x) self.file_menu.setTitle(translate('OpenLP.MainWindow', '&File')) self.file_import_menu.setTitle(translate('OpenLP.MainWindow', '&Import')) self.file_export_menu.setTitle(translate('OpenLP.MainWindow', '&Export')) @@ -498,7 +497,6 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): self.new_data_path = None self.copy_data = False Settings().set_up_default_values() - self.service_not_saved = False self.about_form = AboutForm(self) self.media_controller = MediaController() self.settings_form = SettingsForm(self) @@ -1076,42 +1074,20 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): self.live_controller.display.close() self.live_controller.display = None - def service_changed(self, reset=False, serviceName=None): - """ - Hook to change the main window title when the service changes - - ``reset`` - Shows if the service has been cleared or saved - - ``serviceName`` - The name of the service (if it has one) - """ - if not serviceName: - service_name = u'(unsaved service)' - else: - service_name = serviceName - if reset: - self.service_not_saved = False - title = u'%s - %s' % (self.mainTitle, service_name) - else: - self.service_not_saved = True - title = u'%s - %s*' % (self.mainTitle, service_name) - self.setWindowTitle(title) - - def set_service_modified(self, modified, fileName): + def set_service_modified(self, modified, file_name): """ This method is called from the ServiceManager to set the title of the main window. ``modified`` Whether or not this service has been modified. - ``fileName`` + ``file_name`` The file name of the service file. """ if modified: - title = u'%s - %s*' % (self.mainTitle, fileName) + title = u'%s - %s*' % (UiStrings().OLPV2x, file_name) else: - title = u'%s - %s' % (self.mainTitle, fileName) + title = u'%s - %s' % (UiStrings().OLPV2x, file_name) self.setWindowTitle(title) def show_status_message(self, message): diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index 6d3450a4c..92928640f 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -47,12 +47,12 @@ class TestMainWindow(TestCase): Test if the search edit has focus after CTRL+F has been pressed. """ # GIVEN: Mocked widget. - mocked_current_widget = MagicMock() - self.main_window.media_tool_box.currentWidget = mocked_current_widget + mocked_widget = MagicMock() + self.main_window.media_tool_box.currentWidget.return_value = mocked_widget # WHEN: Press the shortcut. QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) QtTest.QTest.keyRelease(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) # THEN: The on_focus method should have been called. - mocked_current_widget.on_focus.assert_called_with() + mocked_widget.on_focus.assert_called_with() From 53160fc539944dd75cc010a123dea4e0fc84249e Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Thu, 9 May 2013 21:43:44 +0200 Subject: [PATCH 10/23] added doc --- openlp/core/ui/mainwindow.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 95b065baf..debefe084 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -548,13 +548,13 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): def restore_current_media_manager_item(self): """ - + Called on start up to restore the last active media plugin. """ log.info(u'Load data from Settings') if Settings().value(u'advanced/save current plugin'): - saved_plugin = Settings().value(u'advanced/current media plugin') - if saved_plugin != -1: - self.media_tool_box.setCurrentIndex(saved_plugin) + saved_plugin_id = Settings().value(u'advanced/current media plugin') + if saved_plugin_id != -1: + self.media_tool_box.setCurrentIndex(saved_plugin_id) def on_search_shortcut_triggered(self): """ From 0122ac64f20f7300d14ff628ede79993e8d4cba0 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 11 May 2013 19:24:03 +0200 Subject: [PATCH 11/23] fixed test --- tests/interfaces/openlp_core_ui/test_mainwindow.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index 92928640f..837919d85 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -49,9 +49,10 @@ class TestMainWindow(TestCase): # GIVEN: Mocked widget. mocked_widget = MagicMock() self.main_window.media_tool_box.currentWidget.return_value = mocked_widget + self.main_window.show() # WHEN: Press the shortcut. - QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) + QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier, 100) QtTest.QTest.keyRelease(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) # THEN: The on_focus method should have been called. From 23d5df568b6fc4cef4fb96a416f1421eaafa5df2 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 11 May 2013 19:28:42 +0200 Subject: [PATCH 12/23] renames --- openlp/core/ui/firsttimeform.py | 19 +++++++++---------- openlp/core/ui/firsttimewizard.py | 4 ++-- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 087b9a103..e48a6606f 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -76,8 +76,7 @@ class ThemeScreenshotThread(QtCore.QThread): class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): """ - This is the Theme Import Wizard, which allows easy creation and editing of - OpenLP themes. + This is the Theme Import Wizard, which allows easy creation and editing of OpenLP themes. """ log.info(u'ThemeWizardForm loaded') @@ -99,9 +98,9 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.was_download_cancelled = False self.theme_screenshot_thread = None self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading %s...') - self.cancelButton.clicked.connect(self.onCancelButtonClicked) - self.noInternetFinishButton.clicked.connect(self.onNoInternetFinishButtonClicked) - self.currentIdChanged.connect(self.onCurrentIdChanged) + self.cancel_button.clicked.connect(self.onCancelButtonClicked) + self.no_internet_finish_button.clicked.connect(self.onNoInternetFinishButtonClicked) + self.currentIdChanged.connect(self.on_current_id_changed) Registry().register_function(u'config_screen_changed', self.update_screen_list_combo) def exec_(self): @@ -117,7 +116,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): """ self.restart() check_directory_exists(os.path.join(unicode(gettempdir(), get_filesystem_encoding()), u'openlp')) - self.noInternetFinishButton.setVisible(False) + self.no_internet_finish_button.setVisible(False) # Check if this is a re-run of the wizard. self.hasRunWizard = Settings().value(u'core/has run wizard') # Sort out internet access for downloads @@ -177,7 +176,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): else: return self.currentId() + 1 - def onCurrentIdChanged(self, pageId): + def on_current_id_changed(self, pageId): """ Detects Page changes and updates as appropriate. """ @@ -211,9 +210,9 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): elif pageId == FirstTimePage.NoInternet: self.backButton.setVisible(False) self.nextButton.setVisible(False) - self.noInternetFinishButton.setVisible(True) + self.no_internet_finish_button.setVisible(True) if self.hasRunWizard: - self.cancelButton.setVisible(False) + self.cancel_button.setVisible(False) elif pageId == FirstTimePage.Progress: self.application.set_busy_cursor() self.repaint() @@ -404,7 +403,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): 'Click the finish button to start OpenLP.')) self.finishButton.setVisible(True) self.finishButton.setEnabled(True) - self.cancelButton.setVisible(False) + self.cancel_button.setVisible(False) self.nextButton.setVisible(False) self.application.process_events() diff --git a/openlp/core/ui/firsttimewizard.py b/openlp/core/ui/firsttimewizard.py index 3a96873f5..8af9bbbf7 100644 --- a/openlp/core/ui/firsttimewizard.py +++ b/openlp/core/ui/firsttimewizard.py @@ -66,8 +66,8 @@ class Ui_FirstTimeWizard(object): FirstTimeWizard.setOptions(QtGui.QWizard.IndependentPages | QtGui.QWizard.NoBackButtonOnStartPage | QtGui.QWizard.NoBackButtonOnLastPage | QtGui.QWizard.HaveCustomButton1) self.finishButton = self.button(QtGui.QWizard.FinishButton) - self.noInternetFinishButton = self.button(QtGui.QWizard.CustomButton1) - self.cancelButton = self.button(QtGui.QWizard.CancelButton) + self.no_internet_finish_button = self.button(QtGui.QWizard.CustomButton1) + self.cancel_button = self.button(QtGui.QWizard.CancelButton) self.nextButton = self.button(QtGui.QWizard.NextButton) self.backButton = self.button(QtGui.QWizard.BackButton) add_welcome_page(FirstTimeWizard, u':/wizards/wizard_firsttime.bmp') From d9288ac2676f1ca532d5bb138f0e393da3bf05be Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 11 May 2013 19:41:26 +0200 Subject: [PATCH 13/23] renames --- openlp/core/ui/firsttimeform.py | 161 +++++++-------- openlp/core/ui/firsttimewizard.py | 333 +++++++++++++++--------------- 2 files changed, 246 insertions(+), 248 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index e48a6606f..7abec725e 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -68,7 +68,7 @@ class ThemeScreenshotThread(QtCore.QThread): screenshot = config.get(u'theme_%s' % theme, u'screenshot') urllib.urlretrieve(u'%s%s' % (self.parent().web, screenshot), os.path.join(unicode(gettempdir(), get_filesystem_encoding()), u'openlp', screenshot)) - item = QtGui.QListWidgetItem(title, self.parent().themesListWidget) + item = QtGui.QListWidgetItem(title, self.parent().themes_list_widget) item.setData(QtCore.Qt.UserRole, filename) item.setCheckState(QtCore.Qt.Unchecked) item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable) @@ -118,7 +118,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): check_directory_exists(os.path.join(unicode(gettempdir(), get_filesystem_encoding()), u'openlp')) self.no_internet_finish_button.setVisible(False) # Check if this is a re-run of the wizard. - self.hasRunWizard = Settings().value(u'core/has run wizard') + self.has_run_wizard = Settings().value(u'core/has run wizard') # Sort out internet access for downloads if self.web_access: songs = self.config.get(u'songs', u'languages') @@ -126,7 +126,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): for song in songs: title = unicode(self.config.get(u'songs_%s' % song, u'title'), u'utf8') filename = unicode(self.config.get(u'songs_%s' % song, u'filename'), u'utf8') - item = QtGui.QListWidgetItem(title, self.songsListWidget) + item = QtGui.QListWidgetItem(title, self.songs_list_widget) item.setData(QtCore.Qt.UserRole, filename) item.setCheckState(QtCore.Qt.Unchecked) item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable) @@ -134,7 +134,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): bible_languages = bible_languages.split(u',') for lang in bible_languages: language = unicode(self.config.get(u'bibles_%s' % lang, u'title'), u'utf8') - langItem = QtGui.QTreeWidgetItem(self.biblesTreeWidget, [language]) + langItem = QtGui.QTreeWidgetItem(self.bibles_tree_widget, [language]) bibles = self.config.get(u'bibles_%s' % lang, u'translations') bibles = bibles.split(u',') for bible in bibles: @@ -144,7 +144,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): item.setData(0, QtCore.Qt.UserRole, filename) item.setCheckState(0, QtCore.Qt.Unchecked) item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable) - self.biblesTreeWidget.expandAll() + self.bibles_tree_widget.expandAll() # Download the theme screenshots. self.theme_screenshot_thread = ThemeScreenshotThread(self) self.theme_screenshot_thread.start() @@ -176,44 +176,43 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): else: return self.currentId() + 1 - def on_current_id_changed(self, pageId): + def on_current_id_changed(self, page_id): """ Detects Page changes and updates as appropriate. """ - # Keep track of the page we are at. Triggering "Cancel" causes pageId - # to be a -1. + # Keep track of the page we are at. Triggering "Cancel" causes page_id to be a -1. self.application.process_events() - if pageId != -1: - self.lastId = pageId - if pageId == FirstTimePage.Plugins: + if page_id != -1: + self.last_id = page_id + if page_id == FirstTimePage.Plugins: # Set the no internet page text. - if self.hasRunWizard: - self.noInternetLabel.setText(self.noInternetText) + if self.has_run_wizard: + self.no_internet_label.setText(self.no_internet_text) else: - self.noInternetLabel.setText(self.noInternetText + self.cancelWizardText) - elif pageId == FirstTimePage.Defaults: - self.themeComboBox.clear() - for iter in xrange(self.themesListWidget.count()): - item = self.themesListWidget.item(iter) + self.no_internet_label.setText(self.no_internet_text + self.cancelWizardText) + elif page_id == FirstTimePage.Defaults: + self.theme_combo_box.clear() + for iter in xrange(self.themes_list_widget.count()): + item = self.themes_list_widget.item(iter) if item.checkState() == QtCore.Qt.Checked: - self.themeComboBox.addItem(item.text()) - if self.hasRunWizard: + self.theme_combo_box.addItem(item.text()) + if self.has_run_wizard: # Add any existing themes to list. for theme in self.theme_manager.get_themes(): - index = self.themeComboBox.findText(theme) + index = self.theme_combo_box.findText(theme) if index == -1: - self.themeComboBox.addItem(theme) + self.theme_combo_box.addItem(theme) default_theme = Settings().value(u'themes/global theme') # Pre-select the current default theme. - index = self.themeComboBox.findText(default_theme) - self.themeComboBox.setCurrentIndex(index) - elif pageId == FirstTimePage.NoInternet: - self.backButton.setVisible(False) - self.nextButton.setVisible(False) + index = self.theme_combo_box.findText(default_theme) + self.theme_combo_box.setCurrentIndex(index) + elif page_id == FirstTimePage.NoInternet: + self.back_button.setVisible(False) + self.next_button.setVisible(False) self.no_internet_finish_button.setVisible(True) - if self.hasRunWizard: + if self.has_run_wizard: self.cancel_button.setVisible(False) - elif pageId == FirstTimePage.Progress: + elif page_id == FirstTimePage.Progress: self.application.set_busy_cursor() self.repaint() self.application.process_events() @@ -229,15 +228,15 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): The user changed screen resolution or enabled/disabled more screens, so we need to update the combo box. """ - self.displayComboBox.clear() - self.displayComboBox.addItems(self.screens.get_screen_list()) - self.displayComboBox.setCurrentIndex(self.displayComboBox.count() - 1) + self.display_combo_box.clear() + self.display_combo_box.addItems(self.screens.get_screen_list()) + self.display_combo_box.setCurrentIndex(self.display_combo_box.count() - 1) def onCancelButtonClicked(self): """ Process the triggering of the cancel button. """ - if self.lastId == FirstTimePage.NoInternet or (self.lastId <= FirstTimePage.Plugins and not self.hasRunWizard): + if self.last_id == FirstTimePage.NoInternet or (self.last_id <= FirstTimePage.Plugins and not self.has_run_wizard): QtCore.QCoreApplication.exit() sys.exit() self.was_download_cancelled = True @@ -282,15 +281,15 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): def _buildThemeScreenshots(self): """ This method builds the theme screenshots' icons for all items in the - ``self.themesListWidget``. + ``self.themes_list_widget``. """ themes = self.config.get(u'themes', u'files') themes = themes.split(u',') for theme in themes: filename = self.config.get(u'theme_%s' % theme, u'filename') screenshot = self.config.get(u'theme_%s' % theme, u'screenshot') - for index in xrange(self.themesListWidget.count()): - item = self.themesListWidget.item(index) + for index in xrange(self.themes_list_widget.count()): + item = self.themes_list_widget.item(index) if item.data(QtCore.Qt.UserRole) == filename: break item.setIcon(build_icon(os.path.join(unicode(gettempdir(), @@ -326,9 +325,9 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): The value to increment the progress bar by. """ if status_text: - self.progressLabel.setText(status_text) + self.progress_label.setText(status_text) if increment > 0: - self.progressBar.setValue(self.progressBar.value() + increment) + self.progress_bar.setValue(self.progress_bar.value() + increment) self.application.process_events() def _pre_wizard(self): @@ -336,18 +335,18 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): Prepare the UI for the process. """ self.max_progress = 0 - self.finishButton.setVisible(False) + self.finish_button.setVisible(False) self.application.process_events() # Loop through the songs list and increase for each selected item - for i in xrange(self.songsListWidget.count()): + for i in xrange(self.songs_list_widget.count()): self.application.process_events() - item = self.songsListWidget.item(i) + item = self.songs_list_widget.item(i) if item.checkState() == QtCore.Qt.Checked: filename = item.data(QtCore.Qt.UserRole) size = self._getFileSize(u'%s%s' % (self.web, filename)) self.max_progress += size # Loop through the Bibles list and increase for each selected item - iterator = QtGui.QTreeWidgetItemIterator(self.biblesTreeWidget) + iterator = QtGui.QTreeWidgetItemIterator(self.bibles_tree_widget) while iterator.value(): self.application.process_events() item = iterator.value() @@ -357,9 +356,9 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.max_progress += size iterator += 1 # Loop through the themes list and increase for each selected item - for i in xrange(self.themesListWidget.count()): + for i in xrange(self.themes_list_widget.count()): self.application.process_events() - item = self.themesListWidget.item(i) + item = self.themes_list_widget.item(i) if item.checkState() == QtCore.Qt.Checked: filename = item.data(QtCore.Qt.UserRole) size = self._getFileSize(u'%s%s' % (self.web, filename)) @@ -367,16 +366,16 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): if self.max_progress: # Add on 2 for plugins status setting plus a "finished" point. self.max_progress += 2 - self.progressBar.setValue(0) - self.progressBar.setMinimum(0) - self.progressBar.setMaximum(self.max_progress) - self.progressPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Setting Up And Downloading')) - self.progressPage.setSubTitle( + self.progress_bar.setValue(0) + self.progress_bar.setMinimum(0) + self.progress_bar.setMaximum(self.max_progress) + self.progress_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Setting Up And Downloading')) + self.progress_page.setSubTitle( translate('OpenLP.FirstTimeWizard', 'Please wait while OpenLP is set up and your data is downloaded.')) else: - self.progressBar.setVisible(False) - self.progressPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Setting Up')) - self.progressPage.setSubTitle(u'Setup complete.') + self.progress_bar.setVisible(False) + self.progress_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Setting Up')) + self.progress_page.setSubTitle(u'Setup complete.') self.repaint() self.application.process_events() # Try to give the wizard a chance to repaint itself @@ -387,24 +386,24 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): Clean up the UI after the process has finished. """ if self.max_progress: - self.progressBar.setValue(self.progressBar.maximum()) - if self.hasRunWizard: - self.progressLabel.setText(translate('OpenLP.FirstTimeWizard', + self.progress_bar.setValue(self.progress_bar.maximum()) + if self.has_run_wizard: + self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Download complete. Click the finish button to return to OpenLP.')) else: - self.progressLabel.setText(translate('OpenLP.FirstTimeWizard', + self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Download complete. Click the finish button to start OpenLP.')) else: - if self.hasRunWizard: - self.progressLabel.setText(translate('OpenLP.FirstTimeWizard', + if self.has_run_wizard: + self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Click the finish button to return to OpenLP.')) else: - self.progressLabel.setText(translate('OpenLP.FirstTimeWizard', + self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Click the finish button to start OpenLP.')) - self.finishButton.setVisible(True) - self.finishButton.setEnabled(True) + self.finish_button.setVisible(True) + self.finish_button.setEnabled(True) self.cancel_button.setVisible(False) - self.nextButton.setVisible(False) + self.next_button.setVisible(False) self.application.process_events() def _performWizard(self): @@ -413,18 +412,18 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): """ # Set plugin states self._increment_progress_bar(translate('OpenLP.FirstTimeWizard', 'Enabling selected plugins...')) - self._setPluginStatus(self.songsCheckBox, u'songs/status') - self._setPluginStatus(self.bibleCheckBox, u'bibles/status') + self._setPluginStatus(self.songs_check_box, u'songs/status') + self._setPluginStatus(self.bible_check_box, u'bibles/status') # TODO Presentation plugin is not yet working on Mac OS X. # For now just ignore it. if sys.platform != 'darwin': - self._setPluginStatus(self.presentationCheckBox, u'presentations/status') - self._setPluginStatus(self.imageCheckBox, u'images/status') - self._setPluginStatus(self.mediaCheckBox, u'media/status') - self._setPluginStatus(self.remoteCheckBox, u'remotes/status') - self._setPluginStatus(self.customCheckBox, u'custom/status') - self._setPluginStatus(self.songUsageCheckBox, u'songusage/status') - self._setPluginStatus(self.alertCheckBox, u'alerts/status') + self._setPluginStatus(self.presentation_check_box, u'presentations/status') + self._setPluginStatus(self.image_check_box, u'images/status') + self._setPluginStatus(self.media_check_box, u'media/status') + self._setPluginStatus(self.remote_check_box, u'remotes/status') + self._setPluginStatus(self.custom_check_box, u'custom/status') + self._setPluginStatus(self.song_usage_check_box, u'songusage/status') + self._setPluginStatus(self.alert_check_box, u'alerts/status') if self.web_access: # Build directories for downloads songs_destination = os.path.join( @@ -432,8 +431,8 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): bibles_destination = AppLocation.get_section_data_path(u'bibles') themes_destination = AppLocation.get_section_data_path(u'themes') # Download songs - for i in xrange(self.songsListWidget.count()): - item = self.songsListWidget.item(i) + for i in xrange(self.songs_list_widget.count()): + item = self.songs_list_widget.item(i) if item.checkState() == QtCore.Qt.Checked: filename = item.data(QtCore.Qt.UserRole) self._increment_progress_bar(self.downloading % filename, 0) @@ -442,7 +441,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.urlGetFile(u'%s%s' % (self.web, filename), destination) # Download Bibles bibles_iterator = QtGui.QTreeWidgetItemIterator( - self.biblesTreeWidget) + self.bibles_tree_widget) while bibles_iterator.value(): item = bibles_iterator.value() if item.parent() and item.checkState(0) == QtCore.Qt.Checked: @@ -452,20 +451,20 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.urlGetFile(u'%s%s' % (self.web, bible), os.path.join(bibles_destination, bible)) bibles_iterator += 1 # Download themes - for i in xrange(self.themesListWidget.count()): - item = self.themesListWidget.item(i) + for i in xrange(self.themes_list_widget.count()): + item = self.themes_list_widget.item(i) if item.checkState() == QtCore.Qt.Checked: theme = item.data(QtCore.Qt.UserRole) self._increment_progress_bar(self.downloading % theme, 0) self.previous_size = 0 self.urlGetFile(u'%s%s' % (self.web, theme), os.path.join(themes_destination, theme)) # Set Default Display - if self.displayComboBox.currentIndex() != -1: - Settings().setValue(u'core/monitor', self.displayComboBox.currentIndex()) - self.screens.set_current_display(self.displayComboBox.currentIndex()) + if self.display_combo_box.currentIndex() != -1: + Settings().setValue(u'core/monitor', self.display_combo_box.currentIndex()) + self.screens.set_current_display(self.display_combo_box.currentIndex()) # Set Global Theme - if self.themeComboBox.currentIndex() != -1: - Settings().setValue(u'themes/global theme', self.themeComboBox.currentText()) + if self.theme_combo_box.currentIndex() != -1: + Settings().setValue(u'themes/global theme', self.theme_combo_box.currentText()) def _setPluginStatus(self, field, tag): """ diff --git a/openlp/core/ui/firsttimewizard.py b/openlp/core/ui/firsttimewizard.py index 8af9bbbf7..b56507f65 100644 --- a/openlp/core/ui/firsttimewizard.py +++ b/openlp/core/ui/firsttimewizard.py @@ -55,200 +55,199 @@ class Ui_FirstTimeWizard(object): """ The UI widgets for the first time wizard. """ - def setupUi(self, FirstTimeWizard): + def setupUi(self, first_time_wizard): """ Set up the UI. """ - FirstTimeWizard.setObjectName(u'FirstTimeWizard') - FirstTimeWizard.resize(550, 386) - FirstTimeWizard.setModal(True) - FirstTimeWizard.setWizardStyle(QtGui.QWizard.ModernStyle) - FirstTimeWizard.setOptions(QtGui.QWizard.IndependentPages | QtGui.QWizard.NoBackButtonOnStartPage | + first_time_wizard.setObjectName(u'first_time_wizard') + first_time_wizard.resize(550, 386) + first_time_wizard.setModal(True) + first_time_wizard.setWizardStyle(QtGui.QWizard.ModernStyle) + first_time_wizard.setOptions(QtGui.QWizard.IndependentPages | QtGui.QWizard.NoBackButtonOnStartPage | QtGui.QWizard.NoBackButtonOnLastPage | QtGui.QWizard.HaveCustomButton1) - self.finishButton = self.button(QtGui.QWizard.FinishButton) + self.finish_button = self.button(QtGui.QWizard.FinishButton) self.no_internet_finish_button = self.button(QtGui.QWizard.CustomButton1) self.cancel_button = self.button(QtGui.QWizard.CancelButton) - self.nextButton = self.button(QtGui.QWizard.NextButton) - self.backButton = self.button(QtGui.QWizard.BackButton) - add_welcome_page(FirstTimeWizard, u':/wizards/wizard_firsttime.bmp') + self.next_button = self.button(QtGui.QWizard.NextButton) + self.back_button = self.button(QtGui.QWizard.BackButton) + add_welcome_page(first_time_wizard, u':/wizards/wizard_firsttime.bmp') # The plugins page - self.pluginPage = QtGui.QWizardPage() - self.pluginPage.setObjectName(u'pluginPage') - self.pluginLayout = QtGui.QVBoxLayout(self.pluginPage) - self.pluginLayout.setContentsMargins(40, 15, 40, 0) - self.pluginLayout.setObjectName(u'pluginLayout') - self.songsCheckBox = QtGui.QCheckBox(self.pluginPage) - self.songsCheckBox.setChecked(True) - self.songsCheckBox.setObjectName(u'songsCheckBox') - self.pluginLayout.addWidget(self.songsCheckBox) - self.customCheckBox = QtGui.QCheckBox(self.pluginPage) - self.customCheckBox.setChecked(True) - self.customCheckBox.setObjectName(u'customCheckBox') - self.pluginLayout.addWidget(self.customCheckBox) - self.bibleCheckBox = QtGui.QCheckBox(self.pluginPage) - self.bibleCheckBox.setChecked(True) - self.bibleCheckBox.setObjectName(u'bibleCheckBox') - self.pluginLayout.addWidget(self.bibleCheckBox) - self.imageCheckBox = QtGui.QCheckBox(self.pluginPage) - self.imageCheckBox.setChecked(True) - self.imageCheckBox.setObjectName(u'imageCheckBox') - self.pluginLayout.addWidget(self.imageCheckBox) + self.plugin_page = QtGui.QWizardPage() + self.plugin_page.setObjectName(u'plugin_page') + self.plugin_layout = QtGui.QVBoxLayout(self.plugin_page) + self.plugin_layout.setContentsMargins(40, 15, 40, 0) + self.plugin_layout.setObjectName(u'plugin_layout') + self.songs_check_box = QtGui.QCheckBox(self.plugin_page) + self.songs_check_box.setChecked(True) + self.songs_check_box.setObjectName(u'songs_check_box') + self.plugin_layout.addWidget(self.songs_check_box) + self.custom_check_box = QtGui.QCheckBox(self.plugin_page) + self.custom_check_box.setChecked(True) + self.custom_check_box.setObjectName(u'custom_check_box') + self.plugin_layout.addWidget(self.custom_check_box) + self.bible_check_box = QtGui.QCheckBox(self.plugin_page) + self.bible_check_box.setChecked(True) + self.bible_check_box.setObjectName(u'bible_check_box') + self.plugin_layout.addWidget(self.bible_check_box) + self.image_check_box = QtGui.QCheckBox(self.plugin_page) + self.image_check_box.setChecked(True) + self.image_check_box.setObjectName(u'image_check_box') + self.plugin_layout.addWidget(self.image_check_box) # TODO Presentation plugin is not yet working on Mac OS X. # For now just ignore it. if sys.platform != 'darwin': - self.presentationCheckBox = QtGui.QCheckBox(self.pluginPage) - self.presentationCheckBox.setChecked(True) - self.presentationCheckBox.setObjectName(u'presentationCheckBox') - self.pluginLayout.addWidget(self.presentationCheckBox) - self.mediaCheckBox = QtGui.QCheckBox(self.pluginPage) - self.mediaCheckBox.setChecked(True) - self.mediaCheckBox.setObjectName(u'mediaCheckBox') - self.pluginLayout.addWidget(self.mediaCheckBox) - self.remoteCheckBox = QtGui.QCheckBox(self.pluginPage) - self.remoteCheckBox.setObjectName(u'remoteCheckBox') - self.pluginLayout.addWidget(self.remoteCheckBox) - self.songUsageCheckBox = QtGui.QCheckBox(self.pluginPage) - self.songUsageCheckBox.setChecked(True) - self.songUsageCheckBox.setObjectName(u'songUsageCheckBox') - self.pluginLayout.addWidget(self.songUsageCheckBox) - self.alertCheckBox = QtGui.QCheckBox(self.pluginPage) - self.alertCheckBox.setChecked(True) - self.alertCheckBox.setObjectName(u'alertCheckBox') - self.pluginLayout.addWidget(self.alertCheckBox) - FirstTimeWizard.setPage(FirstTimePage.Plugins, self.pluginPage) + self.presentation_check_box = QtGui.QCheckBox(self.plugin_page) + self.presentation_check_box.setChecked(True) + self.presentation_check_box.setObjectName(u'presentation_check_box') + self.plugin_layout.addWidget(self.presentation_check_box) + self.media_check_box = QtGui.QCheckBox(self.plugin_page) + self.media_check_box.setChecked(True) + self.media_check_box.setObjectName(u'media_check_box') + self.plugin_layout.addWidget(self.media_check_box) + self.remote_check_box = QtGui.QCheckBox(self.plugin_page) + self.remote_check_box.setObjectName(u'remote_check_box') + self.plugin_layout.addWidget(self.remote_check_box) + self.song_usage_check_box = QtGui.QCheckBox(self.plugin_page) + self.song_usage_check_box.setChecked(True) + self.song_usage_check_box.setObjectName(u'song_usage_check_box') + self.plugin_layout.addWidget(self.song_usage_check_box) + self.alert_check_box = QtGui.QCheckBox(self.plugin_page) + self.alert_check_box.setChecked(True) + self.alert_check_box.setObjectName(u'alert_check_box') + self.plugin_layout.addWidget(self.alert_check_box) + first_time_wizard.setPage(FirstTimePage.Plugins, self.plugin_page) # The "you don't have an internet connection" page. - self.noInternetPage = QtGui.QWizardPage() - self.noInternetPage.setObjectName(u'noInternetPage') - self.noInternetLayout = QtGui.QVBoxLayout(self.noInternetPage) - self.noInternetLayout.setContentsMargins(50, 30, 50, 40) - self.noInternetLayout.setObjectName(u'noInternetLayout') - self.noInternetLabel = QtGui.QLabel(self.noInternetPage) - self.noInternetLabel.setWordWrap(True) - self.noInternetLabel.setObjectName(u'noInternetLabel') - self.noInternetLayout.addWidget(self.noInternetLabel) - FirstTimeWizard.setPage(FirstTimePage.NoInternet, self.noInternetPage) + self.no_internet_page = QtGui.QWizardPage() + self.no_internet_page.setObjectName(u'no_internet_page') + self.no_internet_layout = QtGui.QVBoxLayout(self.no_internet_page) + self.no_internet_layout.setContentsMargins(50, 30, 50, 40) + self.no_internet_layout.setObjectName(u'no_internet_layout') + self.no_internet_label = QtGui.QLabel(self.no_internet_page) + self.no_internet_label.setWordWrap(True) + self.no_internet_label.setObjectName(u'no_internet_label') + self.no_internet_layout.addWidget(self.no_internet_label) + first_time_wizard.setPage(FirstTimePage.NoInternet, self.no_internet_page) # The song samples page - self.songsPage = QtGui.QWizardPage() - self.songsPage.setObjectName(u'songsPage') - self.songsLayout = QtGui.QVBoxLayout(self.songsPage) - self.songsLayout.setContentsMargins(50, 20, 50, 20) - self.songsLayout.setObjectName(u'songsLayout') - self.songsListWidget = QtGui.QListWidget(self.songsPage) - self.songsListWidget.setAlternatingRowColors(True) - self.songsListWidget.setObjectName(u'songsListWidget') - self.songsLayout.addWidget(self.songsListWidget) - FirstTimeWizard.setPage(FirstTimePage.Songs, self.songsPage) + self.songs_page = QtGui.QWizardPage() + self.songs_page.setObjectName(u'songs_page') + self.songs_layout = QtGui.QVBoxLayout(self.songs_page) + self.songs_layout.setContentsMargins(50, 20, 50, 20) + self.songs_layout.setObjectName(u'songs_layout') + self.songs_list_widget = QtGui.QListWidget(self.songs_page) + self.songs_list_widget.setAlternatingRowColors(True) + self.songs_list_widget.setObjectName(u'songs_list_widget') + self.songs_layout.addWidget(self.songs_list_widget) + first_time_wizard.setPage(FirstTimePage.Songs, self.songs_page) # The Bible samples page - self.biblesPage = QtGui.QWizardPage() - self.biblesPage.setObjectName(u'biblesPage') - self.biblesLayout = QtGui.QVBoxLayout(self.biblesPage) - self.biblesLayout.setContentsMargins(50, 20, 50, 20) - self.biblesLayout.setObjectName(u'biblesLayout') - self.biblesTreeWidget = QtGui.QTreeWidget(self.biblesPage) - self.biblesTreeWidget.setAlternatingRowColors(True) - self.biblesTreeWidget.header().setVisible(False) - self.biblesTreeWidget.setObjectName(u'biblesTreeWidget') - self.biblesLayout.addWidget(self.biblesTreeWidget) - FirstTimeWizard.setPage(FirstTimePage.Bibles, self.biblesPage) + self.bibles_page = QtGui.QWizardPage() + self.bibles_page.setObjectName(u'bibles_page') + self.bibles_layout = QtGui.QVBoxLayout(self.bibles_page) + self.bibles_layout.setContentsMargins(50, 20, 50, 20) + self.bibles_layout.setObjectName(u'bibles_layout') + self.bibles_tree_widget = QtGui.QTreeWidget(self.bibles_page) + self.bibles_tree_widget.setAlternatingRowColors(True) + self.bibles_tree_widget.header().setVisible(False) + self.bibles_tree_widget.setObjectName(u'bibles_tree_widget') + self.bibles_layout.addWidget(self.bibles_tree_widget) + first_time_wizard.setPage(FirstTimePage.Bibles, self.bibles_page) # The theme samples page - self.themesPage = QtGui.QWizardPage() - self.themesPage.setObjectName(u'themesPage') - self.themesLayout = QtGui.QVBoxLayout(self.themesPage) - self.themesLayout.setContentsMargins(20, 50, 20, 60) - self.themesLayout.setObjectName(u'themesLayout') - self.themesListWidget = QtGui.QListWidget(self.themesPage) - self.themesListWidget.setViewMode(QtGui.QListView.IconMode) - self.themesListWidget.setMovement(QtGui.QListView.Static) - self.themesListWidget.setFlow(QtGui.QListView.LeftToRight) - self.themesListWidget.setSpacing(4) - self.themesListWidget.setUniformItemSizes(True) - self.themesListWidget.setIconSize(QtCore.QSize(133, 100)) - self.themesListWidget.setWrapping(False) - self.themesListWidget.setObjectName(u'themesListWidget') - self.themesLayout.addWidget(self.themesListWidget) - FirstTimeWizard.setPage(FirstTimePage.Themes, self.themesPage) + self.themes_page = QtGui.QWizardPage() + self.themes_page.setObjectName(u'themes_page') + self.themes_layout = QtGui.QVBoxLayout(self.themes_page) + self.themes_layout.setContentsMargins(20, 50, 20, 60) + self.themes_layout.setObjectName(u'themes_layout') + self.themes_list_widget = QtGui.QListWidget(self.themes_page) + self.themes_list_widget.setViewMode(QtGui.QListView.IconMode) + self.themes_list_widget.setMovement(QtGui.QListView.Static) + self.themes_list_widget.setFlow(QtGui.QListView.LeftToRight) + self.themes_list_widget.setSpacing(4) + self.themes_list_widget.setUniformItemSizes(True) + self.themes_list_widget.setIconSize(QtCore.QSize(133, 100)) + self.themes_list_widget.setWrapping(False) + self.themes_list_widget.setObjectName(u'themes_list_widget') + self.themes_layout.addWidget(self.themes_list_widget) + first_time_wizard.setPage(FirstTimePage.Themes, self.themes_page) # the default settings page - self.defaultsPage = QtGui.QWizardPage() - self.defaultsPage.setObjectName(u'defaultsPage') - self.defaultsLayout = QtGui.QFormLayout(self.defaultsPage) - self.defaultsLayout.setContentsMargins(50, 20, 50, 20) - self.defaultsLayout.setObjectName(u'defaultsLayout') - self.displayLabel = QtGui.QLabel(self.defaultsPage) - self.displayLabel.setObjectName(u'displayLabel') - self.displayComboBox = QtGui.QComboBox(self.defaultsPage) - self.displayComboBox.setEditable(False) - self.displayComboBox.setInsertPolicy(QtGui.QComboBox.NoInsert) - self.displayComboBox.setObjectName(u'displayComboBox') - self.defaultsLayout.addRow(self.displayLabel, self.displayComboBox) - self.themeLabel = QtGui.QLabel(self.defaultsPage) - self.themeLabel.setObjectName(u'themeLabel') - self.themeComboBox = QtGui.QComboBox(self.defaultsPage) - self.themeComboBox.setEditable(False) - self.themeComboBox.setInsertPolicy(QtGui.QComboBox.NoInsert) - self.themeComboBox.setSizeAdjustPolicy(QtGui.QComboBox.AdjustToContents) - self.themeComboBox.setObjectName(u'themeComboBox') - self.defaultsLayout.addRow(self.themeLabel, self.themeComboBox) - FirstTimeWizard.setPage(FirstTimePage.Defaults, self.defaultsPage) + self.defaults_page = QtGui.QWizardPage() + self.defaults_page.setObjectName(u'defaults_page') + self.defaults_layout = QtGui.QFormLayout(self.defaults_page) + self.defaults_layout.setContentsMargins(50, 20, 50, 20) + self.defaults_layout.setObjectName(u'defaults_layout') + self.display_label = QtGui.QLabel(self.defaults_page) + self.display_label.setObjectName(u'display_label') + self.display_combo_box = QtGui.QComboBox(self.defaults_page) + self.display_combo_box.setEditable(False) + self.display_combo_box.setInsertPolicy(QtGui.QComboBox.NoInsert) + self.display_combo_box.setObjectName(u'display_combo_box') + self.defaults_layout.addRow(self.display_label, self.display_combo_box) + self.theme_label = QtGui.QLabel(self.defaults_page) + self.theme_label.setObjectName(u'theme_label') + self.theme_combo_box = QtGui.QComboBox(self.defaults_page) + self.theme_combo_box.setEditable(False) + self.theme_combo_box.setInsertPolicy(QtGui.QComboBox.NoInsert) + self.theme_combo_box.setSizeAdjustPolicy(QtGui.QComboBox.AdjustToContents) + self.theme_combo_box.setObjectName(u'theme_combo_box') + self.defaults_layout.addRow(self.theme_label, self.theme_combo_box) + first_time_wizard.setPage(FirstTimePage.Defaults, self.defaults_page) # Progress page - self.progressPage = QtGui.QWizardPage() - self.progressPage.setObjectName(u'progressPage') - self.progressLayout = QtGui.QVBoxLayout(self.progressPage) - self.progressLayout.setMargin(48) - self.progressLayout.setObjectName(u'progressLayout') - self.progressLabel = QtGui.QLabel(self.progressPage) - self.progressLabel.setObjectName(u'progressLabel') - self.progressLayout.addWidget(self.progressLabel) - self.progressBar = QtGui.QProgressBar(self.progressPage) - self.progressBar.setObjectName(u'progressBar') - self.progressLayout.addWidget(self.progressBar) - FirstTimeWizard.setPage(FirstTimePage.Progress, self.progressPage) - self.retranslateUi(FirstTimeWizard) + self.progress_page = QtGui.QWizardPage() + self.progress_page.setObjectName(u'progress_page') + self.progress_layout = QtGui.QVBoxLayout(self.progress_page) + self.progress_layout.setMargin(48) + self.progress_layout.setObjectName(u'progress_layout') + self.progress_label = QtGui.QLabel(self.progress_page) + self.progress_label.setObjectName(u'progress_label') + self.progress_layout.addWidget(self.progress_label) + self.progress_bar = QtGui.QProgressBar(self.progress_page) + self.progress_bar.setObjectName(u'progress_bar') + self.progress_layout.addWidget(self.progress_bar) + first_time_wizard.setPage(FirstTimePage.Progress, self.progress_page) + self.retranslateUi(first_time_wizard) - def retranslateUi(self, FirstTimeWizard): + def retranslateUi(self, first_time_wizard): """ Translate the UI on the fly """ - FirstTimeWizard.setWindowTitle(translate('OpenLP.FirstTimeWizard', 'First Time Wizard')) + first_time_wizard.setWindowTitle(translate('OpenLP.FirstTimeWizard', 'First Time Wizard')) self.title_label.setText(u'%s' % translate('OpenLP.FirstTimeWizard', 'Welcome to the First Time Wizard')) self.information_label.setText(translate('OpenLP.FirstTimeWizard', 'This wizard will help you to configure OpenLP for initial use. Click the next button below to start.')) - self.pluginPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Activate required Plugins')) - self.pluginPage.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select the Plugins you wish to use. ')) - self.songsCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Songs')) - self.customCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Custom Slides')) - self.bibleCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Bible')) - self.imageCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Images')) + self.plugin_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Activate required Plugins')) + self.plugin_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select the Plugins you wish to use. ')) + self.songs_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Songs')) + self.custom_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Custom Slides')) + self.bible_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Bible')) + self.image_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Images')) # TODO Presentation plugin is not yet working on Mac OS X. # For now just ignore it. if sys.platform != 'darwin': - self.presentationCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Presentations')) - self.mediaCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Media (Audio and Video)')) - self.remoteCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Allow remote access')) - self.songUsageCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Monitor Song Usage')) - self.alertCheckBox.setText(translate('OpenLP.FirstTimeWizard', 'Allow Alerts')) - self.noInternetPage.setTitle(translate('OpenLP.FirstTimeWizard', 'No Internet Connection')) - self.noInternetPage.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Unable to detect an Internet connection.')) - self.noInternetText = translate('OpenLP.FirstTimeWizard', - 'No Internet connection was found. The First Time Wizard needs an ' - 'Internet connection in order to be able to download sample ' - 'songs, Bibles and themes. Click the Finish button now to start ' - 'OpenLP with initial settings and no sample data.\n\nTo re-run the ' - 'First Time Wizard and import this sample data at a later time, ' - 'check your Internet connection and re-run this wizard by ' - 'selecting "Tools/Re-run First Time Wizard" from OpenLP.') + self.presentation_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Presentations')) + self.media_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Media (Audio and Video)')) + self.remote_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Allow remote access')) + self.song_usage_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Monitor Song Usage')) + self.alert_check_box.setText(translate('OpenLP.FirstTimeWizard', 'Allow Alerts')) + self.no_internet_page.setTitle(translate('OpenLP.FirstTimeWizard', 'No Internet Connection')) + self.no_internet_page.setSubTitle( + translate('OpenLP.FirstTimeWizard', 'Unable to detect an Internet connection.')) + self.no_internet_text = translate('OpenLP.FirstTimeWizard', + 'No Internet connection was found. The First Time Wizard needs an Internet connection in order to be able ' + 'to download sample songs, Bibles and themes. Click the Finish button now to start OpenLP with initial ' + 'settings and no sample data.\n\nTo re-run the First Time Wizard and import this sample data at a later ' + 'time, check your Internet connection and re-run this wizard by selecting "Tools/Re-run First Time Wizard" ' + 'from OpenLP.') self.cancelWizardText = translate('OpenLP.FirstTimeWizard', '\n\nTo cancel the First Time Wizard completely (and not start OpenLP), click the Cancel button now.') - self.songsPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Songs')) - self.songsPage.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download public domain songs.')) - self.biblesPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Bibles')) - self.biblesPage.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download free Bibles.')) - self.themesPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Themes')) - self.themesPage.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download sample themes.')) - self.defaultsPage.setTitle(translate('OpenLP.FirstTimeWizard', 'Default Settings')) - self.defaultsPage.setSubTitle(translate('OpenLP.FirstTimeWizard', + self.songs_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Songs')) + self.songs_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download public domain songs.')) + self.bibles_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Bibles')) + self.bibles_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download free Bibles.')) + self.themes_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Sample Themes')) + self.themes_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Select and download sample themes.')) + self.defaults_page.setTitle(translate('OpenLP.FirstTimeWizard', 'Default Settings')) + self.defaults_page.setSubTitle(translate('OpenLP.FirstTimeWizard', 'Set up default settings to be used by OpenLP.')) - self.displayLabel.setText(translate('OpenLP.FirstTimeWizard', 'Default output display:')) - self.themeLabel.setText(translate('OpenLP.FirstTimeWizard', 'Select default theme:')) - self.progressLabel.setText(translate('OpenLP.FirstTimeWizard', 'Starting configuration process...')) - FirstTimeWizard.setButtonText(QtGui.QWizard.CustomButton1, translate('OpenLP.FirstTimeWizard', 'Finish')) + self.display_label.setText(translate('OpenLP.FirstTimeWizard', 'Default output display:')) + self.theme_label.setText(translate('OpenLP.FirstTimeWizard', 'Select default theme:')) + self.progress_label.setText(translate('OpenLP.FirstTimeWizard', 'Starting configuration process...')) + first_time_wizard.setButtonText(QtGui.QWizard.CustomButton1, translate('OpenLP.FirstTimeWizard', 'Finish')) From ad8e28fbe93b18036e6c9f04eaf291643b65f8a1 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 11 May 2013 20:11:52 +0200 Subject: [PATCH 14/23] renames --- openlp/core/ui/firsttimeform.py | 64 ++++++++++++++++----------------- 1 file changed, 32 insertions(+), 32 deletions(-) diff --git a/openlp/core/ui/firsttimeform.py b/openlp/core/ui/firsttimeform.py index 7abec725e..b66a38445 100644 --- a/openlp/core/ui/firsttimeform.py +++ b/openlp/core/ui/firsttimeform.py @@ -98,8 +98,8 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.was_download_cancelled = False self.theme_screenshot_thread = None self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading %s...') - self.cancel_button.clicked.connect(self.onCancelButtonClicked) - self.no_internet_finish_button.clicked.connect(self.onNoInternetFinishButtonClicked) + self.cancel_button.clicked.connect(self.on_cancel_button_clicked) + self.no_internet_finish_button.clicked.connect(self.on_no_internet_finish_button_clicked) self.currentIdChanged.connect(self.on_current_id_changed) Registry().register_function(u'config_screen_changed', self.update_screen_list_combo) @@ -170,7 +170,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): time.sleep(0.1) self.application.process_events() # Build the screenshot icons, as this can not be done in the thread. - self._buildThemeScreenshots() + self._build_theme_screenshots() self.application.set_normal_cursor() return FirstTimePage.Defaults else: @@ -219,7 +219,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): # Try to give the wizard a chance to redraw itself time.sleep(0.2) self._pre_wizard() - self._performWizard() + self._perform_wizard() self._post_wizard() self.application.set_normal_cursor() @@ -232,7 +232,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.display_combo_box.addItems(self.screens.get_screen_list()) self.display_combo_box.setCurrentIndex(self.display_combo_box.count() - 1) - def onCancelButtonClicked(self): + def on_cancel_button_clicked(self): """ Process the triggering of the cancel button. """ @@ -246,39 +246,39 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): time.sleep(0.1) self.application.set_normal_cursor() - def onNoInternetFinishButtonClicked(self): + def on_no_internet_finish_button_clicked(self): """ Process the triggering of the "Finish" button on the No Internet page. """ self.application.set_busy_cursor() - self._performWizard() + self._perform_wizard() self.application.set_normal_cursor() Settings().setValue(u'core/has run wizard', True) self.close() - def urlGetFile(self, url, fpath): + def url_get_file(self, url, f_path): """" - Download a file given a URL. The file is retrieved in chunks, giving - the ability to cancel the download at any point. + Download a file given a URL. The file is retrieved in chunks, giving the ability to cancel the download at any + point. """ block_count = 0 block_size = 4096 - urlfile = urllib2.urlopen(url) - filename = open(fpath, "wb") + url_file = urllib2.urlopen(url) + filename = open(f_path, "wb") # Download until finished or canceled. while not self.was_download_cancelled: - data = urlfile.read(block_size) + data = url_file.read(block_size) if not data: break filename.write(data) block_count += 1 - self._downloadProgress(block_count, block_size) + self._download_progress(block_count, block_size) filename.close() # Delete file if cancelled, it may be a partial file. if self.was_download_cancelled: - os.remove(fpath) + os.remove(f_path) - def _buildThemeScreenshots(self): + def _build_theme_screenshots(self): """ This method builds the theme screenshots' icons for all items in the ``self.themes_list_widget``. @@ -293,7 +293,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): if item.data(QtCore.Qt.UserRole) == filename: break item.setIcon(build_icon(os.path.join(unicode(gettempdir(), - get_filesystem_encoding()), u'openlp', screenshot))) + get_filesystem_encoding()), u'openlp', screenshot))) def _getFileSize(self, url): """ @@ -306,7 +306,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): meta = site.info() return int(meta.getheaders("Content-Length")[0]) - def _downloadProgress(self, count, block_size): + def _download_progress(self, count, block_size): """ Calculate and display the download progress. """ @@ -406,24 +406,24 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self.next_button.setVisible(False) self.application.process_events() - def _performWizard(self): + def _perform_wizard(self): """ Run the tasks in the wizard. """ # Set plugin states self._increment_progress_bar(translate('OpenLP.FirstTimeWizard', 'Enabling selected plugins...')) - self._setPluginStatus(self.songs_check_box, u'songs/status') - self._setPluginStatus(self.bible_check_box, u'bibles/status') + self._set_plugin_status(self.songs_check_box, u'songs/status') + self._set_plugin_status(self.bible_check_box, u'bibles/status') # TODO Presentation plugin is not yet working on Mac OS X. # For now just ignore it. if sys.platform != 'darwin': - self._setPluginStatus(self.presentation_check_box, u'presentations/status') - self._setPluginStatus(self.image_check_box, u'images/status') - self._setPluginStatus(self.media_check_box, u'media/status') - self._setPluginStatus(self.remote_check_box, u'remotes/status') - self._setPluginStatus(self.custom_check_box, u'custom/status') - self._setPluginStatus(self.song_usage_check_box, u'songusage/status') - self._setPluginStatus(self.alert_check_box, u'alerts/status') + self._set_plugin_status(self.presentation_check_box, u'presentations/status') + self._set_plugin_status(self.image_check_box, u'images/status') + self._set_plugin_status(self.media_check_box, u'media/status') + self._set_plugin_status(self.remote_check_box, u'remotes/status') + self._set_plugin_status(self.custom_check_box, u'custom/status') + self._set_plugin_status(self.song_usage_check_box, u'songusage/status') + self._set_plugin_status(self.alert_check_box, u'alerts/status') if self.web_access: # Build directories for downloads songs_destination = os.path.join( @@ -438,7 +438,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): self._increment_progress_bar(self.downloading % filename, 0) self.previous_size = 0 destination = os.path.join(songs_destination, unicode(filename)) - self.urlGetFile(u'%s%s' % (self.web, filename), destination) + self.url_get_file(u'%s%s' % (self.web, filename), destination) # Download Bibles bibles_iterator = QtGui.QTreeWidgetItemIterator( self.bibles_tree_widget) @@ -448,7 +448,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): bible = item.data(0, QtCore.Qt.UserRole) self._increment_progress_bar(self.downloading % bible, 0) self.previous_size = 0 - self.urlGetFile(u'%s%s' % (self.web, bible), os.path.join(bibles_destination, bible)) + self.url_get_file(u'%s%s' % (self.web, bible), os.path.join(bibles_destination, bible)) bibles_iterator += 1 # Download themes for i in xrange(self.themes_list_widget.count()): @@ -457,7 +457,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): theme = item.data(QtCore.Qt.UserRole) self._increment_progress_bar(self.downloading % theme, 0) self.previous_size = 0 - self.urlGetFile(u'%s%s' % (self.web, theme), os.path.join(themes_destination, theme)) + self.url_get_file(u'%s%s' % (self.web, theme), os.path.join(themes_destination, theme)) # Set Default Display if self.display_combo_box.currentIndex() != -1: Settings().setValue(u'core/monitor', self.display_combo_box.currentIndex()) @@ -466,7 +466,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard): if self.theme_combo_box.currentIndex() != -1: Settings().setValue(u'themes/global theme', self.theme_combo_box.currentText()) - def _setPluginStatus(self, field, tag): + def _set_plugin_status(self, field, tag): """ Set the status of a plugin. """ From 20c200cf0733be8a96b7a10e744ef4b20405c285 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 12 May 2013 11:38:25 +0200 Subject: [PATCH 15/23] added test --- .../openlp_core_ui/test_mainwindow.py | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index 837919d85..a484133f6 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -25,7 +25,8 @@ class TestMainWindow(TestCase): self.app.args =[] Registry().register(u'application', self.app) # Mock classes and methods used by mainwindow. - with patch(u'openlp.core.ui.mainwindow.ImageManager') as mocked_image_manager, \ + with patch(u'openlp.core.ui.mainwindow.SettingsForm') as mocked_settings_form, \ + patch(u'openlp.core.ui.mainwindow.ImageManager') as mocked_image_manager, \ patch(u'openlp.core.ui.mainwindow.SlideController') as mocked_slide_controller, \ patch(u'openlp.core.ui.mainwindow.OpenLPDockWidget') as mocked_dock_widget, \ patch(u'openlp.core.ui.mainwindow.QtGui.QToolBox') as mocked_q_tool_box_class, \ @@ -42,6 +43,21 @@ class TestMainWindow(TestCase): del self.main_window del self.app + def restore_current_media_manager_item_test(self): + """ + Regression test for bug #1152509. + """ + # GIVEN: Mocked Settings().value method. + with patch(u'openlp.core.ui.mainwindow.Settings.value') as mocked_value: + # save current plugin: True; current media plugin: 2 + mocked_value.side_effect = [True, 2] + + # WHEN: Call the restore method. + Registry().execute(u'bootstrap_post_set_up') + + # THEN: The current widget should have been set. + self.main_window.media_tool_box.setCurrentIndex.assert_called_with(2) + def on_search_shortcut_triggered_test(self): """ Test if the search edit has focus after CTRL+F has been pressed. From 1290b85abebf1f13813732e7e43767339cb699bf Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 1 Jun 2013 16:49:47 +0200 Subject: [PATCH 16/23] removed test --- .../openlp_core_ui/test_mainwindow.py | 17 +---------------- 1 file changed, 1 insertion(+), 16 deletions(-) diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index a484133f6..a3125f593 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -4,7 +4,7 @@ Package to test the openlp.core.ui.mainwindow package. from unittest import TestCase from mock import MagicMock, patch -from PyQt4 import QtCore, QtGui, QtTest +from PyQt4 import QtGui from openlp.core.lib import Registry from openlp.core.ui.mainwindow import MainWindow @@ -58,18 +58,3 @@ class TestMainWindow(TestCase): # THEN: The current widget should have been set. self.main_window.media_tool_box.setCurrentIndex.assert_called_with(2) - def on_search_shortcut_triggered_test(self): - """ - Test if the search edit has focus after CTRL+F has been pressed. - """ - # GIVEN: Mocked widget. - mocked_widget = MagicMock() - self.main_window.media_tool_box.currentWidget.return_value = mocked_widget - self.main_window.show() - - # WHEN: Press the shortcut. - QtTest.QTest.keyPress(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier, 100) - QtTest.QTest.keyRelease(self.main_window, QtCore.Qt.Key_F, QtCore.Qt.ControlModifier) - - # THEN: The on_focus method should have been called. - mocked_widget.on_focus.assert_called_with() From 8c3c43a11dab978af513912c88db687484e9c09b Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 1 Jun 2013 20:16:34 +0200 Subject: [PATCH 17/23] changed shortcut category --- openlp/core/ui/aboutdialog.py | 4 ++-- openlp/core/ui/mainwindow.py | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/openlp/core/ui/aboutdialog.py b/openlp/core/ui/aboutdialog.py index 82f0a6683..f17d70bac 100644 --- a/openlp/core/ui/aboutdialog.py +++ b/openlp/core/ui/aboutdialog.py @@ -291,7 +291,7 @@ class Ui_AboutDialog(object): 'but WITHOUT ANY WARRANTY; without even the implied warranty of ' 'MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See below ' 'for more details.') - gpltext = ('GNU GENERAL PUBLIC LICENSE\n' + gpl_text = ('GNU GENERAL PUBLIC LICENSE\n' 'Version 2, June 1991\n' '\n' 'Copyright (C) 1989, 1991 Free Software Foundation, Inc., 51 ' @@ -662,7 +662,7 @@ class Ui_AboutDialog(object): 'linking proprietary applications with the library. If this is ' 'what you want to do, use the GNU Lesser General Public License ' 'instead of this License.') - self.license_text_edit.setPlainText(u'%s\n\n%s\n\n%s\n\n\n%s' % (copyright_note, licence, disclaimer, gpltext)) + self.license_text_edit.setPlainText(u'%s\n\n%s\n\n%s\n\n\n%s' % (copyright_note, licence, disclaimer, gpl_text)) self.about_notebook.setTabText(self.about_notebook.indexOf(self.license_tab), translate('OpenLP.AboutForm', 'License')) self.volunteer_button.setText(translate('OpenLP.AboutForm', 'Volunteer')) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index debefe084..6adc79ef8 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -312,7 +312,7 @@ class Ui_MainWindow(object): self.web_site_item = create_action(main_window, u'webSiteItem', can_shortcuts=True, category=UiStrings().Help) # Shortcuts not connected to buttons or menu entires. self.search_shortcut_action = create_action(main_window, - u'searchShortcut', can_shortcuts=True, category=UiStrings().File, + u'searchShortcut', can_shortcuts=True, category=translate('OpenLP.MainWindow', 'General'), triggers=self.on_search_shortcut_triggered) add_actions(self.file_import_menu, (self.settings_import_item, None, self.import_theme_item, self.import_language_item)) From 6ddbdc196d53efe49ecb366ee3e5a640386ddde0 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 1 Jun 2013 20:19:53 +0200 Subject: [PATCH 18/23] fixed spelling --- tests/interfaces/openlp_core_ui/test_mainwindow.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/interfaces/openlp_core_ui/test_mainwindow.py b/tests/interfaces/openlp_core_ui/test_mainwindow.py index a3125f593..363b2e529 100644 --- a/tests/interfaces/openlp_core_ui/test_mainwindow.py +++ b/tests/interfaces/openlp_core_ui/test_mainwindow.py @@ -31,7 +31,7 @@ class TestMainWindow(TestCase): patch(u'openlp.core.ui.mainwindow.OpenLPDockWidget') as mocked_dock_widget, \ patch(u'openlp.core.ui.mainwindow.QtGui.QToolBox') as mocked_q_tool_box_class, \ patch(u'openlp.core.ui.mainwindow.QtGui.QMainWindow.addDockWidget') as mocked_add_dock_method, \ - patch(u'openlp.core.ui.mainwindow.ServiceManager') as mocked_slervice_manager, \ + patch(u'openlp.core.ui.mainwindow.ServiceManager') as mocked_service_manager, \ patch(u'openlp.core.ui.mainwindow.ThemeManager') as mocked_theme_manager, \ patch(u'openlp.core.ui.mainwindow.Renderer') as mocked_renderer: self.main_window = MainWindow() From 1f80f6c83036d95486afa8059068d15b61808b26 Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sat, 1 Jun 2013 20:35:00 +0200 Subject: [PATCH 19/23] renames --- openlp/core/ui/mainwindow.py | 30 +++++++++++++++--------------- openlp/core/ui/slidecontroller.py | 6 +++--- 2 files changed, 18 insertions(+), 18 deletions(-) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index 6adc79ef8..ef7181ee1 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -100,10 +100,10 @@ class Ui_MainWindow(object): self.main_contentLayout.setMargin(0) self.main_contentLayout.setObjectName(u'main_contentLayout') main_window.setCentralWidget(self.main_content) - self.controlSplitter = QtGui.QSplitter(self.main_content) - self.controlSplitter.setOrientation(QtCore.Qt.Horizontal) - self.controlSplitter.setObjectName(u'controlSplitter') - self.main_contentLayout.addWidget(self.controlSplitter) + self.control_splitter = QtGui.QSplitter(self.main_content) + self.control_splitter.setOrientation(QtCore.Qt.Horizontal) + self.control_splitter.setObjectName(u'control_splitter') + self.main_contentLayout.addWidget(self.control_splitter) # Create slide controllers self.preview_controller = SlideController(self) self.live_controller = SlideController(self, True) @@ -113,9 +113,9 @@ class Ui_MainWindow(object): panel_locked = Settings().value(u'user interface/lock panel') self.live_controller.panel.setVisible(live_visible) # Create menu - self.menuBar = QtGui.QMenuBar(main_window) - self.menuBar.setObjectName(u'menuBar') - self.file_menu = QtGui.QMenu(self.menuBar) + self.menu_bar = QtGui.QMenuBar(main_window) + self.menu_bar.setObjectName(u'menu_bar') + self.file_menu = QtGui.QMenu(self.menu_bar) self.file_menu.setObjectName(u'fileMenu') self.recent_files_menu = QtGui.QMenu(self.file_menu) self.recent_files_menu.setObjectName(u'recentFilesMenu') @@ -124,22 +124,22 @@ class Ui_MainWindow(object): self.file_export_menu = QtGui.QMenu(self.file_menu) self.file_export_menu.setObjectName(u'file_export_menu') # View Menu - self.view_menu = QtGui.QMenu(self.menuBar) + self.view_menu = QtGui.QMenu(self.menu_bar) self.view_menu.setObjectName(u'viewMenu') self.view_modeMenu = QtGui.QMenu(self.view_menu) self.view_modeMenu.setObjectName(u'viewModeMenu') # Tools Menu - self.tools_menu = QtGui.QMenu(self.menuBar) + self.tools_menu = QtGui.QMenu(self.menu_bar) self.tools_menu.setObjectName(u'tools_menu') # Settings Menu - self.settings_menu = QtGui.QMenu(self.menuBar) + self.settings_menu = QtGui.QMenu(self.menu_bar) self.settings_menu.setObjectName(u'settingsMenu') self.settings_language_menu = QtGui.QMenu(self.settings_menu) self.settings_language_menu.setObjectName(u'settingsLanguageMenu') # Help Menu - self.help_menu = QtGui.QMenu(self.menuBar) + self.help_menu = QtGui.QMenu(self.menu_bar) self.help_menu.setObjectName(u'helpMenu') - main_window.setMenuBar(self.menuBar) + main_window.setMenuBar(self.menu_bar) self.status_bar = QtGui.QStatusBar(main_window) self.status_bar.setObjectName(u'status_bar') main_window.setStatusBar(self.status_bar) @@ -346,7 +346,7 @@ class Ui_MainWindow(object): self.about_item)) else: add_actions(self.help_menu, (self.on_line_help_item, None, self.web_site_item, self.about_item)) - add_actions(self.menuBar, (self.file_menu.menuAction(), self.view_menu.menuAction(), + add_actions(self.menu_bar, (self.file_menu.menuAction(), self.view_menu.menuAction(), self.tools_menu.menuAction(), self.settings_menu.menuAction(), self.help_menu.menuAction())) add_actions(self, [self.search_shortcut_action]) # Initialise the translation @@ -1189,7 +1189,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): self.restoreState(settings.value(u'main window state')) self.live_controller.splitter.restoreState(settings.value(u'live splitter geometry')) self.preview_controller.splitter.restoreState(settings.value(u'preview splitter geometry')) - self.controlSplitter.restoreState(settings.value(u'main window splitter geometry')) + self.control_splitter.restoreState(settings.value(u'main window splitter geometry')) settings.endGroup() def save_settings(self): @@ -1210,7 +1210,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): settings.setValue(u'main window geometry', self.saveGeometry()) settings.setValue(u'live splitter geometry', self.live_controller.splitter.saveState()) settings.setValue(u'preview splitter geometry', self.preview_controller.splitter.saveState()) - settings.setValue(u'main window splitter geometry', self.controlSplitter.saveState()) + settings.setValue(u'main window splitter geometry', self.control_splitter.saveState()) settings.endGroup() def update_recent_files_menu(self): diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 86b114e1e..bfaf3b2a6 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -119,7 +119,7 @@ class SlideController(DisplayController): self.service_item = None self.slide_limits = None self.update_slide_limits() - self.panel = QtGui.QWidget(parent.controlSplitter) + self.panel = QtGui.QWidget(parent.control_splitter) self.slideList = {} # Layout for holding panel self.panel_layout = QtGui.QVBoxLayout(self.panel) @@ -582,7 +582,7 @@ class SlideController(DisplayController): self.preview_list_widget.resizeRowsToContents() else: # Sort out image heights. - width = self.main_window.controlSplitter.sizes()[self.split] + width = self.main_window.control_splitter.sizes()[self.split] for framenumber in range(len(self.service_item.get_frames())): self.preview_list_widget.setRowHeight(framenumber, width / self.ratio) self.onControllerSizeChanged(self.controller.width()) @@ -753,7 +753,7 @@ class SlideController(DisplayController): self._resetBlank() Registry().execute(u'%s_start' % service_item.name.lower(), [service_item, self.is_live, self.hide_mode(), slideno]) self.slideList = {} - width = self.main_window.controlSplitter.sizes()[self.split] + width = self.main_window.control_splitter.sizes()[self.split] self.preview_list_widget.clear() self.preview_list_widget.setRowCount(0) self.preview_list_widget.setColumnWidth(0, width) From 34099c5df7ab65dfd596b1d032c6134c7d8d3e9a Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Thu, 6 Jun 2013 18:07:05 +0200 Subject: [PATCH 20/23] if the media doc is invisible, make it visible --- openlp/core/ui/mainwindow.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/openlp/core/ui/mainwindow.py b/openlp/core/ui/mainwindow.py index ef7181ee1..1f8e3340e 100644 --- a/openlp/core/ui/mainwindow.py +++ b/openlp/core/ui/mainwindow.py @@ -560,6 +560,9 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow): """ Called when the search shotcut has been pressed. """ + # Make sure the media_dock is visible. + if not self.media_manager_dock.isVisible(): + self.media_manager_dock.setVisible(True) widget = self.media_tool_box.currentWidget() if widget: widget.on_focus() From 39d691d2ebf997c1c741e7566461f3eee22b58eb Mon Sep 17 00:00:00 2001 From: Andreas Preikschat Date: Sun, 16 Jun 2013 18:46:44 +0200 Subject: [PATCH 21/23] fix --- openlp/core/ui/slidecontroller.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 44781d4c4..0a49110a6 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -694,9 +694,8 @@ class SlideController(DisplayController): def addServiceManagerItem(self, item, slideno): """ - Method to install the service item into the controller and - request the correct toolbar for the plugin. - Called by ServiceManager + Method to install the service item into the controller and request the correct toolbar for the plugin. Called by + :class:`~openlp.core.ui.ServiceManager` """ log.debug(u'addServiceManagerItem live = %s' % self.is_live) # If no valid slide number is specified we take the first one, but we @@ -721,8 +720,7 @@ class SlideController(DisplayController): def _process_item(self, service_item, slideno): """ - Loads a ServiceItem into the system from ServiceManager - Display the slide number passed + Loads a ServiceItem into the system from ServiceManager. Display the slide number passed. """ log.debug(u'processManagerItem live = %s' % self.is_live) self.on_stop_loop() @@ -758,7 +756,7 @@ class SlideController(DisplayController): self.setAudioItemsVisibility(True) row = 0 text = [] - width = self.main_window.controlSplitter.sizes()[self.split] + width = self.main_window.control_splitter.sizes()[self.split] for framenumber, frame in enumerate(self.service_item.get_frames()): slideHeight = 0 if self.service_item.is_text(): From 538e885cfb3e02d04e2ff2c18fc1f8099bcbf5fc Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 3 Jul 2013 17:34:02 +0100 Subject: [PATCH 22/23] Fix broken test --- tests/functional/openlp_core_lib/test_serviceitem.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/functional/openlp_core_lib/test_serviceitem.py b/tests/functional/openlp_core_lib/test_serviceitem.py index 4e777b953..f970eba22 100644 --- a/tests/functional/openlp_core_lib/test_serviceitem.py +++ b/tests/functional/openlp_core_lib/test_serviceitem.py @@ -272,13 +272,13 @@ class TestServiceItem(TestCase): service_item.add_icon = MagicMock() # WHEN: adding an media from a saved Service and mocked exists - line = self.convert_file_service_item(u'migrate_video_20_22.osd') + line = read_service_from_file(u'migrate_video_20_22.osd') with patch('os.path.exists'): - service_item.set_from_service(line, TEST_PATH) + service_item.set_from_service(line[0], TEST_RESOURCES_PATH) # THEN: We should get back a converted service item assert service_item.is_valid is True, u'The new service item should be valid' - assert service_item.processor is None, u'The Processor should have been set' - assert service_item.title is None, u'The title should be set to a value' + assert service_item.processor is not None, u'The Processor should have been set' + assert service_item.title is not None, u'The title should be set to a value' assert service_item.is_capable(ItemCapabilities.HasDetailedTitleDisplay) is False, \ u'The Capability should have been removed' From ab3fd38551044f4530eafb2dda88b54dbca23522 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 3 Jul 2013 17:34:40 +0100 Subject: [PATCH 23/23] Fix broken test --- tests/functional/openlp_core_lib/test_serviceitem.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/functional/openlp_core_lib/test_serviceitem.py b/tests/functional/openlp_core_lib/test_serviceitem.py index f970eba22..fdeb081b3 100644 --- a/tests/functional/openlp_core_lib/test_serviceitem.py +++ b/tests/functional/openlp_core_lib/test_serviceitem.py @@ -278,7 +278,7 @@ class TestServiceItem(TestCase): # THEN: We should get back a converted service item assert service_item.is_valid is True, u'The new service item should be valid' - assert service_item.processor is not None, u'The Processor should have been set' + assert service_item.processor == u'VLC', u'The Processor should have been set' assert service_item.title is not None, u'The title should be set to a value' assert service_item.is_capable(ItemCapabilities.HasDetailedTitleDisplay) is False, \ u'The Capability should have been removed'