]> code.citadel.org Git - citadel.git/blobdiff - webcit/roomchat.c
Remove $Id$ tags from most of webcit
[citadel.git] / webcit / roomchat.c
index 1e2d8499199f5e5b17870611b213dd00dfe8cecb..2278333ea913422a32ff6b286ad2ff6cdcdfaabb 100644 (file)
@@ -1,6 +1,4 @@
 /*
- * $Id$
- *
  * This module handles multiuser chat.
  *
  * Copyright (c) 1996-2010 by the citadel.org team
@@ -62,10 +60,10 @@ void chat_recv(void) {
                if (strcasecmp(cl_user, WC->last_chat_user)) {
                        wc_printf("<br>\n");
                        if (!strcasecmp(cl_user, ChrPtr(WC->wc_fullname))) {
-                               wc_printf("<span class=\"chat_username_me\">");
+                               wc_printf("<span class=\"chat_myname_class\">");
                        }
                        else {
-                               wc_printf("<span class=\"chat_username_notme\">");
+                               wc_printf("<span class=\"chat_notmyname_class\">");
                        }
                        escputs(cl_user);
                        strcpy(WC->last_chat_user, cl_user);
@@ -77,7 +75,7 @@ void chat_recv(void) {
                }
 
                /* what did they say ... */
-               wc_printf("<span class=\"chat_text\">");
+               wc_printf("<span class=\"chat_text_class\">");
                while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
                        escputs(buf);
                }
@@ -102,14 +100,6 @@ void chat_send(void) {
                strcpy(send_this, "");
        }
 
-       if (havebstr("help_button")) {
-               strcpy(send_this, "/help");
-       }
-
-       if (havebstr("list_button")) {
-               strcpy(send_this, "/who");
-       }
-
        if (havebstr("exit_button")) {
                strcpy(send_this, "/quit");
        }
@@ -126,12 +116,50 @@ void chat_send(void) {
 }
 
 
+/*
+ * wholist for chat
+ */
+void chat_rwho(void) {
+       char buf[1024];
+
+       serv_puts("RCHT rwho");
+       serv_getln(buf, sizeof buf);
+       if (buf[0] == '1') {
+               while (serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
+                       if (!strcasecmp(buf, ChrPtr(WC->wc_fullname))) {
+                               wc_printf("<span class=\"chat_myname_class\">");
+                       }
+                       else {
+                               wc_printf("<span class=\"chat_notmyname_class\">");
+                       }
+                       wc_printf("<img src=\"static/citadelchat_16x.gif\">");
+                       escputs(buf);
+                       wc_printf("</span><br>\n");
+               }
+       }
+}
+
+
+/*
+ * advise the Citadel server that the user is navigating away from the chat window
+ */
+void chat_exit(void) {
+       char buf[1024];
+
+       serv_puts("RCHT exit");
+       serv_getln(buf, sizeof buf);            /* Throw away the server reply */
+}
+
+
+
 void 
 InitModule_ROOMCHAT
 (void)
 {
        WebcitAddUrlHandler(HKEY("chat"), "", 0, do_chat, 0);
        WebcitAddUrlHandler(HKEY("chat_recv"), "", 0, chat_recv, AJAX);
+       WebcitAddUrlHandler(HKEY("chat_rwho"), "", 0, chat_rwho, AJAX);
+       WebcitAddUrlHandler(HKEY("chat_exit"), "", 0, chat_exit, AJAX);
        WebcitAddUrlHandler(HKEY("chat_send"), "", 0, chat_send, 0);
 }