summaryrefslogtreecommitdiffstats
path: root/src/views/macaw/open_chats_panel.rs
blob: bdb0084068d5ab175b75cc3c310496179a215563 (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
74
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() /> }.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 {
        view! {
            <div class="open-chat-view">
                <ChatViewHeader chat=chat.clone() />
                <MessageHistoryBuffer chat=chat.clone() />
                {move || {
                    let chat_jid = chat.get().correspondent().get();
                    view! {
                        <ChatViewMessageComposer chat=chat_jid />
                    }
                }}
            </div>
        }
    }
}