aboutsummaryrefslogtreecommitdiff
path: root/main/src/ui/conversation_content_view/file_widget.vala
diff options
context:
space:
mode:
authorfiaxh <git@lightrise.org>2024-11-02 22:24:59 +0100
committerfiaxh <git@lightrise.org>2024-11-15 14:40:08 -0600
commit79f792e090330a05753f9edb27332a946eb0840d (patch)
tree5a6f1ad3ac0af0beea44ca9e83e7a9b052263025 /main/src/ui/conversation_content_view/file_widget.vala
parentaaf4542e6208460c305db4be36b15dc832ddc95a (diff)
downloaddino-79f792e090330a05753f9edb27332a946eb0840d.tar.gz
dino-79f792e090330a05753f9edb27332a946eb0840d.zip
Fix and improve stateless file-sharing
Diffstat (limited to 'main/src/ui/conversation_content_view/file_widget.vala')
-rw-r--r--main/src/ui/conversation_content_view/file_widget.vala55
1 files changed, 6 insertions, 49 deletions
diff --git a/main/src/ui/conversation_content_view/file_widget.vala b/main/src/ui/conversation_content_view/file_widget.vala
index 69781f30..583609d2 100644
--- a/main/src/ui/conversation_content_view/file_widget.vala
+++ b/main/src/ui/conversation_content_view/file_widget.vala
@@ -27,7 +27,7 @@ public class FileMetaItem : ConversationSummary.ContentMetaItem {
}
public override Gee.List<Plugins.MessageAction>? get_item_actions(Plugins.WidgetType type) {
- if (file_transfer.provider != 0 || file_transfer.info == null) return null;
+ if ((file_transfer.provider != FileManager.HTTP_PROVIDER_ID && file_transfer.provider != FileManager.SFS_PROVIDER_ID) || file_transfer.info == null) return null;
Gee.List<Plugins.MessageAction> actions = new ArrayList<Plugins.MessageAction>();
@@ -43,7 +43,6 @@ public class FileWidget : SizeRequestBox {
enum State {
IMAGE,
- IMAGE_PREVIEW,
DEFAULT
}
@@ -90,13 +89,15 @@ public class FileWidget : SizeRequestBox {
}
private async void update_widget() {
- if (show_image() && state != State.IMAGE) {
+ bool show_image = FileImageWidget.can_display(file_transfer);
+
+ if (show_image && state != State.IMAGE) {
var content_bak = content;
FileImageWidget file_image_widget = null;
try {
file_image_widget = new FileImageWidget();
- yield file_image_widget.load_from_file(file_transfer.get_file(), file_transfer.file_name);
+ yield file_image_widget.set_file_transfer(file_transfer);
// If the widget changed in the meanwhile, stop
if (content != content_bak) return;
@@ -109,26 +110,7 @@ public class FileWidget : SizeRequestBox {
} catch (Error e) { }
}
- if (show_preview() && state != State.IMAGE_PREVIEW) {
- var content_bak = content;
-
- FilePreviewWidget file_preview_widget = null;
- try {
- file_preview_widget = new FilePreviewWidget() { visible=true };
- yield file_preview_widget.load_from_thumbnail(file_transfer, stream_interactor);
-
- // If the widget changed in the meanwhile, stop
- if (content != content_bak) return;
-
- if (content != null) this.remove(content);
- content = file_preview_widget;
- state = State.IMAGE_PREVIEW;
- this.append(content);
- return;
- } catch (Error e) { }
- }
-
- if (!show_image() && state != State.DEFAULT && state != State.IMAGE_PREVIEW) {
+ if (!show_image && state != State.DEFAULT) {
if (content != null) this.remove(content);
FileDefaultWidget default_file_widget = new FileDefaultWidget();
default_widget_controller = new FileDefaultWidgetController(default_file_widget);
@@ -139,31 +121,6 @@ public class FileWidget : SizeRequestBox {
}
}
- private bool show_image() {
- if (file_transfer.mime_type == null) return false;
-
- // If the image is being sent by this client, we already have the file
- bool in_progress_from_us = file_transfer.direction == FileTransfer.DIRECTION_SENT &&
- file_transfer.ourpart.equals(file_transfer.account.full_jid) &&
- file_transfer.state == FileTransfer.State.IN_PROGRESS;
- if (file_transfer.state != FileTransfer.State.COMPLETE && !in_progress_from_us) {
- return false;
- }
-
- foreach (PixbufFormat pixbuf_format in Pixbuf.get_formats()) {
- foreach (string mime_type in pixbuf_format.get_mime_types()) {
- if (mime_type == file_transfer.mime_type) {
- return true;
- }
- }
- }
- return false;
- }
-
- private bool show_preview() {
- return !this.file_transfer.thumbnails.is_empty;
- }
-
public override void dispose() {
if (default_widget_controller != null) default_widget_controller.dispose();
default_widget_controller = null;