# -*- coding: utf-8 -*- # Copyright © 2005 Lateef Alabi-Oki # # This file is part of Scribes. # # Scribes is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # Scribes is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Scribes; if not, write to the Free Software # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA """ This module exposes a class that creates the findbar's next button. @author: Lateef Alabi-Oki @organization: The Scribes Project @copyright: Copyright © 2005 Lateef Alabi-Oki @license: GNU GPLv2 or Later @contact: mystilleef@gmail.com """ from gtk import Button class FindNextButton(Button): """ This class creates a button for the text editor's findbar. The button allows users to cycle through found matches. """ def __init__(self, findbar): """ Initialize the button object. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param findbar: The text editor's findbar. @type findbar: A ScribesFindBar object. """ Button.__init__(self) self.__init_attributes(findbar) self.__set_properties() self.__create_button() self.__signal_id_4 = self.connect("clicked", self.__nextbutton_clicked_cb) self.__signal_id_5 = self.__editor.connect("show-bar", self.__nextbutton_show_bar_cb) self.__signal_id_6 = self.__editor.connect("hide-bar", self.__nextbutton_hide_bar_cb) self.__signal_id_7 = self.__entry.connect("changed", self.__nextbutton_changed_cb) self.__signal_id_1 = self.__searchmanager.connect_after("next", self.__nextbutton_next_cb) self.__signal_id_2 = self.__searchmanager.connect_after("previous", self.__nextbutton_previous_cb) self.__signal_id_3 = self.__searchmanager.connect("matches-found", self.__nextbutton_matches_found_cb) self.__signal_id_8 = self.__word_check_button.connect("toggled", self.__nextbutton_toggled_cb) self.__signal_id_9 = self.__case_check_button.connect("toggled", self.__nextbutton_toggled_cb) self.__signal_id_10 = findbar.connect("delete", self.__destroy_cb) self.__block_search_replace_signals() def __init_attributes(self, findbar): """ Initialize the button's attributes. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param findbar: The text editor's findbar. @type findbar: A ScribesFindBar object. """ self.__editor = findbar.editor self.__entry = findbar.find_text_entry self.__searchmanager = findbar.search_replace_manager self.__signal_id_1 = self.__signal_id_8 = self.__signal_id_9 = None self.__signal_id_2 = self.__signal_id_6 = self.__signal_id_7 = None self.__signal_id_3 = self.__signal_id_4 = self.__signal_id_5 = None self.__signal_id_10 = None self.__word_check_button = findbar.match_word_button self.__case_check_button = findbar.match_case_button return def __set_properties(self): """ Set the button's default properties. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. """ self.set_property("sensitive", False) return def __create_button(self): """ Customize the button. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. """ from SCRIBES.utils import create_button from i18n import msg0004 from gtk import STOCK_GO_FORWARD hbox = create_button(STOCK_GO_FORWARD, msg0004) self.add(hbox) return def __nextbutton_clicked_cb(self, button): """ Handles callback when the "clicked" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param button: The next button for the findbar. @type button: A ScribesFindBar object. @return: True to propagate signals to parent widgets. @type: A Boolean Object. """ if self.__searchmanager.index == self.__searchmanager.number_of_matches - 1: pass else: self.__searchmanager.next() return True def __nextbutton_show_bar_cb(self, editor, bar): """ Handles callback when the "show-bar" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param editor: Reference to the text editor. @type editor: An Editor object. @param bar: The text editor's findbar. @type bar: A ScribesFindBar object. """ self.__unblock_search_replace_signals() if self.__entry.get_text(): self.set_property("sensitive", True) else: self.set_property("sensitive", False) return def __nextbutton_hide_bar_cb(self, editor, bar): """ Handles callback when the "hide-bar" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param editor: Reference to the text editor. @type editor: An Editor object. @param bar: The text editor's findbar. @type bar: A ScribesFindBar object. """ self.__block_search_replace_signals() return def __nextbutton_changed_cb(self, entry): """ Handles callback when the "changed" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param entry: The findbar's entry object. @type entry: A ScribesFindEntry object. @return: True to propagate signals to parent widgets. @type: A Boolean Object. """ if entry.get_text(): self.set_property("sensitive", True) else: self.set_property("sensitive", False) return True def __nextbutton_next_cb(self, searchmanager): """ Handles callback when the "next" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param searchmanager: The text editor's search processor @type searchmanager: A SearchProcessor object. """ if searchmanager.index == searchmanager.number_of_matches - 1: self.set_property("sensitive", False) return def __nextbutton_previous_cb(self, searchmanager): """ Handles callback when the "previous" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param searchmanager: The text editor's search processor @type searchmanager: A SearchProcessor object. """ if searchmanager.index < searchmanager.number_of_matches - 1: self.set_property("sensitive", True) return def __nextbutton_matches_found_cb(self, searchmanager): """ Handles callback when the "matches-found" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param searchmanager: The text editor's search processor @type searchmanager: A SearchProcessor object. """ self.set_property("sensitive", True) return def __nextbutton_toggled_cb(self, togglebutton): """ Handles callback when the "toggled" signal is emitted. @param self: Reference to the ScribesFindNextButton instance. @type self: A ScribesFindNextButton object. @param togglebutton: The check buttons on the findbar. @type togglebutton: A gtk.CheckButton object. @return: True to prevent propagation of signals to parent widgets. @type: A Boolean Object. """ return True def __block_search_replace_signals(self): self.__searchmanager.handler_block(self.__signal_id_1) self.__searchmanager.handler_block(self.__signal_id_2) self.__searchmanager.handler_block(self.__signal_id_3) return def __unblock_search_replace_signals(self): self.__searchmanager.handler_unblock(self.__signal_id_1) self.__searchmanager.handler_unblock(self.__signal_id_2) self.__searchmanager.handler_unblock(self.__signal_id_3) return def __destroy_cb(self, findbar): """ Handles callback when the "destroy" signal is emitted. @param self: Reference to the FindNextButton instance. @type self: A FindNextButton object. @param findbar: Reference to the FindBar instance. @type findbar: A FindBar object. """ from SCRIBES.utils import disconnect_signal, delete_attributes disconnect_signal(self.__signal_id_1, self.__searchmanager) disconnect_signal(self.__signal_id_2, self.__searchmanager) disconnect_signal(self.__signal_id_3, self.__searchmanager) disconnect_signal(self.__signal_id_4, self) disconnect_signal(self.__signal_id_5, self.__editor) disconnect_signal(self.__signal_id_6, self.__editor) disconnect_signal(self.__signal_id_7, self.__entry) disconnect_signal(self.__signal_id_8, self.__word_check_button) disconnect_signal(self.__signal_id_9, self.__case_check_button) disconnect_signal(self.__signal_id_10, findbar) self.destroy() delete_attributes(self) del self self = None return