]> code.citadel.org Git - citadel.git/blobdiff - webcit/vcard_edit.c
* Worked on meeting accept/decline a little bit
[citadel.git] / webcit / vcard_edit.c
index 12f15cbe7d1b1f2173dc09919cc7ebd6078461e4..8dcd227cd4e4b78fb6a7effff1f638b32a50e23c 100644 (file)
@@ -30,7 +30,7 @@
 
 
 
-void edit_vcard(void) {
+void do_edit_vcard(long msgnum, char *partnum, char *return_to) {
        char buf[SIZ];
        char *serialized_vcard = NULL;
        size_t total_len = 0;
@@ -39,6 +39,7 @@ void edit_vcard(void) {
        struct vCard *v;
        int i;
        char *key, *value;
+       char whatuser[SIZ];
 
        char lastname[SIZ];
        char firstname[SIZ];
@@ -52,6 +53,9 @@ void edit_vcard(void) {
        char state[SIZ];
        char zipcode[SIZ];
        char country[SIZ];
+       char hometel[SIZ];
+       char worktel[SIZ];
+       char inetemail[SIZ];
        char extrafields[SIZ];
 
        lastname[0] = 0;
@@ -66,10 +70,35 @@ void edit_vcard(void) {
        state[0] = 0;
        zipcode[0] = 0;
        country[0] = 0;
+       hometel[0] = 0;
+       worktel[0] = 0;
+       inetemail[0] = 0;
        extrafields[0] = 0;
 
-       output_headers(1);
-       sprintf(buf, "OPNA %s|%s", bstr("msgnum"), bstr("partnum") );
+       output_headers(3);
+
+       strcpy(whatuser, "");
+       sprintf(buf, "MSG0 %ld|1", msgnum);
+       serv_puts(buf);
+       serv_gets(buf);
+       if (buf[0] != '1') {
+               wDumpContent(1);
+               return;
+       }
+       while (serv_gets(buf), strcmp(buf, "000")) {
+               if (!strncasecmp(buf, "from=", 5)) {
+                       strcpy(whatuser, &buf[5]);
+               }
+               else if (!strncasecmp(buf, "node=", 5)) {
+                       strcat(whatuser, " @ ");
+                       strcat(whatuser, &buf[5]);
+               }
+       }
+
+       total_len = atoi(&buf[4]);
+
+
+       sprintf(buf, "OPNA %ld|%s", msgnum, partnum);
        serv_puts(buf);
        serv_gets(buf);
        if (buf[0] != '2') {
@@ -125,6 +154,21 @@ void edit_vcard(void) {
                        extract_token(country, value, 6, ';');
                }
 
+               else if (!strcasecmp(key, "tel;home")) {
+                       extract_token(hometel, value, 0, ';');
+               }
+
+               else if (!strcasecmp(key, "tel;work")) {
+                       extract_token(worktel, value, 0, ';');
+               }
+
+               else if (!strcasecmp(key, "email;internet")) {
+                       if (inetemail[0] != 0) {
+                               strcat(inetemail, "\n");
+                       }
+                       strcat(inetemail, value);
+               }
+
                else {
                        strcat(extrafields, key);
                        strcat(extrafields, ":");
@@ -137,36 +181,43 @@ void edit_vcard(void) {
        vcard_free(v);
 
        /* Display the form */
-       wprintf("<FORM METHOD=\"POST\" ACTION=\"/do_FIXME_stuff\">\n");
-       wprintf("<H2><IMG VALIGN=CENTER SRC=\"/static/vcard.gif\">"
-               "Contact information for FIXME</H2>\n");
+       wprintf("<FORM METHOD=\"POST\" ACTION=\"/submit_vcard\">\n");
+       wprintf("<H2><IMG ALIGN=CENTER SRC=\"/static/vcard.gif\">"
+               "Contact information for ");
+       escputs(whatuser);
+       wprintf("</H2>\n");
 
-       wprintf("Last name: "
-               "<INPUT TYPE=\"text\" NAME=\"lastname\" "
-               "VALUE=\"%s\" MAXLENGTH=\"29\"><BR>\n",
-               lastname);
-       wprintf("First name: "
-               "<INPUT TYPE=\"text\" NAME=\"firstname\" "
-               "VALUE=\"%s\" MAXLENGTH=\"29\"><BR>\n",
-               firstname);
-       wprintf("Prefix: "
-               "<INPUT TYPE=\"text\" NAME=\"prefix\" "
-               "VALUE=\"%s\" MAXLENGTH=\"5\"><BR>\n",
+       wprintf("<TABLE border=0><TR>"
+               "<TD>Prefix</TD>"
+               "<TD>First</TD>"
+               "<TD>Middle</TD>"
+               "<TD>Last</TD>"
+               "<TD>Suffix</TD></TR>\n");
+       wprintf("<TR><TD><INPUT TYPE=\"text\" NAME=\"prefix\" "
+               "VALUE=\"%s\" MAXLENGTH=\"5\"></TD>",
                prefix);
-       wprintf("Suffix: "
-               "<INPUT TYPE=\"text\" NAME=\"suffix\" "
-               "VALUE=\"%s\" MAXLENGTH=\"10\"><BR><BR>\n",
+       wprintf("<TD><INPUT TYPE=\"text\" NAME=\"firstname\" "
+               "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+               firstname);
+       wprintf("<TD><INPUT TYPE=\"text\" NAME=\"middlename\" "
+               "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+               middlename);
+       wprintf("<TD><INPUT TYPE=\"text\" NAME=\"lastname\" "
+               "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+               lastname);
+       wprintf("<TD><INPUT TYPE=\"text\" NAME=\"suffix\" "
+               "VALUE=\"%s\" MAXLENGTH=\"10\"></TD></TR></TABLE>\n",
                suffix);
 
-       wprintf("<TABLE border=0><TR><TD>Address - PO box; optional:</TD>"
+       wprintf("<TABLE border=0><TR><TD>PO box (optional):</TD>"
                "<TD><INPUT TYPE=\"text\" NAME=\"pobox\" "
                "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
                pobox);
-       wprintf("<TR><TD>Street:</TD>"
+       wprintf("<TR><TD>Address line 1:</TD>"
                "<TD><INPUT TYPE=\"text\" NAME=\"extadr\" "
                "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
                extadr);
-       wprintf("<TR><TD>&nbsp;</TD>"
+       wprintf("<TR><TD>Address line 2:</TD>"
                "<TD><INPUT TYPE=\"text\" NAME=\"street\" "
                "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
                street);
@@ -187,10 +238,106 @@ void edit_vcard(void) {
                "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR></TABLE>\n",
                country);
 
-       wprintf("<TEXTAREA NAME=\"extrafields\" ROWS=10 COLS=80 WIDTH=80>");
+       wprintf("<TABLE BORDER=0><TR><TD>Home telephone:</TD>"
+               "<TD><INPUT TYPE=\"text\" NAME=\"hometel\" "
+               "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
+               hometel);
+       wprintf("<TR><TD>Work telephone:</TD>"
+               "<TD><INPUT TYPE=\"text\" NAME=\"worktel\" "
+               "VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR></TABLE>\n",
+               worktel);
+
+       wprintf("<TABLE border=0><TR><TD>Internet e-mail addresses:<BR>"
+               "<FONT size=-2>For addresses in the Citadel directory, "
+               "the topmost address will be used in outgoing mail."
+               "</FONT></TD><TD>"
+               "<TEXTAREA NAME=\"inetemail\" ROWS=5 COLS=40 WIDTH=40>");
+       escputs(inetemail);
+       wprintf("</TEXTAREA></TD></TR></TABLE><BR>\n");
+
+       wprintf("<INPUT TYPE=\"hidden\" NAME=\"extrafields\" VALUE=\"");
        escputs(extrafields);
-       wprintf("</TEXTAREA><BR>\n");
+       wprintf("\">\n");
+
+       wprintf("<INPUT TYPE=\"hidden\" NAME=\"return_to\" VALUE=\"");
+       urlescputs(return_to);
+       wprintf("\">\n");
+
+       wprintf("<CENTER>\n");
+                wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+                wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
+                wprintf("</CENTER></FORM>\n");
 
         
        wDumpContent(1);
 }
+
+
+
+void edit_vcard(void) {
+       long msgnum;
+       char *partnum;
+
+       msgnum = atol(bstr("msgnum"));
+       partnum = bstr("partnum");
+       do_edit_vcard(msgnum, partnum, "");
+}
+
+
+
+
+void submit_vcard(void) {
+       char buf[SIZ];
+       int i;
+
+       if (strcmp(bstr("sc"), "OK")) { 
+               readloop("readnew");
+               return;
+       }
+
+       sprintf(buf, "ENT0 1|||4||");
+       serv_puts(buf);
+       serv_gets(buf);
+       if (buf[0] != '4') {
+               edit_vcard();
+               return;
+       }
+
+       serv_puts("Content-type: text/x-vcard");
+       serv_puts("");
+       serv_puts("begin:vcard");
+       serv_printf("n:%s;%s;%s;%s;%s",
+               bstr("lastname"),
+               bstr("firstname"),
+               bstr("middlename"),
+               bstr("prefix"),
+               bstr("suffix") );
+       serv_printf("adr:%s;%s;%s;%s;%s;%s;%s",
+               bstr("pobox"),
+               bstr("extadr"),
+               bstr("street"),
+               bstr("city"),
+               bstr("state"),
+               bstr("zipcode"),
+               bstr("country") );
+       serv_printf("tel;home:%s", bstr("hometel") );
+       serv_printf("tel;work:%s", bstr("worktel") );
+       
+       for (i=0; i<num_tokens(bstr("inetemail"), '\n'); ++i) {
+               extract_token(buf, bstr("inetemail"), i, '\n');
+               if (strlen(buf) > 0) {
+                       serv_printf("email;internet:%s", buf);
+               }
+       }
+
+       serv_printf("%s", bstr("extrafields") );
+       serv_puts("end:vcard");
+       serv_puts("000");
+
+       if (!strcmp(bstr("return_to"), "/select_user_to_edit")) {
+               select_user_to_edit(NULL, NULL);
+       }
+       else {
+               readloop("readnew");
+       }
+}