+ try:
+ model, itr = self._recentviewselection.get_selected()
+ if not itr:
+ return
+
+ number = self._recentmodel.get_value(itr, self.NUMBER_IDX)
+ number = make_ugly(number)
+ contactPhoneNumbers = [("Phone", number)]
+ description = self._recentmodel.get_value(itr, self.FROM_IDX)
+
+ action, phoneNumber, message = self._phoneTypeSelector.run(
+ contactPhoneNumbers,
+ messages = (description, ),
+ parent = self._window,
+ )
+ if action == PhoneTypeSelector.ACTION_CANCEL:
+ return
+ assert phoneNumber, "A lack of phone number exists"
+
+ self.number_selected(action, phoneNumber, message)
+ self._recentviewselection.unselect_all()
+ except Exception, e:
+ self._errorDisplay.push_exception()
+
+
+class MessagesView(object):
+
+ NUMBER_IDX = 0
+ DATE_IDX = 1
+ HEADER_IDX = 2
+ MESSAGE_IDX = 3
+ MESSAGES_IDX = 4
+
+ def __init__(self, widgetTree, backend, errorDisplay):
+ self._errorDisplay = errorDisplay
+ self._backend = backend
+
+ self._isPopulated = False
+ self._messagemodel = gtk.ListStore(
+ gobject.TYPE_STRING, # number
+ gobject.TYPE_STRING, # date
+ gobject.TYPE_STRING, # header
+ gobject.TYPE_STRING, # message
+ object, # messages
+ )
+ self._messageview = widgetTree.get_widget("messages_view")
+ self._messageviewselection = None
+ self._onMessageviewRowActivatedId = 0
+
+ self._messageRenderer = gtk.CellRendererText()
+ self._messageRenderer.set_property("wrap-mode", pango.WRAP_WORD)
+ self._messageRenderer.set_property("wrap-width", 500)
+ self._messageColumn = gtk.TreeViewColumn("Messages")
+ self._messageColumn.pack_start(self._messageRenderer, expand=True)
+ self._messageColumn.add_attribute(self._messageRenderer, "markup", self.MESSAGE_IDX)
+ self._messageColumn.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED)
+
+ self._window = gtk_toolbox.find_parent_window(self._messageview)
+ self._phoneTypeSelector = PhoneTypeSelector(widgetTree, self._backend)
+
+ self._updateSink = gtk_toolbox.threaded_stage(
+ gtk_toolbox.comap(
+ self._idly_populate_messageview,
+ gtk_toolbox.null_sink(),
+ )
+ )
+
+ def enable(self):
+ assert self._backend.is_authed(), "Attempting to enable backend while not logged in"
+ self._messageview.set_model(self._messagemodel)
+ self._messageview.set_headers_visible(False)
+
+ self._messageview.append_column(self._messageColumn)
+ self._messageviewselection = self._messageview.get_selection()
+ self._messageviewselection.set_mode(gtk.SELECTION_SINGLE)
+
+ self._onMessageviewRowActivatedId = self._messageview.connect("row-activated", self._on_messageview_row_activated)
+
+ def disable(self):
+ self._messageview.disconnect(self._onMessageviewRowActivatedId)
+
+ self.clear()
+
+ self._messageview.remove_column(self._messageColumn)
+ self._messageview.set_model(None)
+
+ def number_selected(self, action, number, message):
+ """
+ @note Actual dial function is patched in later
+ """
+ raise NotImplementedError("Horrible unknown error has occurred")
+
+ def update(self, force = False):
+ if not force and self._isPopulated:
+ return False
+ self._updateSink.send(())
+ return True
+
+ def clear(self):
+ self._isPopulated = False
+ self._messagemodel.clear()
+
+ @staticmethod
+ def name():
+ return "Messages"
+
+ def load_settings(self, config, section):
+ pass
+
+ def save_settings(self, config, section):
+ """
+ @note Thread Agnostic
+ """
+ pass