]> code.citadel.org Git - citadel.git/blobdiff - webcit/blogview_renderer.c
Began working on a permalink system WARNING NOT WORKING YET
[citadel.git] / webcit / blogview_renderer.c
index 3cf584af9623b9a92aead20e27081b37711a1e86..164c7539563fb542bded28a0e1a2254708786346 100644 (file)
@@ -48,25 +48,26 @@ void blogpost_render_and_destroy(struct blogpost *bp) {
 
        if ( ((p == 0) || (p == bp->top_level_id)) && (bp->num_msgs > 0) ) {
                /* Show the top level post */
-               read_message(WC->WBuf, HKEY("view_message"), bp->msgs[0], NULL, &Mime);
+               read_message(WC->WBuf, HKEY("view_blog_post"), bp->msgs[0], NULL, &Mime);
 
                if (p == 0) {
                        /* Show the number of comments */
                        wc_printf("<a href=\"readfwd?p=%d?gotofirst=", bp->top_level_id);
                        urlescputs(ChrPtr(WC->CurRoom.name));
-                       wc_printf("#comments\">%d comments</a>", bp->num_msgs - 1);
+                       wc_printf("#comments\">");
+                       wc_printf(_("%d comments"), bp->num_msgs - 1);
+                       wc_printf("</a>");
                }
                else if (bp->num_msgs < 2) {
-                       wc_printf("dere r no comments here!<br>\n");
+                       wc_printf(_("%d comments"), 0);
                }
                else {
                        wc_printf("<a name=\"comments\"></a>\n");
-                       wc_printf("%d comments<br>\n", bp->num_msgs - 1);
-                       wc_printf("<blockquote>");
+                       wc_printf(_("%d comments"), bp->num_msgs - 1);
+                       wc_printf("<br>\n");
                        for (i=1; i<bp->num_msgs; ++i) {
-                               read_message(WC->WBuf, HKEY("view_message"), bp->msgs[i], NULL, &Mime);
+                               read_message(WC->WBuf, HKEY("view_blog_comment"), bp->msgs[i], NULL, &Mime);
                        }
-                       wc_printf("</blockquote>");
                }
        }
 
@@ -236,6 +237,28 @@ int blogview_Cleanup(void **ViewSpecific)
        return 0;
 }
 
+/*
+ * Generate a permalink for a post
+ *
+ * FIXME THIS IS WRONG, FIND THE FOO
+ *
+ */
+void tmplput_blog_permalink(StrBuf *Target, WCTemplputParams *TP) {
+       int p = atoi(BSTR("p"));        /* are we looking for a specific post? */
+       char perma[SIZ];
+       char encoded_perma[SIZ];
+       
+       strcpy(perma, "/readfwd?gotofirst=");
+       urlesc(&perma[strlen(perma)], sizeof(perma)-strlen(perma), ChrPtr(WC->CurRoom.name));
+
+       if (p != 0) {
+               snprintf(&perma[strlen(perma)], sizeof(perma)-strlen(perma), "?p=%d", p);
+       }
+
+       CtdlEncodeBase64(encoded_perma, perma, strlen(perma), 0);
+       StrBufAppendPrintf(Target, "/B64%s", encoded_perma);
+}
+
 
 void 
 InitModule_BLOGVIEWRENDERERS
@@ -250,4 +273,5 @@ InitModule_BLOGVIEWRENDERERS
                blogview_render,
                blogview_Cleanup
        );
+       RegisterNamespace("BLOG:PERMALINK", 0, 0, tmplput_blog_permalink, NULL, CTX_NONE);
 }