render gif in PostView

Signed-off-by: kernelkind <kernelkind@gmail.com>
This commit is contained in:
kernelkind
2025-02-20 16:48:54 -05:00
parent e5fc461a79
commit 9d88ba1415

View File

@@ -14,7 +14,7 @@ use egui::{vec2, Frame, Layout, Margin, Pos2, ScrollArea, Sense, TextBuffer};
use enostr::{FilledKeypair, FullKeypair, NoteId, Pubkey, RelayPool}; use enostr::{FilledKeypair, FullKeypair, NoteId, Pubkey, RelayPool};
use nostrdb::{Ndb, Transaction}; use nostrdb::{Ndb, Transaction};
use notedeck::{Images, NoteCache}; use notedeck::{supported_mime_hosted_at_url, Images, NoteCache};
use tracing::error; use tracing::error;
use super::contents::render_note_preview; use super::contents::render_note_preview;
@@ -386,12 +386,15 @@ impl<'a> PostView<'a> {
(300, 300) (300, 300)
}; };
if let Some(cache_type) =
supported_mime_hosted_at_url(&mut self.img_cache.urls, &media.url)
{
render_images( render_images(
ui, ui,
self.img_cache, self.img_cache,
&media.url, &media.url,
crate::images::ImageType::Content(width, height), crate::images::ImageType::Content(width, height),
notedeck::MediaCacheType::Image, // TODO(kernelkind): support gifs in PostView cache_type,
|ui| { |ui| {
ui.spinner(); ui.spinner();
}, },
@@ -408,8 +411,10 @@ impl<'a> PostView<'a> {
media_size media_size
}; };
let texture_handle = let texture_handle = handle_repaint(
handle_repaint(ui, retrieve_latest_texture(url, gifs, renderable_media)); ui,
retrieve_latest_texture(url, gifs, renderable_media),
);
let img_resp = ui.add( let img_resp = ui.add(
egui::Image::new(texture_handle) egui::Image::new(texture_handle)
.max_size(size) .max_size(size)
@@ -428,6 +433,12 @@ impl<'a> PostView<'a> {
ui.advance_cursor_after_rect(img_resp.rect); ui.advance_cursor_after_rect(img_resp.rect);
}, },
); );
} else {
self.draft
.upload_errors
.push("Uploaded media is not supported.".to_owned());
error!("Unsupported mime type at url: {}", &media.url);
}
} }
to_remove.reverse(); to_remove.reverse();
for i in to_remove { for i in to_remove {