Add notifications for new posts and replies.
[Sone.git] / src / main / resources / templates / include / head.html
index 8f7aa48..deb020c 100644 (file)
@@ -8,7 +8,9 @@
        <script language="javascript">
                /* this initializes the status update input field. */
                $(document).ready(function() {
-                       registerInputTextareaSwap("#sone #update-status .status-input", "WebInterface.DefaultText.StatusUpdate", "text", false, false);
+                       getTranslation("WebInterface.DefaultText.StatusUpdate", function(text) {
+                               registerInputTextareaSwap("#sone #update-status .status-input", text, "text", false, false);
+                       })
                });
        </script>
 
        <script language="javascript">
                /* this initializes all reply input fields. */
                $(document).ready(function() {
-                       registerInputTextareaSwap("#sone input.reply-input", "WebInterface.DefaultText.Reply", "text", false, false);
-                       addCommentLinks();
+                       getTranslation("WebInterface.DefaultText.Reply", function(text) {
+                               registerInputTextareaSwap("#sone input.reply-input", text, "text", false, false);
+                               addCommentLinks();
+                       })
                });
        </script>
 
        <script language="javascript">
                /* replace all “delete” buttons with javascript. */
                $(document).ready(function() {
-                       $("#sone .post").each(function() {
-                               postId = $(this).attr("id");
-                               enhanceDeletePostButton("#sone .post#" + postId + " > .inner-part > .status-line .delete button", postId);
-                               (function(postId) {
-                                       $("#sone .post#" + postId + " .reply").each(function() {
-                                               replyId = $(this).attr("id");
-                                               (function(postId, reply, replyId) {
-                                                       reply.find(".delete button").each(function() {
-                                                               enhanceDeleteReplyButton("#sone .post#" + postId + " .reply#" + replyId + " .delete button", replyId);
-                                                       })
-                                               })(postId, $(this), replyId);
+                       getTranslation("WebInterface.Confirmation.DeletePostButton", function(text) {
+                               deletePostText = text;
+                               getTranslation("WebInterface.Confirmation.DeleteReplyButton", function(text) {
+                                       deleteReplyText = text;
+                                       $("#sone .post").each(function() {
+                                               postId = $(this).attr("id");
+                                               enhanceDeletePostButton("#sone .post#" + postId + " > .inner-part > .status-line .delete button", postId, deletePostText);
+                                               (function(postId) {
+                                                       $("#sone .post#" + postId + " .reply").each(function() {
+                                                               replyId = $(this).attr("id");
+                                                               (function(postId, reply, replyId) {
+                                                                       reply.find(".delete button").each(function() {
+                                                                               enhanceDeleteReplyButton("#sone .post#" + postId + " .reply#" + replyId + " .delete button", replyId, deleteReplyText);
+                                                                       })
+                                                               })(postId, $(this), replyId);
+                                                       });
+                                               })(postId);
                                        });
-                               })(postId);
+                               });
                        });
                });
        </script>
        <script language="javascript">
                /* hides all replies but the latest two. */
                $(document).ready(function() {
-                       $("#sone .post .replies").each(function() {
-                               allReplies = $(this).find(".reply");
-                               if (allReplies.length > 2) {
-                                       for (replyIndex = 0; replyIndex < (allReplies.length - 2); ++replyIndex) {
-                                               $(allReplies[replyIndex]).addClass("hidden");
-                                       }
-                                       clickToShowElement = $("<div></div>").addClass("click-to-show");
-                                       (function(clickToShowElement, allReplies) {
-                                               getTranslation("WebInterface.ClickToShow.Replies", function(text) {
+                       getTranslation("WebInterface.ClickToShow.Replies", function(text) {
+                               $("#sone .post .replies").each(function() {
+                                       allReplies = $(this).find(".reply");
+                                       if (allReplies.length > 2) {
+                                               newHidden = false;
+                                               for (replyIndex = 0; replyIndex < (allReplies.length - 2); ++replyIndex) {
+                                                       $(allReplies[replyIndex]).addClass("hidden");
+                                                       newHidden |= $(allReplies[replyIndex]).hasClass("new");
+                                               }
+                                               clickToShowElement = $("<div></div>").addClass("click-to-show");
+                                               if (newHidden) {
+                                                       clickToShowElement.addClass("new");
+                                               }
+                                               (function(clickToShowElement, allReplies, text) {
                                                        clickToShowElement.text(text);
-                                               });
-                                               clickToShowElement.click(function() {
-                                                       allReplies.removeClass("hidden");
-                                                       clickToShowElement.addClass("hidden");
-                                               });
-                                       })(clickToShowElement, allReplies);
-                                       $(allReplies[0]).before(clickToShowElement);
-                               }
+                                                       clickToShowElement.click(function() {
+                                                               allReplies.removeClass("hidden");
+                                                               clickToShowElement.addClass("hidden");
+                                                       });
+                                               })(clickToShowElement, allReplies, text);
+                                               $(allReplies[0]).before(clickToShowElement);
+                                       }
+                               });
                        });
                });
        </script>
                });
        </script>
 
+       <script language="javascript">
+               /* display large notification about new replies and posts. */
+               $(document).ready(function() {
+                       newPostCount = $("#sone .post.new").length;
+                       newReplyCount = $("#sone .reply.new").length;
+                       if ((newPostCount + newReplyCount) == 0) {
+                               return;
+                       }
+                       if (newPostCount > 0) {
+                               postNotification = $("<div></div>").addClass("notification");
+                               getTranslation("WebInterface.Notification.NewPostCount", function(text) {
+                                       postNotification.append($("<div></div>").text(text)).append($("<div></div>").addClass("post-count").text(newPostCount));
+                               });
+                               postNotification.appendTo("#sone #notification-area");
+                       }
+                       if (newReplyCount > 0) {
+                               replyNotification = $("<div></div>").addClass("notification");
+                               getTranslation("WebInterface.Notification.NewReplyCount", function(text) {
+                                       replyNotification.append($("<div></div>").text(text)).append($("<div></div>").addClass("post-count").text(newReplyCount));
+                               });
+                               replyNotification.appendTo("#sone #notification-area");
+                       }
+               });
+       </script>
+
        <div id="main">
 
                <%if !webInterface.core.identityManager.connected>
                        </div>
                <%/if>
 
+               <div id="notification-area"></div>
+
                <div id="profile" class="<%ifnull currentSone>offline<%else>online<%/if>">
                        <a class="picture" href="index.html">
                                <%ifnull !currentSone>