Mercurial > libervia-desktop
view cagou/kv/menu.kv @ 412:7c6149c249c1
chat: attachment sending:
- files to send are not sent directly anymore, but added to attachment, and linked to the
message when it is sent, this is more user friendly and avoid the accidental sending of
wrong file
- user can remove the attachment before sending the message, using the "close" symbol
- new "Chat.addAtachment" method
- upload progress is shown on the AttachmentItem thanks to the "progress" property
- AttachmentItem stays in the attachments layout until uploaded or an error happens.
Messages can still be sent while the item is being uploaded.
author | Goffi <goffi@goffi.org> |
---|---|
date | Sun, 23 Feb 2020 15:39:03 +0100 |
parents | f7476818f9fb |
children | 5761b5f03c0c |
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/>. #:import _ sat.core.i18n._ #:import C cagou.core.constants.Const <AboutContent>: text_size: self.size color: 1, 1, 1, 1 halign: "center" valign: "middle" <AboutPopup>: title_align: "center" size_hint: 0.8, 0.8 <ExtraMenuItem>: size_hint: 1, None height: dp(30) <ExtraSideMenu>: bg_color: 0.23, 0.23, 0.23, 1 ExtraMenuItem: text: _("About") on_press: root.onAbout() Widget: # to push content to the top <TransferMenu>: items_layout: items_layout orientation: "vertical" size_hint: 1, 0.5 canvas.before: Color: rgba: 0, 0, 0, 1 Rectangle: pos: self.pos size: self.size BoxLayout: size_hint: 1, None height: dp(50) ToggleButton: id: upload_btn text: _(u"upload") group: "transfer" state: "down" ToggleButton: id: send_btn text: _(u"send") group: "transfer" Label: color: 1, 1, 1, 1 size_hint: 1, 0.3 text: root.transfer_txt if upload_btn.state == 'down' else root.send_txt text_size: self.size halign: 'center' valign: 'top' ScrollView: do_scroll_x: False StackLayout: size_hint: 1, None padding: 20, 0 spacing: 15, 5 id: items_layout <TransferItem>: orientation: "vertical" size_hint: None, None size: dp(50), dp(90) IconButton: source: root.plug_info['icon_medium'] allow_stretch: True size_hint: 1, None height: dp(50) Label: color: 1, 1, 1, 1 text: root.plug_info['name'] text_size: self.size halign: "center" valign: "top" <SideMenu>: orientation: "vertical" size_hint: self.size_hint_close canvas.before: Color: rgba: self.bg_color Rectangle: pos: self.pos size: self.size <EntitiesSelectorMenu>: bg_color: 0, 0, 0, 0.9 filter_input: filter_input layout: layout callback_on_close: True Label: size_hint: 1, None text_size: root.width, None size: self.texture_size padding: dp(5), dp(5) color: 1, 1, 1, 1 text: root.instructions halign: "center" TextInput: id: filter_input size_hint: 1, None height: dp(32) multiline: False hint_text: _(u"enter filter here") ScrollView: size_hint: 1, 1 BoxLayout: id: layout orientation: "vertical" size_hint: 1, None height: self.minimum_height spacing: dp(5)