f3707d48c935e373862cf7b207f435522018c50a
[citadel.git] / webcit-ng / static / js / views.js
1 // Copyright (c) 2016-2023 by the citadel.org team
2 //
3 // This program is open source software.  Use, duplication, or
4 // disclosure are subject to the GNU General Public License v3.
5
6
7 // Clear the sidebar buttons of any style indicating that one is selected
8 function clear_sidebar_selection() {
9         var items = document.getElementById("ctdl-sidebar").getElementsByTagName("*");
10         for (var i = items.length; i--;) {
11                 if (items[i].id.includes("ctdl-sidebar-button-")) {
12                         items[i].classList.remove("ctdl-sidebar-button-selected");
13                 }
14         }
15         document.getElementById("ctdl_mail_folder_list").style.display = "none";
16 }
17
18
19 // Clear any drop handlers that might have been set by the previous view
20 function clear_drop_handlers() {
21 }
22
23
24 // Clear the top bar navigation buttons.  The view renderer will set its own buttons.
25 function clear_navigation_buttons() {
26         for (const d of ["ctdl-newmsg-button", "ctdl-ungoto-button", "ctdl-skip-button", "ctdl-goto-button", "ctdl-delete-button"]) {
27                 document.getElementById(d).style.display = "none";
28         }
29 }
30
31
32 // This function is the dispatcher that determines the correct view for a room, and calls the correct renderer.
33 function render_room_view() {
34
35         clear_navigation_buttons();
36         clear_sidebar_selection();
37         clear_drop_handlers();
38
39         document.getElementById("ctdl-main").innerHTML = 
40                 "<div class=\"ctdl-middle\">"
41                 + _("Loading messages from server, please wait")
42                 + "</div>";
43
44         switch(current_view) {
45
46                 // The "forum" module displays rooms with the "VIEW_BBS" view as classic style web forums.
47                 case views.VIEW_BBS:
48                         document.getElementById("ctdl-sidebar-button-forums").classList.add("ctdl-sidebar-button-selected");
49                         view_render_forums();
50                         break;
51
52                 // The "mail" module displays rooms with the VIEW_MAILBOX view as a webmail program.
53                 case views.VIEW_MAILBOX:
54                 case views.VIEW_DRAFTS:
55                         document.getElementById("ctdl-sidebar-button-mail").classList.add("ctdl-sidebar-button-selected");
56                         display_mail_folder_list("ctdl_mail_folder_list");
57                         view_render_mail();
58                         break;
59
60                 // The "contacts" module displays rooms with the VIEW_ADDRESSBOOK view as a contacts manager.
61                 case views.VIEW_ADDRESSBOOK:
62                         document.getElementById("ctdl-main").innerHTML =
63                                 "<div class=\"ctdl-middle\">'" + current_room + "' is an address book but there is no renderer.</div>";
64                         break;
65
66                 case views.VIEW_CALENDAR:
67                 case views.VIEW_CALBRIEF:
68                         document.getElementById("ctdl-main").innerHTML =
69                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a calendar but there is no renderer.</div>";
70                         break;
71
72                 case views.VIEW_TASKS:
73                         document.getElementById("ctdl-main").innerHTML =
74                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a task list but there is no renderer.</div>";
75                         break;
76
77                 case views.VIEW_NOTES:
78                         document.getElementById("ctdl-main").innerHTML =
79                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a notes list but there is no renderer.</div>";
80                         break;
81
82                 case views.VIEW_WIKI:
83                         document.getElementById("ctdl-main").innerHTML =
84                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a wiki but there is no renderer.</div>";
85                         break;
86
87                 case views.VIEW_JOURNAL:
88                         document.getElementById("ctdl-main").innerHTML =
89                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a journal but there is no renderer.</div>";
90                         break;
91
92                 case views.VIEW_BLOG:
93                         document.getElementById("ctdl-main").innerHTML =
94                                 "<div class=\"ctdl-middle\">'" + current_room + "' is a blog but there is no renderer.</div>";
95                         break;
96
97                 case views.VIEW_QUEUE:
98                         document.getElementById("ctdl-main").innerHTML =
99                                 "<div class=\"ctdl-middle\">We ought to be displaying the email queue here.</div>";
100                         break;
101
102                 default:
103                         document.getElementById("ctdl-main").innerHTML =
104                                 "<div class=\"ctdl-middle\">The view for " + current_room + " is " + current_view + " but there is no renderer.</div>";
105                         break;
106         }
107
108 }
109
110
111 // This gets called when the user clicks the "enter message" or "post message" or "add item" button etc.
112 function entmsg_dispatcher() {
113         switch(current_view) {
114                 case views.VIEW_BBS:
115                         forum_entmsg();
116                         break;
117                 case views.VIEW_MAILBOX:
118                         mail_compose(false, "", 0, "", "", "");
119                         break;
120                 default:
121                         break;
122         }
123 }
124
125
126 // This gets called when the user clicks the "delete" button etc.
127 function delete_dispatcher() {
128         switch(current_view) {
129                 case views.VIEW_MAILBOX:
130                         mail_delete_selected();
131                         break;
132                 default:
133                         break;
134         }
135 }
136
137