-<div id="sone">
+<div id="sone" class="<%ifnull ! currentSone>online<%else>offline<%/if>">
+
+ <div id="formPassword"><% formPassword|html></div>
<script src="javascript/jquery-1.4.2.js" language="javascript"></script>
<script src="javascript/sone.js" language="javascript"></script>
- <div id="sidebar">
-
- <div id="profile">
- <div class="picture"><img src="images/sone.png" width="76" height="53" alt="Sone Logo" /></div>
- <div class="nice-name profile-link"><a href="viewSone.html?sone=<% currentSone.id>"><% currentSone.niceName|html></a></div>
- <div><a href="editProfile.html"><%= View.Head.ProfileLink.Text|l10n|html></a></div>
+ <script language="javascript">
+ /* this initializes the status update input field. */
+ $(document).ready(function() {
+ getTranslation("WebInterface.DefaultText.StatusUpdate", function(text) {
+ registerInputTextareaSwap("#sone #update-status .status-input", text, "text", false, false);
+ })
+ });
+ </script>
+
+ <script language="javascript">
+ /* these functions are necessary for updating Sone statuses. */
+ $(document).ready(function() {
+ $("#sone .sone").each(function() {
+ watchSone($(this).find(".id").text(), $(this).hasClass("local"));
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* this initializes all reply input fields. */
+ $(document).ready(function() {
+ getTranslation("WebInterface.DefaultText.Reply", function(text) {
+ registerInputTextareaSwap("#sone input.reply-input", text, "text", false, false);
+ addCommentLinks();
+ })
+ });
+ </script>
+
+ <script language="javascript">
+ /* replaces all “post reply!” forms with AJAX. */
+ $(document).ready(function() {
+ $("#sone .create-reply button:submit").click(function() {
+ $(this.form).submit(function() {
+ return false;
+ });
+ inputField = $(this.form).find(":input:enabled").get(0);
+ postId = getPostId($(inputField));
+ text = $(inputField).val();
+ $(inputField).val("");
+ postReply(postId, text, function(success, error, replyId) {
+ if (success) {
+ getReply(replyId, function(soneId, soneName, replyTime, replyDisplayTime, text, html) {
+ newReply = $(html).insertBefore("#sone .post#" + postId + " .create-reply");
+ $("#sone .post#" + postId + " .create-reply").addClass("hidden");
+ getTranslation("WebInterface.Confirmation.DeleteReplyButton", function(deleteReplyText) {
+ enhanceDeleteReplyButton("#sone .post#" + postId + " .reply#" + replyId + " .delete button", replyId, deleteReplyText);
+ });
+ newReply.find(".status-line .like").submit(function() {
+ likeReply(getReplyId(this));
+ return false;
+ });
+ newReply.find(".status-line .unlike").submit(function() {
+ unlikeReply(getReplyId(this));
+ return false;
+ });
+ addCommentLink(postId, newReply);
+ });
+ } else {
+ alert(error);
+ }
+ });
+ return false;
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* replace all “delete” buttons with javascript. */
+ $(document).ready(function() {
+ 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);
+ });
+ });
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* hides all replies but the latest two. */
+ $(document).ready(function() {
+ 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, text);
+ $(allReplies[0]).before(clickToShowElement);
+ }
+ });
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* convert all “follow”, “unfollow”, “block”, and “unblock” links to something nicer. */
+ $(document).ready(function() {
+ $("#sone .follow").submit(function() {
+ var followElement = this;
+ $.getJSON("ajax/followSone.ajax", { "sone": getSoneId(this), "formPassword": getFormPassword() }, function() {
+ $(followElement).addClass("hidden");
+ $(followElement).parent().find(".unfollow").removeClass("hidden");
+ });
+ return false;
+ });
+ $("#sone .unfollow").submit(function() {
+ var unfollowElement = this;
+ $.getJSON("ajax/unfollowSone.ajax", { "sone": getSoneId(this), "formPassword": getFormPassword() }, function() {
+ $(unfollowElement).addClass("hidden");
+ $(unfollowElement).parent().find(".follow").removeClass("hidden");
+ });
+ return false;
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* convert all “like” buttons to javascript functions. */
+ $(document).ready(function() {
+ $("#sone .post > .inner-part > .status-line .like").submit(function() {
+ likePost(getPostId(this));
+ return false;
+ });
+ $("#sone .post > .inner-part > .status-line .unlike").submit(function() {
+ unlikePost(getPostId(this));
+ return false;
+ });
+ $("#sone .post .reply .status-line .like").submit(function() {
+ likeReply(getReplyId(this));
+ return false;
+ });
+ $("#sone .post .reply .status-line .unlike").submit(function() {
+ unlikeReply(getReplyId(this));
+ return false;
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* process all existing notifications, ajaxify dismiss buttons. */
+ $(document).ready(function() {
+ $("#sone #notification-area .notification").each(function() {
+ ajaxifyNotification($(this));
+ });
+ });
+ </script>
+
+ <script language="javascript">
+ /* activate notification polling. */
+ $(document).ready(function() {
+ setTimeout(getNotifications, 5000);
+ });
+ </script>
+
+ <div id="main">
+
+ <%if !webInterface.core.identityManager.connected>
+ <div id="plugin-warning">
+ <%= Warning.PluginNotConnected.Text|l10n|html|replace needle="{link}" replacement="<a href=\"/plugins/\">"|replace needle="{/link}" replacement="</a>">
+ </div>
+ <%/if>
+
+ <div id="notification-area">
+
+ <form id="notification-dismiss-template" class="hidden dismiss" action="dismissNotification.html" method="post">
+ <input type="hidden" name="formPassword" value="<% formPassword|html>" />
+ <input type="hidden" name="returnPage" value="<% request.uri|html>" />
+ <input type="hidden" name="notification" value="" />
+ <button type="submit"><%= Notification.Button.Dismiss|l10n|html></button>
+ </form>
+
+ <%foreach webInterface.notifications.all notification>
+ <div class="notification" id="<% notification.id|html>">
+ <%if notification.dismissable>
+ <form class="dismiss" action="dismissNotification.html" method="post">
+ <input type="hidden" name="formPassword" value="<% formPassword|html>" />
+ <input type="hidden" name="returnPage" value="<% request.uri|html>" />
+ <input type="hidden" name="notification" value="<% notification.id|html>" />
+ <button type="submit"><%= Notification.Button.Dismiss|l10n|html></button>
+ </form>
+ <%/if>
+ <% notification>
+ </div>
+ <%/foreach>
</div>
-
- <div id="links">
+
+ <div id="profile" class="<%ifnull currentSone>offline<%else>online<%/if>">
+ <a class="picture" href="index.html">
+ <%ifnull !currentSone>
+ <img src="/WoT/GetIdenticon?identity=<% currentSone.id|html>&width=80&height=80" width="80" height="80" alt="Profile Avatar" />
+ <%else>
+ <img src="images/sone.png" width="80" height="80" alt="Sone is offline" />
+ <%/if>
+ </a>
+ <%ifnull ! currentSone>
+ <div id="home-sone">
+ <% currentSone|store key=sone>
+ <%include include/viewSone.html>
+ <%include include/updateStatus.html>
+ </div>
+ <%/if>
</div>
-
- </div>
-
- <div id="main">