summaryrefslogtreecommitdiffstats
path: root/src/views/macaw/open_chats_panel.rs
blob: 062c7867f46c8ff53edc909ac8940815c4a976be (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
use leptos::prelude::*;
use open_chat::OpenChatView;
use reactive_stores::{ArcStore, Store};

use crate::open_chats::{OpenChatsPanel, OpenChatsPanelStoreFields};

// TODO: multiple panels
// pub struct OpenChats {
//     panels:
// }

#[component]
pub fn OpenChatsPanelView() -> impl IntoView {
    let open_chats: Store<OpenChatsPanel> = use_context().expect("no open chats panel in context");

    // TODO: tabs
    // view! {
    //     {move || {
    //         if open_chats.chats().read().len() > 1 {
    //             Some(
    //                 view! {
    //                     <For
    //                         each=move || open_chats.chats().get()
    //                         key=|(jid, _)| jid.clone()
    //                         let(chat)
    //                     ></For>
    //                 },
    //             )
    //         } else {
    //             None
    //         }
    //     }}
    // }
    view! {
        <div class="open-chat-views">
            {move || {
                if let Some(open_chat) = open_chats.chat_view().get() {
                    if let Some(open_chat) = open_chats.chats().read().get(&open_chat) {
                        view! { <OpenChatView chat=open_chat.clone() /> }.into_any()
                    } else {
                        view! {}.into_any()
                    }
                } else {
                    view! {}.into_any()
                }
            }}
        </div>
    }
}

mod open_chat {
    use filamento::chat::{Chat, ChatStoreFields};
    use leptos::prelude::*;
    use reactive_stores::{ArcStore, Store};

    use crate::{chat::MacawChat, components::{chat_header::ChatViewHeader, message_composer::ChatViewMessageComposer, message_history_buffer::MessageHistoryBuffer}};

    #[component]
    pub fn OpenChatView(chat: MacawChat) -> impl IntoView {
        let chat_chat: Store<Chat> =
            <ArcStore<filamento::chat::Chat> as Clone>::clone(&chat.chat).into();
        let chat_jid = move || chat_chat.correspondent().get();

        view! {
            <div class="open-chat-view">
                <ChatViewHeader chat=chat.clone() />
                <MessageHistoryBuffer chat=chat.clone() />
                <ChatViewMessageComposer chat=chat_jid() />
            </div>
        }
    }
}