diff options
author | Ugnich Anton | 2013-10-24 01:24:19 +0700 |
---|---|---|
committer | Ugnich Anton | 2013-10-24 01:24:19 +0700 |
commit | 19dbb5c44b3c32b894ed2c3c83d6c67aa69e7c17 (patch) | |
tree | 29bfc3ebc1f5d098143355eb2a17aff560378165 | |
parent | 1ff9fecd9342970bdc4a835ee5a57a5f27cdd206 (diff) |
Home + Discover
-rw-r--r-- | src/java/Global.properties | 2 | ||||
-rw-r--r-- | src/java/Global_ru.properties | 2 | ||||
-rw-r--r-- | src/java/com/juick/http/www/Discover.java (renamed from src/java/com/juick/http/www/Blogs.java) | 97 | ||||
-rw-r--r-- | src/java/com/juick/http/www/Home.java | 121 | ||||
-rw-r--r-- | src/java/com/juick/http/www/Main.java | 21 | ||||
-rw-r--r-- | src/java/com/juick/http/www/PageTemplates.java | 17 | ||||
-rw-r--r-- | web/style3.css | 22 |
7 files changed, 166 insertions, 116 deletions
diff --git a/src/java/Global.properties b/src/java/Global.properties index 706e258f..f823d7d2 100644 --- a/src/java/Global.properties +++ b/src/java/Global.properties @@ -1,6 +1,8 @@ # To change this template, choose Tools | Templates # and open the template in the editor. +Home=Home +Discover=Discover Search=Search Blogs=Blogs Chats=Chats diff --git a/src/java/Global_ru.properties b/src/java/Global_ru.properties index a7c7e9d5..2df1f883 100644 --- a/src/java/Global_ru.properties +++ b/src/java/Global_ru.properties @@ -1,6 +1,8 @@ # To change this template, choose Tools | Templates # and open the template in the editor. +Home=\u0414\u043e\u043c\u043e\u0439 +Discover=\u041e\u0431\u0437\u043e\u0440 Search=\u041f\u043e\u0438\u0441\u043a Blogs=\u0411\u043b\u043e\u0433\u0438 Chats=\u0427\u0430\u0442\u044b diff --git a/src/java/com/juick/http/www/Blogs.java b/src/java/com/juick/http/www/Discover.java index cf58ed4f..b76a1d77 100644 --- a/src/java/com/juick/http/www/Blogs.java +++ b/src/java/com/juick/http/www/Discover.java @@ -40,27 +40,13 @@ import javax.servlet.http.HttpServletResponse; * * @author Ugnich Anton */ -public class Blogs { - - protected void doGet(Connection sql, Connection sqlSearch, HttpServletRequest request, HttpServletResponse response, com.juick.User visitor) throws ServletException, IOException { - String paramTagStrQuery = request.getParameter("tag"); - if (paramTagStrQuery != null) { - String url = "/tag/" + URLEncoder.encode(paramTagStrQuery, "UTF-8"); - String paramBeforeStr = request.getParameter("before"); - if (paramBeforeStr != null) { - url += "?before=" + paramBeforeStr; - } - Utils.sendPermanentRedirect(response, url); - } +public class Discover { + protected void doGet(Connection sql, Connection sqlSearch, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { + com.juick.User visitor = Utils.getVisitorUser(sql, request); Locale locale = request.getLocale(); ResourceBundle rb = ResourceBundle.getBundle("Blogs", locale); - String title; - ArrayList<Integer> mids; - - String paramShow = request.getParameter("show"); - String requesturi = request.getRequestURI(); int paramTag = 0; @@ -72,8 +58,6 @@ public class Blogs { response.sendError(404); return; } - } else if (requesturi.startsWith("/places/")) { - //TODO перенести сюда блок, который страницей ниже } int paramBefore = 0; @@ -90,9 +74,12 @@ public class Blogs { paramSearch = null; } - com.juick.Place place = null; int visitor_uid = visitor != null ? visitor.UID : 0; + String title; + ArrayList<Integer> mids; + + String paramShow = request.getParameter("show"); if (paramShow == null) { if (paramTag > 0) { title = "*" + Utils.encodeHTML(paramTagStr); @@ -100,59 +87,10 @@ public class Blogs { } else if (paramSearch != null) { title = rb.getString("Search") + ": " + Utils.encodeHTML(paramSearch); mids = MessagesQueries.getSearch(sql, sqlSearch, Utils.encodeSphinx(paramSearch), paramBefore); - } else if (requesturi.matches("^\\/places\\/\\d+$")) { - int place_id = 0; - try { - place_id = Integer.parseInt(requesturi.substring(8)); - } catch (NumberFormatException e) { - } - place = com.juick.server.PlacesQueries.getPlace(sql, place_id); - if (place != null) { - title = place.name; - mids = MessagesQueries.getPlace(sql, place_id, visitor_uid, paramBefore); - } else { - response.sendError(404); - return; - } } else { title = rb.getString("Last messages"); mids = MessagesQueries.getAll(sql, visitor_uid, paramBefore); } - } else if (paramShow.equals("my")) { - if (visitor != null) { - title = rb.getString("My feed"); - mids = MessagesQueries.getMyFeed(sql, visitor.UID, paramBefore); - } else { - response.sendError(404); - return; - } - } else if (paramShow.equals("private")) { - if (visitor != null) { - title = rb.getString("Private"); - mids = MessagesQueries.getPrivate(sql, visitor.UID, paramBefore); - } else { - response.sendError(404); - return; - } - } else if (paramShow.equals("discuss")) { - if (visitor != null) { - title = rb.getString("Discussions"); - mids = MessagesQueries.getDiscussions(sql, visitor.UID, paramBefore); - } else { - response.sendError(404); - return; - } - } else if (paramShow.equals("recommended")) { - if (visitor != null) { - title = rb.getString("Recommended"); - mids = MessagesQueries.getRecommended(sql, visitor.UID, paramBefore); - } else { - response.sendError(404); - return; - } - } else if (paramShow.equals("top")) { - title = rb.getString("Popular"); - mids = MessagesQueries.getPopular(sql, paramBefore); } else if (paramShow.equals("photos")) { title = rb.getString("With photos"); mids = MessagesQueries.getPhotos(sql, visitor_uid, paramBefore); @@ -171,10 +109,6 @@ public class Blogs { out.println("<div id=\"wrapper\">"); out.println("<div id=\"content\">"); - if (place != null) { - out.println("<div id=\"geomap\"><img src=\"http://maps.google.com/maps/api/staticmap?center=" + place.lat + "," + place.lon + "&markers=color:orange|" + place.lat + "," + place.lon + "&zoom=14&size=600x300&maptype=hybrid&sensor=false\" width=\"600\" height=\"300\" alt=\"Map\"/></div>"); - } - if (mids.size() > 0) { out.println("<ul>"); PageTemplates.printMessages(out, sql, null, mids, visitor, locale, visitor == null ? 2 : 3); @@ -197,24 +131,11 @@ public class Blogs { out.println("<div id=\"column\" class=\"abs\">"); - if (visitor != null) { - out.println(" <ul>"); - out.println(" <li><a href=\"/?show=my\">" + rb.getString("My feed") + "</a></li>"); - out.println(" <li><a href=\"/?show=private\">" + rb.getString("Private") + "</a></li>"); - out.println(" <li><a href=\"/?show=discuss\">" + rb.getString("Discussions") + "</a></li>"); - out.println(" <li><a href=\"/?show=recommended\">" + rb.getString("Recommended") + "</a></li>"); - out.println(" </ul>"); - out.println(" <hr/>"); - } out.println(" <ul>"); - out.println(" <li><a href=\"/\">" + rb.getString("All messages") + "</a></li>"); - out.println(" <li><a href=\"/?show=top\">" + rb.getString("Popular") + "</a></li>"); - out.println(" <li><a href=\"/?show=photos\">" + rb.getString("With photos") + "</a></li>"); + out.println(" <li><a href=\"/discover\">" + rb.getString("All messages") + "</a></li>"); + out.println(" <li><a href=\"/discover?show=photos\">" + rb.getString("With photos") + "</a></li>"); out.println(" </ul>"); out.println(" <hr/>"); - out.println(" <form action=\"/\">"); - out.println(" <p><input type=\"text\" name=\"search\" class=\"inp\" placeholder=\"" + rb.getString("Search") + "\"/></p>"); - out.println(" </form>"); out.println(" <p>" + getTags(sql, 45) + "</p>"); out.println("</div>"); diff --git a/src/java/com/juick/http/www/Home.java b/src/java/com/juick/http/www/Home.java new file mode 100644 index 00000000..b9009a80 --- /dev/null +++ b/src/java/com/juick/http/www/Home.java @@ -0,0 +1,121 @@ +/* + * Juick + * Copyright (C) 2008-2011, Ugnich Anton + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ +package com.juick.http.www; + +import com.juick.server.MessagesQueries; +import java.io.IOException; +import java.io.PrintWriter; +import java.sql.Connection; +import java.util.ArrayList; +import java.util.Locale; +import java.util.ResourceBundle; +import javax.servlet.ServletException; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + +/** + * + * @author Ugnich Anton + */ +public class Home { + + protected void doGet(Connection sql, Connection sqlSearch, HttpServletRequest request, HttpServletResponse response, com.juick.User visitor) throws ServletException, IOException { + Locale locale = request.getLocale(); + ResourceBundle rb = ResourceBundle.getBundle("Blogs", locale); + + int paramBefore = 0; + String paramBeforeStr = request.getParameter("before"); + if (paramBeforeStr != null) { + try { + paramBefore = Integer.parseInt(paramBeforeStr); + } catch (NumberFormatException e) { + } + } + + String title; + ArrayList<Integer> mids; + + String paramShow = request.getParameter("show"); + if (paramShow == null || paramShow.equals("my")) { + title = rb.getString("My feed"); + mids = MessagesQueries.getMyFeed(sql, visitor.UID, paramBefore); + } else if (paramShow.equals("private")) { + title = rb.getString("Private"); + mids = MessagesQueries.getPrivate(sql, visitor.UID, paramBefore); + } else if (paramShow.equals("discuss")) { + title = rb.getString("Discussions"); + mids = MessagesQueries.getDiscussions(sql, visitor.UID, paramBefore); + } else if (paramShow.equals("recommended")) { + title = rb.getString("Recommended"); + mids = MessagesQueries.getRecommended(sql, visitor.UID, paramBefore); + } else if (paramShow.equals("top")) { + title = rb.getString("Popular"); + mids = MessagesQueries.getPopular(sql, paramBefore); + } else { + response.sendError(404); + return; + } + + response.setContentType("text/html; charset=UTF-8"); + PrintWriter out = response.getWriter(); + try { + PageTemplates.pageHead(out, title, null); + PageTemplates.pageNavigation(out, locale, visitor, null); + + out.println("<div id=\"topwrapper\">"); + out.println("<div id=\"wrapper\">"); + out.println("<div id=\"content\">"); + + if (mids.size() > 0) { + out.println("<ul>"); + PageTemplates.printMessages(out, sql, null, mids, visitor, locale, visitor == null ? 2 : 3); + out.println("</ul>"); + } + + if (mids.size() == 20) { + String nextpage = "?before=" + mids.get(mids.size() - 1); + if (paramShow != null) { + nextpage += "&show=" + paramShow; + } + out.println("<p class=\"page\"><a href=\"" + nextpage + "\">Older →</a></p>"); + } + PageTemplates.pageFooter(request, out, locale, visitor, true); + out.println("</div>"); + out.println("</div>"); // wrapper + + + out.println("<div id=\"column\" class=\"abs\">"); + out.println(" <ul>"); + out.println(" <li><a href=\"/?show=my\">" + rb.getString("My feed") + "</a></li>"); + out.println(" <li><a href=\"/?show=private\">" + rb.getString("Private") + "</a></li>"); + out.println(" <li><a href=\"/?show=discuss\">" + rb.getString("Discussions") + "</a></li>"); + out.println(" <li><a href=\"/?show=recommended\">" + rb.getString("Recommended") + "</a></li>"); + out.println(" <li class=\"margtop\"><a href=\"/?show=top\">" + rb.getString("Popular") + "</a></li>"); + out.println(" </ul>"); + out.println(" <hr/>"); + out.println("</div>"); + + out.println("</div>"); // topwrapper + + PageTemplates.pageDialogTemplate(out, locale); + PageTemplates.pageEnd(out); + } finally { + out.close(); + } + } +} diff --git a/src/java/com/juick/http/www/Main.java b/src/java/com/juick/http/www/Main.java index 4c6e310b..8b760e44 100644 --- a/src/java/com/juick/http/www/Main.java +++ b/src/java/com/juick/http/www/Main.java @@ -41,7 +41,8 @@ public class Main extends HttpServlet { Connection sql; Connection sqlSearch; Stream xmpp; - Blogs blogs = new Blogs(); + Home home = new Home(); + Discover discover = new Discover(); Login login = new Login(); Help help = new Help(); User pagesUser = new User(); @@ -111,14 +112,10 @@ public class Main extends HttpServlet { if (uri.equals("/")) { com.juick.User visitor = Utils.getVisitorUser(sql, request); - if (request.getQueryString() == null) { - if (visitor == null) { - login.doGetLoginForm(sql, request, response); - } else { - blogs.doGet(sql, sqlSearch, request, response, visitor); - } + if (visitor == null) { + login.doGetLoginForm(sql, request, response); } else { - blogs.doGet(sql, sqlSearch, request, response, visitor); + home.doGet(sql, sqlSearch, request, response, visitor); } } else if (uri.equals("/post")) { com.juick.User visitor = Utils.getVisitorUser(sql, request); @@ -147,12 +144,10 @@ public class Main extends HttpServlet { help.doRedirectToHelpIndex(sql, request, response); } else if (uri.startsWith("/help/")) { help.doGetHelp(sql, request, response); + } else if (uri.equals("/discover")) { + discover.doGet(sql, sqlSearch, request, response); } else if (uri.startsWith("/tag/")) { - com.juick.User visitor = Utils.getVisitorUser(sql, request); - blogs.doGet(sql, sqlSearch, request, response, visitor); - } else if (uri.startsWith("/places/")) { - com.juick.User visitor = Utils.getVisitorUser(sql, request); - blogs.doGet(sql, sqlSearch, request, response, visitor); + discover.doGet(sql, sqlSearch, request, response); } else if (uri.matches("^/\\d+$")) { String strID = request.getRequestURI().substring(1); int mid = 0; diff --git a/src/java/com/juick/http/www/PageTemplates.java b/src/java/com/juick/http/www/PageTemplates.java index fc9bb1d5..0c98f26f 100644 --- a/src/java/com/juick/http/www/PageTemplates.java +++ b/src/java/com/juick/http/www/PageTemplates.java @@ -50,7 +50,7 @@ public class PageTemplates { out.println("<!DOCTYPE html>"); out.print("<html>"); out.print("<head>"); - out.print("<link rel=\"stylesheet\" href=\"/style.2013102203.css\"/>"); + out.print("<link rel=\"stylesheet\" href=\"/style.2013102401.css\"/>"); out.print("<script type=\"text/javascript\" src=\"//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js\" defer=\"defer\"></script>"); out.print("<script type=\"text/javascript\" src=\"//ajax.googleapis.com/ajax/libs/swfobject/2.2/swfobject.js\" defer=\"defer\" async=\"async\"></script>"); out.print("<script type=\"text/javascript\" src=\"/scripts.2013072200.js\" defer=\"defer\"></script>"); @@ -69,14 +69,19 @@ public class PageTemplates { ResourceBundle rb = ResourceBundle.getBundle("Global", loc); out.println("<div id=\"hwrapper\">"); out.println("<ul id=\"header\">"); - out.println(" <li id=\"logo\"><a href=\"" + (user != null ? "/?show=my" : "/") + "\"><div class=\"head-ico\" id=\"hi-logo\"></div></a></li>"); - /* - out.print(" <li id=\"search\"><form action=\"/\"><input type=\"text\" name=\"search\" class=\"text\" placeholder=\"" + rb.getString("Search") + "\""); + if (user != null) { + out.println(" <li><a href=\"/\"><div class=\"head-ico\" id=\"hi-home\"></div><label>" + rb.getString("Home") + "</label></a></li>"); + out.println(" <li><a href=\"/discover\"><div class=\"head-ico\" id=\"hi-discover\"></div><label>" + rb.getString("Discover") + "</label></a></li>"); + } else { + out.println(" <li><a href=\"/\"><div class=\"head-ico\" id=\"hi-logo\"></div></a></li>"); + } + + out.print(" <li id=\"search\"><form action=\"/discover\"><input type=\"text\" name=\"search\" class=\"text\" placeholder=\"" + rb.getString("Search") + "\""); if (search != null) { - out.print(" value=\"" + Utils.encodeHTML(search) + "\""); + out.print(" value=\"" + Utils.encodeHTML(search) + "\""); } out.println("/></form></li>"); - */ + if (user != null) { out.println(" <li class=\"right\"><a href=\"/logout\"><div class=\"head-ico\" id=\"hi-logout\"></div></a></li>"); out.println(" <li class=\"right\"><a href=\"/settings\"><div class=\"head-ico\" id=\"hi-settings\"></div></a></li>"); diff --git a/web/style3.css b/web/style3.css index 8a59f4ee..cd66bc20 100644 --- a/web/style3.css +++ b/web/style3.css @@ -9,7 +9,8 @@ hr { height: 1px; background: #CCC; margin: 10px 0; } pre { white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word; } .u { text-decoration: underline; } -#header, #topwrapper { width: 860px; } +#header { width: 880px; } +#topwrapper { width: 860px; } #content, #footer { width: 600px; } #header, #topwrapper, #footer { margin: 0 auto; } #content { margin: 15px 0 0 260px; } @@ -18,19 +19,21 @@ pre { white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; #hwrapper { float: left; width: 100%; background: #333; padding-bottom: 2px; } #header li { float: left; line-height: 48px; } -#header .text { margin-left: 15px; width: 285px; padding: 4px; border: none; background: #EEE; } +#header .text { margin-left: 15px; width: 185px; padding: 4px; border: none; background: #EEE; } #header>.right { float: right; } -#header a { display: block; font-size: 18px; padding: 0 10px; color: #AAA; } +#header a { display: block; font-size: 18px; padding: 0 10px; color: #999; } #header .wide { padding: 0 20px; } #header img { max-width: 32px; max-height: 32px; vertical-align: middle; margin-right: 4px; } #header label { cursor: pointer; } .head-ico { width: 32px; height: 32px; display: inline-block; vertical-align: middle; margin-bottom: 2px; - background: url("") no-repeat; } + background: url("") no-repeat; } #hi-logo { width: 110px; margin: 0 50px; } -#hi-post { background-position: -142px 0; margin: 0 5px 0 -5px; } -#hi-settings { background-position: -174px 0; } -#hi-logout { background-position: -206px 0; } +#hi-home { background-position: -142px 0; } +#hi-discover { background-position: -174px 0; } +#hi-post { background-position: -206px 0; margin: 0 5px 0 -5px; } +#hi-settings { background-position: -238px 0; } +#hi-logout { background-position: -270px 0; } /********/ @@ -93,6 +96,7 @@ blockquote { border-left: 1px dashed #CCC; margin: 10px 0 10px 10px; padding-lef #column { width: 230px; top: 0; padding-top: 10px; overflow: hidden; } #column ul, #column p, #column hr { margin: 10px 0; } #column li { margin: 6px 0; } +#column .margtop { margin-top: 15px; } #column p { font-size: small; line-height: 140%; } #column .inp { width: 222px; padding: 3px; border: 1px solid #CCC; border-radius: 3px; background: #F5F5E9; } #ctitle { font-size: 14pt; } @@ -130,7 +134,7 @@ blockquote { border-left: 1px dashed #CCC; margin: 10px 0 10px 10px; padding-lef #topwrapper { margin-top: 3em; } #header li { line-height: 42px; } - #search { position: absolute; left: 42px; right: 222px; min-width: 55px; } + #search { position: absolute; left: 84px; right: 222px; min-width: 55px; } #header a { padding: 0 7px; } #header .text { width: 100%; } #header label { display: none; } @@ -153,4 +157,4 @@ blockquote { border-left: 1px dashed #CCC; margin: 10px 0 10px 10px; padding-lef .fix,.abs { position: static; } #column { clear: both; margin: 0 3%; width: 44%; float: left; } #rcol { float: left; width: 44%; margin: 20px 3% 0 3%; } -}
\ No newline at end of file +} |