From 6ee4190a26f32bfa953302ee363ad3bb6c384ebb Mon Sep 17 00:00:00 2001 From: cel 🌸 Date: Sun, 1 Jun 2025 16:10:26 +0100 Subject: refactor: reorganise code --- src/open_chats.rs | 88 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 src/open_chats.rs (limited to 'src/open_chats.rs') diff --git a/src/open_chats.rs b/src/open_chats.rs new file mode 100644 index 0000000..ed89537 --- /dev/null +++ b/src/open_chats.rs @@ -0,0 +1,88 @@ +use filamento::chat::ChatStoreFields; +use indexmap::IndexMap; +use jid::BareJID; +use reactive_stores::{ArcStore, Store}; +use tracing::debug; +use leptos::prelude::*; + +use crate::chat::MacawChat; + +#[derive(Store, Default)] +pub struct OpenChatsPanel { + // jid must be a chat in the chats map + chat_view: Option, + #[store(key: BareJID = |(jid, _)| jid.clone())] + chats: IndexMap, +} + +pub fn open_chat(open_chats: Store, chat: MacawChat) { + if let Some(jid) = &*open_chats.chat_view().read() { + if let Some((index, _jid, entry)) = open_chats.chats().write().shift_remove_full(jid) { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + open_chats + .chats() + .write() + .insert_before(index, new_jid.clone(), chat); + *open_chats.chat_view().write() = Some(new_jid); + } else { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + open_chats.chats().write().insert(new_jid.clone(), chat); + *open_chats.chat_view().write() = Some(new_jid); + } + } else { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + open_chats.chats().write().insert(new_jid.clone(), chat); + *open_chats.chat_view().write() = Some(new_jid); + } +} + +impl OpenChatsPanel { + pub fn open(&mut self, chat: MacawChat) { + if let Some(jid) = &mut self.chat_view { + debug!("a chat was already open"); + if let Some((index, _jid, entry)) = self.chats.shift_remove_full(jid) { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + self.chats.insert_before(index, new_jid.clone(), chat); + *&mut self.chat_view = Some(new_jid); + } else { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + self.chats.insert(new_jid.clone(), chat); + *&mut self.chat_view = Some(new_jid); + } + } else { + let new_jid = as Clone>::clone(&chat.chat) + .correspondent() + .read() + .clone(); + self.chats.insert(new_jid.clone(), chat); + *&mut self.chat_view = Some(new_jid); + } + debug!("opened chat"); + } + + // TODO: + // pub fn open_in_new_tab_unfocused(&mut self) { + + // } + + // pub fn open_in_new_tab_focus(&mut self) { + + // } +} + + -- cgit