Mercurial > libervia-desktop-kivy
view cagou/kv/common_widgets.kv @ 425:13884aac1220
chat: show images in attachments:
- if an image is received from somebody in roster, it is automatically displayed (we
display only for people in roster to avoid IP address leak)
- encrypted files are decrypted and stored in cache before being displayed
- GIFs image are shown as attachment because they are badly handle in Kivy (images
frequencies is not handled correctly, and memory consumption explode). Instead, a click
on it will open the GIF in the appropriate software of the platform.
- a click on an attachment image will open it in the gallery
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 26 Feb 2020 16:47:39 +0100 |
parents | 027fad764864 |
children | 3c9ba4a694ef |
line wrap: on
line source
# Cagou: desktop/mobile frontend for Salut à Toi XMPP client # Copyright (C) 2016-2019 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/>. <ItemWidget>: size_hint: None, None width: self.base_width height: self.minimum_height orientation: 'vertical' <DeviceWidget>: Symbol: size_hint: 1, None height: dp(80) font_size: dp(40) symbol: root.getSymbol() color: 0, 0, 0, 1 Label: size_hint: None, None width: dp(100) font_size: sp(14) text_size: dp(95), None size: self.texture_size text: root.name halign: 'center' <CategorySeparator>: size_hint: 1, None height: sp(35) bold: True font_size: sp(20) color: app.c_sec <ImageViewer>: do_rotation: False AsyncImage: source: root.source allow_stretch: True, <ImagesGallery>: carousel: carousel canvas.before: Color: rgba: 0, 0, 0, 1 Rectangle: pos: self.pos size: self.size Carousel: id: carousel