Get rid of the contextual chat.
This commit is contained in:
parent
7af2ea5bbd
commit
3f4625f0a1
1
README
1
README
@ -22,5 +22,4 @@ F1 Activity zoom level
|
|||||||
F2 Home zoom level
|
F2 Home zoom level
|
||||||
F3 Friends zoom level
|
F3 Friends zoom level
|
||||||
F4 Mesh zoom level
|
F4 Mesh zoom level
|
||||||
F5 Show the people page
|
|
||||||
F6 Open a terminal activity
|
F6 Open a terminal activity
|
||||||
|
@ -5,7 +5,6 @@ bin_SCRIPTS = \
|
|||||||
sugar-activity \
|
sugar-activity \
|
||||||
sugar-activity-factory \
|
sugar-activity-factory \
|
||||||
sugar-console \
|
sugar-console \
|
||||||
sugar-people \
|
|
||||||
sugar-presence-service
|
sugar-presence-service
|
||||||
|
|
||||||
sugardir = $(pkgdatadir)/shell
|
sugardir = $(pkgdatadir)/shell
|
||||||
@ -16,8 +15,6 @@ sugar_PYTHON = \
|
|||||||
ConsoleWindow.py \
|
ConsoleWindow.py \
|
||||||
FirstTimeDialog.py \
|
FirstTimeDialog.py \
|
||||||
Owner.py \
|
Owner.py \
|
||||||
PeopleWindow.py \
|
|
||||||
PresenceView.py \
|
|
||||||
Shell.py
|
Shell.py
|
||||||
|
|
||||||
EXTRA_DIST = $(bin_SCRIPTS)
|
EXTRA_DIST = $(bin_SCRIPTS)
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
import gtk
|
|
||||||
|
|
||||||
from sugar.chat.ActivityChat import ActivityChat
|
|
||||||
from PresenceView import PresenceView
|
|
||||||
|
|
||||||
class PeopleWindow(gtk.Window):
|
|
||||||
def __init__(self, shell, activity):
|
|
||||||
gtk.Window.__init__(self)
|
|
||||||
|
|
||||||
self.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
|
|
||||||
self.set_default_size(620, 440)
|
|
||||||
self.connect("delete_event", lambda w, e: w.hide_on_delete())
|
|
||||||
|
|
||||||
hbox = gtk.HBox(False, 12)
|
|
||||||
hbox.set_border_width(12)
|
|
||||||
|
|
||||||
presence_view = PresenceView(shell, activity)
|
|
||||||
hbox.pack_start(presence_view, False)
|
|
||||||
presence_view.show()
|
|
||||||
|
|
||||||
self._chat = ActivityChat(activity)
|
|
||||||
hbox.pack_start(self._chat)
|
|
||||||
self._chat.show()
|
|
||||||
|
|
||||||
self.add(hbox)
|
|
||||||
hbox.show()
|
|
||||||
|
|
||||||
def share(self):
|
|
||||||
self._chat.share()
|
|
@ -1,149 +0,0 @@
|
|||||||
import gtk
|
|
||||||
import gobject
|
|
||||||
import dbus
|
|
||||||
|
|
||||||
from sugar.presence import PresenceService
|
|
||||||
from sugar.presence.Service import Service
|
|
||||||
from sugar.chat.BuddyChat import BuddyChat
|
|
||||||
|
|
||||||
from gettext import gettext as _
|
|
||||||
|
|
||||||
class PresenceView(gtk.VBox):
|
|
||||||
_MODEL_COL_NICK = 0
|
|
||||||
_MODEL_COL_ICON = 1
|
|
||||||
_MODEL_COL_BUDDY = 2
|
|
||||||
|
|
||||||
def __init__(self, shell, activity):
|
|
||||||
gtk.VBox.__init__(self, False, 6)
|
|
||||||
|
|
||||||
self._activity = activity
|
|
||||||
self._activity_ps = None
|
|
||||||
self._shell = shell
|
|
||||||
|
|
||||||
self._pservice = PresenceService.get_instance()
|
|
||||||
self._pservice.connect("activity-appeared", self._activity_appeared_cb)
|
|
||||||
|
|
||||||
self._setup_ui()
|
|
||||||
|
|
||||||
activity_ps = self._pservice.get_activity(activity.get_id())
|
|
||||||
if activity_ps:
|
|
||||||
self._set_activity_ps(activity_ps)
|
|
||||||
|
|
||||||
if activity:
|
|
||||||
if self._activity.get_shared():
|
|
||||||
self._share_button.set_sensitive(False)
|
|
||||||
else:
|
|
||||||
self._share_button.set_sensitive(True)
|
|
||||||
else:
|
|
||||||
self._share_button.set_sensitive(False)
|
|
||||||
|
|
||||||
def _set_activity_ps(self, activity_ps):
|
|
||||||
self._activity_ps = activity_ps
|
|
||||||
self._activity_ps.connect('buddy-joined', self._buddy_joined_cb)
|
|
||||||
self._activity_ps.connect('buddy-left', self._buddy_left_cb)
|
|
||||||
for buddy in activity_ps.get_joined_buddies():
|
|
||||||
self._add_buddy(buddy)
|
|
||||||
|
|
||||||
def _setup_ui(self):
|
|
||||||
self.set_size_request(120, -1)
|
|
||||||
|
|
||||||
label = gtk.Label(_("Who's around:"))
|
|
||||||
label.set_alignment(0.0, 0.5)
|
|
||||||
self.pack_start(label, False)
|
|
||||||
label.show()
|
|
||||||
|
|
||||||
self._buddy_store = gtk.ListStore(gobject.TYPE_STRING,
|
|
||||||
gtk.gdk.Pixbuf,
|
|
||||||
gobject.TYPE_PYOBJECT,
|
|
||||||
bool)
|
|
||||||
|
|
||||||
sw = gtk.ScrolledWindow()
|
|
||||||
sw.set_shadow_type(gtk.SHADOW_IN)
|
|
||||||
sw.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
|
|
||||||
|
|
||||||
self._buddy_list_view = gtk.TreeView(self._buddy_store)
|
|
||||||
self._buddy_list_view.set_headers_visible(False)
|
|
||||||
self._buddy_list_view.connect("cursor-changed", self._on_buddyList_buddy_selected)
|
|
||||||
self._buddy_list_view.connect("row-activated", self._on_buddyList_buddy_double_clicked)
|
|
||||||
|
|
||||||
sw.add(self._buddy_list_view)
|
|
||||||
self._buddy_list_view.show()
|
|
||||||
|
|
||||||
renderer = gtk.CellRendererPixbuf()
|
|
||||||
column = gtk.TreeViewColumn("", renderer, pixbuf=self._MODEL_COL_ICON)
|
|
||||||
column.set_resizable(False)
|
|
||||||
column.set_expand(False);
|
|
||||||
self._buddy_list_view.append_column(column)
|
|
||||||
|
|
||||||
renderer = gtk.CellRendererText()
|
|
||||||
column = gtk.TreeViewColumn("", renderer, text=self._MODEL_COL_NICK)
|
|
||||||
column.set_resizable(True)
|
|
||||||
column.set_sizing("GTK_TREE_VIEW_COLUMN_GROW_ONLY");
|
|
||||||
column.set_expand(True);
|
|
||||||
self._buddy_list_view.append_column(column)
|
|
||||||
|
|
||||||
self.pack_start(sw)
|
|
||||||
sw.show()
|
|
||||||
|
|
||||||
button_box = gtk.HButtonBox()
|
|
||||||
|
|
||||||
self._share_button = gtk.Button(_('Share'))
|
|
||||||
self._share_button.connect('clicked', self._share_button_clicked_cb)
|
|
||||||
button_box.pack_start(self._share_button)
|
|
||||||
self._share_button.show()
|
|
||||||
|
|
||||||
self.pack_start(button_box, False)
|
|
||||||
button_box.show()
|
|
||||||
|
|
||||||
def _share_button_clicked_cb(self, button):
|
|
||||||
self._activity.share()
|
|
||||||
self._share_button.set_sensitive(False)
|
|
||||||
|
|
||||||
def _on_buddyList_buddy_selected(self, view, *args):
|
|
||||||
(model, aniter) = view.get_selection().get_selected()
|
|
||||||
name = model.get(aniter, self._MODEL_COL_NICK)
|
|
||||||
|
|
||||||
def _on_buddyList_buddy_double_clicked(self, view, *args):
|
|
||||||
""" Select the chat for this buddy or group """
|
|
||||||
(model, aniter) = view.get_selection().get_selected()
|
|
||||||
chat = None
|
|
||||||
buddy = view.get_model().get_value(aniter, self._MODEL_COL_BUDDY)
|
|
||||||
if buddy:
|
|
||||||
self._shell.get_chat_controller().open_chat_activity(buddy)
|
|
||||||
|
|
||||||
def __buddy_icon_changed_cb(self, buddy):
|
|
||||||
it = self._get_iter_for_buddy(buddy)
|
|
||||||
self._buddy_store.set(it, self._MODEL_COL_ICON, buddy.get_icon_pixbuf())
|
|
||||||
|
|
||||||
def _activity_appeared_cb(self, pservice, activity):
|
|
||||||
if self._activity_ps:
|
|
||||||
return
|
|
||||||
if activity.get_id() == self._activity.get_id():
|
|
||||||
self._set_activity_ps(activity)
|
|
||||||
|
|
||||||
def _buddy_joined_cb(self, pservice, buddy):
|
|
||||||
self._add_buddy(buddy)
|
|
||||||
|
|
||||||
def _add_buddy(self, buddy):
|
|
||||||
if buddy.is_owner():
|
|
||||||
# Do not show ourself in the buddy list
|
|
||||||
return
|
|
||||||
|
|
||||||
aniter = self._buddy_store.append(None)
|
|
||||||
self._buddy_store.set(aniter,
|
|
||||||
self._MODEL_COL_NICK, buddy.get_name(),
|
|
||||||
self._MODEL_COL_BUDDY, buddy)
|
|
||||||
buddy.connect('icon-changed', self.__buddy_icon_changed_cb)
|
|
||||||
|
|
||||||
def _buddy_left_cb(self, pservice, buddy):
|
|
||||||
aniter = self._get_iter_for_buddy(buddy)
|
|
||||||
if aniter:
|
|
||||||
self._buddy_store.remove(aniter)
|
|
||||||
|
|
||||||
def _get_iter_for_buddy(self, buddy):
|
|
||||||
aniter = self._buddy_store.get_iter_first()
|
|
||||||
while aniter:
|
|
||||||
list_buddy = self._buddy_store.get_value(aniter, self._MODEL_COL_BUDDY)
|
|
||||||
if buddy == list_buddy:
|
|
||||||
return aniter
|
|
||||||
aniter = self._buddy_store.iter_next(aniter)
|
|
@ -5,5 +5,4 @@
|
|||||||
<Alt>n=next
|
<Alt>n=next
|
||||||
<Alt>p=prev
|
<Alt>p=prev
|
||||||
<Alt>c=close
|
<Alt>c=close
|
||||||
f5=!sugar-people
|
|
||||||
f6=!sugar-activity org.sugar.Terminal
|
f6=!sugar-activity org.sugar.Terminal
|
||||||
|
@ -4,4 +4,5 @@ sugar_PYTHON = \
|
|||||||
FriendsPanel.py \
|
FriendsPanel.py \
|
||||||
Panel.py \
|
Panel.py \
|
||||||
PanelManager.py \
|
PanelManager.py \
|
||||||
|
TopPanel.py \
|
||||||
VerbsPanel.py
|
VerbsPanel.py
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
#!/usr/bin/python
|
|
||||||
|
|
||||||
import dbus
|
|
||||||
import dbus.glib
|
|
||||||
|
|
||||||
bus = dbus.SessionBus()
|
|
||||||
proxy_obj = bus.get_object('com.redhat.Sugar.Shell', '/com/redhat/Sugar/Shell')
|
|
||||||
shell = dbus.Interface(proxy_obj, 'com.redhat.Sugar.Shell')
|
|
||||||
shell.show_people()
|
|
Loading…
Reference in New Issue
Block a user