+class MessagesView(object):
+
+ NUMBER_IDX = 0
+ DATE_IDX = 1
+ HEADER_IDX = 2
+ MESSAGE_IDX = 3
+
+ 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
+ )
+ self._messageview = widgetTree.get_widget("messages_view")
+ self._messageviewselection = None
+ self._onMessageviewRowActivatedId = 0
+
+ textrenderer = gtk.CellRendererText()
+ textrenderer.set_property("yalign", 0)
+ self._dateColumn = gtk.TreeViewColumn("Date")
+ self._dateColumn.pack_start(textrenderer, expand=True)
+ self._dateColumn.add_attribute(textrenderer, "markup", self.DATE_IDX)
+
+ textrenderer = gtk.CellRendererText()
+ textrenderer.set_property("yalign", 0)
+ self._headerColumn = gtk.TreeViewColumn("From")
+ self._headerColumn.pack_start(textrenderer, expand=True)
+ self._headerColumn.add_attribute(textrenderer, "markup", self.HEADER_IDX)
+
+ textrenderer = gtk.CellRendererText()
+ textrenderer.set_property("yalign", 0)
+ self._messageColumn = gtk.TreeViewColumn("Messages")
+ self._messageColumn.pack_start(textrenderer, expand=True)
+ self._messageColumn.add_attribute(textrenderer, "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)
+
+ def enable(self):
+ assert self._backend.is_authed()
+ self._messageview.set_model(self._messagemodel)
+
+ self._messageview.append_column(self._dateColumn)
+ self._messageview.append_column(self._headerColumn)
+ 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._dateColumn)
+ self._messageview.remove_column(self._headerColumn)
+ 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
+
+ def update(self, force = False):
+ if not force and self._isPopulated:
+ return
+ backgroundPopulate = threading.Thread(target=self._idly_populate_messageview)
+ backgroundPopulate.setDaemon(True)
+ backgroundPopulate.start()
+
+ 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
+
+ def _idly_populate_messageview(self):
+ self._isPopulated = True
+ self._messagemodel.clear()
+
+ try:
+ messageItems = self._backend.get_messages()
+ except RuntimeError, e:
+ self._errorDisplay.push_exception_with_lock(e)
+ self._isPopulated = False
+ messageItems = []
+
+ for header, number, relativeDate, message in messageItems:
+ number = make_ugly(number)
+ row = (number, relativeDate, header, message)
+ with gtk_toolbox.gtk_lock():
+ self._messagemodel.append(row)
+
+ return False
+
+ def _on_messageview_row_activated(self, treeview, path, view_column):
+ model, itr = self._messageviewselection.get_selected()
+ if not itr:
+ return
+
+ contactPhoneNumbers = [("Phone", self._messagemodel.get_value(itr, self.NUMBER_IDX))]
+ description = self._messagemodel.get_value(itr, self.MESSAGE_IDX)
+
+ action, phoneNumber, message = self._phoneTypeSelector.run(
+ contactPhoneNumbers,
+ message = description,
+ parent = self._window,
+ )
+ if action == PhoneTypeSelector.ACTION_CANCEL:
+ return
+ assert phoneNumber
+
+ self.number_selected(action, phoneNumber, message)
+ self._messageviewselection.unselect_all()
+
+