Mercurial > libervia-web
view src/browser/sat_browser/contact_widget.py @ 676:849ffb24d5bf frontends_multi_profiles
browser side: menus refactorisation:
- use of the new quick_frontends.quick_menus module, resulting in a big code simplification in Libervia
- menu are added in there respective modules: main menus are done directely in libervia_main, while tarot and radiocol menus are done in game_tarot and game_radiocol
- launchAction has the same signature as in QuickApp
- base_menu: there are now 2 classes to launch an action: MenuCmd which manage quick_menus classes, and SimpleCmd to launch a generic callback
- base_menu: MenuNode has been removed as logic is now in quick_menus
- base_menu: GenericMenuBar.update method can be called to fully (re)build the menus
- base_widget: removed WidgetSubMenuBar which is no more useful (GenericMenuBar do the same thing)
- plugin_menu_context is used in LiberviaWidget and other classes with menus to indicate which menu types must be used
- otr menus hooks are temporarily removed, will be fixed soon
author | Goffi <goffi@goffi.org> |
---|---|
date | Tue, 17 Mar 2015 20:42:02 +0100 |
parents | 2201ff543a05 |
children | e876f493dccc |
line wrap: on
line source
#!/usr/bin/python # -*- coding: utf-8 -*- # Libervia: a Salut à Toi frontend # Copyright (C) 2011, 2012, 2013, 2014 Jérôme Poisson <goffi@goffi.org> # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # This program 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 Affero General Public License for more details. # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. import pyjd # this is dummy in pyjs from sat.core.log import getLogger log = getLogger(__name__) from sat.core import exceptions from sat_frontends.quick_frontend import quick_menus from pyjamas.ui.VerticalPanel import VerticalPanel from pyjamas.ui.HTML import HTML from pyjamas.ui.Image import Image from pyjamas.ui.ClickListener import ClickHandler from constants import Const as C import html_tools import base_widget import libervia_widget unicode = str # XXX: pyjama doesn't manage unicode class ContactLabel(HTML): """Display a contact in HTML, selecting best display (jid/nick/etc)""" def __init__(self, host, jid_, display=C.CONTACT_DEFAULT_DISPLAY): """ @param host (SatWebFrontend): host instance @param jid_ (jid.JID): contact JID @param display (tuple): prioritize the display methods of the contact's label with values in ("jid", "nick", "bare", "resource"). """ # TODO: add a listener for nick changes HTML.__init__(self) self.host = host self.jid = jid_ if "nick" in display: self.nick = self.host.contact_lists[C.PROF_KEY_NONE].getCache(self.jid, "nick") self.display = display self.alert = False self.refresh() self.setStyleName('contactLabel') def refresh(self): alert_html = "<strong>(*)</strong> " if self.alert else "" contact_raw = None for disp in self.display: if disp == "jid": contact_raw = unicode(self.jid) elif disp == "nick": contact_raw = self.nick elif disp == "bare": contact_raw = unicode(self.jid.bare) elif disp == "resource": contact_raw = self.jid.resource else: raise exceptions.InternalError(u"Unknown display argument [{}]".format(disp)) if contact_raw: break if not contact_raw: log.error(u"Counld not find a contact display for jid {jid} (display: {display})".format(jid=self.jid, display=self.display)) contact_raw = "UNNAMED" contact_html = html_tools.html_sanitize(contact_raw) html = "%(alert)s%(contact)s" % {'alert': alert_html, 'contact': contact_html} self.setHTML(html) def updateNick(self, new_nick): """Change the current nick @param new_nick(unicode): new nick to use """ self.nick = new_nick self.refresh() def setAlert(self, alert): """Show a visual indicator @param alert: True if alert must be shown """ self.alert = alert self.refresh() class ContactMenuBar(base_widget.WidgetMenuBar): def onBrowserEvent(self, event): base_widget.WidgetMenuBar.onBrowserEvent(self, event) event.stopPropagation() # prevent opening the chat dialog @classmethod def getCategoryHTML(cls, menu_name_i18n, type_): return '<img src="%s"/>' % C.DEFAULT_AVATAR_URL def setUrl(self, url): """Set the URL of the contact avatar.""" self.items[0].setHTML('<img src="%s" />' % url) class ContactBox(VerticalPanel, ClickHandler, libervia_widget.DragLabel): def __init__(self, host, jid_, style_name=None, display=C.CONTACT_DEFAULT_DISPLAY, plugin_menu_context=None): """ @param host (SatWebFrontend): host instance @param jid_ (jid.JID): contact JID @param style_name (unicode): CSS style name @param contacts_display (tuple): prioritize the display methods of the contact's label with values in ("jid", "nick", "bare", "resource"). @param plugin_menu_context (iterable): contexts of menus to have (list of C.MENU_* constant) """ self.plugin_menu_context = [] if plugin_menu_context is None else plugin_menu_context VerticalPanel.__init__(self, StyleName=style_name or 'contactBox', VerticalAlignment='middle') ClickHandler.__init__(self) libervia_widget.DragLabel.__init__(self, jid_, "CONTACT", host) self.jid = jid_ self.label = ContactLabel(host, self.jid, display=display) self.avatar = ContactMenuBar(self, host) if plugin_menu_context else Image() try: # FIXME: dirty hack to force using an Image when the menu is actually empty self.avatar.items[0] except IndexError: self.avatar = Image() self.updateAvatar(host.getAvatarURL(self.jid.bare)) self.add(self.avatar) self.add(self.label) self.addClickListener(self) def setAlert(self, alert): """Show a visual indicator @param alert: True if alert indicator show be shown""" self.label.setAlert(alert) def updateAvatar(self, url): """Update the avatar. @param url (unicode): image url """ self.avatar.setUrl(url) def updateNick(self, new_nick): """Update the nickname. @param new_nick (unicode): new nickname to use """ self.label.updateNick(new_nick) def onClick(self, sender): try: self.parent.onClick(self.jid.bare) except (AttributeError, TypeError): pass else: self.setAlert(False) quick_menus.QuickMenusManager.addDataCollector(C.MENU_JID_CONTEXT, lambda caller, dummy: {'jid': unicode(caller.jid.bare)})