Mercurial > libervia-backend
view sat_frontends/primitivus/status.py @ 2671:0fa217fafabf
tools (common/template), jp: refactoring to handle multiple sites:
- site can now be specified in template header before theme, for instance: (some_site/some_theme)path/to/template.ext
- absolute template paths are now implemented, but Renderer must be instanciated with trusted to True for security reason (it's the case for jp)
- a new "front_url_filter" callable can be given to Renderer, which will convert template path to URL seen by end-user (default to real path).
- the "front_url_filter" can be used in templates with… "front_url" filter
- template_data is a new named tuple available in templates, which give site, theme and template relative URL
- search order is site/theme, site/default_theme, and default/default_theme where default link to sat_pubsub templates
- when loading CSS files, files with _noscript suffixes are now loaded, and used when javascript is not available
- "styles_extra.css" is also loaded before "styles.css", useful when a theme want to reuse default style, and just override some rules
- new site can be specified in sat.conf [DEFAULT] section, using sites_path_public_dict or sites_path_private_dict (where sites_path_private_dict won't be used in public frontends, like Libervia)
- "private" argument of Renderer tells the renderer to load private sites or not
- templates are now loaded from "templates" subdirectory, to differenciate them from other data like i18n
- jp template output has been updated to handle those changes, and to manage absolute templates
author | Goffi <goffi@goffi.org> |
---|---|
date | Mon, 10 Sep 2018 08:58:18 +0200 |
parents | 56f94936df1e |
children | e6806aaab16d |
line wrap: on
line source
#!/usr/bin/env python2 # -*- coding: utf-8 -*- # Primitivus: a SAT frontend # Copyright (C) 2013-2016 Adrien Cossa (souliane@mailoo.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/>. from sat.core.i18n import _ import urwid from urwid_satext import sat_widgets from sat_frontends.quick_frontend.constants import Const as commonConst from sat_frontends.primitivus.constants import Const as C class StatusBar(urwid.Columns): def __init__(self, host): self.host = host self.presence = sat_widgets.ClickableText("") status_prefix = urwid.Text("[") status_suffix = urwid.Text("]") self.status = sat_widgets.ClickableText("") self.setPresenceStatus(C.PRESENCE_UNAVAILABLE, "") urwid.Columns.__init__( self, [ ("weight", 1, self.presence), ("weight", 1, status_prefix), ("weight", 9, self.status), ("weight", 1, status_suffix), ], ) urwid.connect_signal(self.presence, "click", self.onPresenceClick) urwid.connect_signal(self.status, "click", self.onStatusClick) def onPresenceClick(self, sender=None): if not self.host.bridge.isConnected( self.host.current_profile ): # FIXME: manage multi-profiles return options = [commonConst.PRESENCE[presence] for presence in commonConst.PRESENCE] list_widget = sat_widgets.GenericList( options=options, option_type=sat_widgets.ClickableText, on_click=self.onChange ) decorated = sat_widgets.LabelLine( list_widget, sat_widgets.SurroundedText(_("Set your presence")) ) self.host.showPopUp(decorated) def onStatusClick(self, sender=None): if not self.host.bridge.isConnected( self.host.current_profile ): # FIXME: manage multi-profiles return pop_up_widget = sat_widgets.InputDialog( _("Set your status"), _("New status"), default_txt=self.status.get_text(), cancel_cb=self.host.removePopUp, ok_cb=self.onChange, ) self.host.showPopUp(pop_up_widget) def onChange(self, sender=None, user_data=None): new_value = user_data.get_text() previous = ( [key for key in C.PRESENCE if C.PRESENCE[key][0] == self.presence.get_text()][ 0 ], self.status.get_text(), ) if isinstance(user_data, sat_widgets.ClickableText): new = ( [ key for key in commonConst.PRESENCE if commonConst.PRESENCE[key] == new_value ][0], previous[1], ) elif isinstance(user_data, sat_widgets.AdvancedEdit): new = (previous[0], new_value[0]) if new != previous: statuses = { C.PRESENCE_STATUSES_DEFAULT: new[1] } # FIXME: manage multilingual statuses for ( profile ) in ( self.host.profiles ): # FIXME: for now all the profiles share the same status self.host.bridge.setPresence( show=new[0], statuses=statuses, profile_key=profile ) self.setPresenceStatus(new[0], new[1]) self.host.removePopUp() def setPresenceStatus(self, show, status): show_icon, show_attr = C.PRESENCE.get(show) self.presence.set_text(("show_normal", show_icon)) if status is not None: self.status.set_text((show_attr, status)) self.host.redraw()