use latest svjatoslavcommons
[meviz.git] / src / main / java / eu / svjatoslav / meviz / htmlindexer / layouts / MixedLayout.java
index 345cd40..cf1285e 100755 (executable)
@@ -1,7 +1,7 @@
 /*
  * Meviz - Various tools collection to work with multimedia.
  * Copyright (C) 2012, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu
- * 
+ *
  * This program is free software; you can redistribute it and/or
  * modify it under the terms of version 2 of the GNU General Public License
  * as published by the Free Software Foundation.
@@ -9,23 +9,28 @@
 
 package eu.svjatoslav.meviz.htmlindexer.layouts;
 
+import java.io.IOException;
 import java.io.UnsupportedEncodingException;
 import java.util.List;
 
 import org.apache.log4j.Logger;
 
 import eu.svjatoslav.commons.file.FilePathParser;
-import eu.svjatoslav.commons.network.UrlParamEncoder;
 import eu.svjatoslav.meviz.htmlindexer.AbstractIndexer;
 import eu.svjatoslav.meviz.htmlindexer.Constants;
+import eu.svjatoslav.meviz.htmlindexer.IndexingContext;
 import eu.svjatoslav.meviz.htmlindexer.Layout;
+import eu.svjatoslav.meviz.htmlindexer.Utils;
 import eu.svjatoslav.meviz.htmlindexer.metadata.Dimension;
+import eu.svjatoslav.meviz.htmlindexer.metadata.DirectoryMetadata;
 import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.AbstractFile;
 import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.GeneralFile;
 import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.Picture;
 
 public class MixedLayout implements Layout {
 
+       public static final String encoding = "UTF-8";
+
        Logger logger = Logger.getLogger(MixedLayout.class);
 
        StringBuffer dirHtml = new StringBuffer();
@@ -34,175 +39,138 @@ public class MixedLayout implements Layout {
 
        String galleryTitle;
 
-       String[] path;
-
-       public static final String encoding = "UTF-8";
-
-       int currentColumn = 0;
-
-       int horizontalColumnsLimit = 2;
+       List<String> path;
 
        private AbstractIndexer indexer;
 
-       private String pathPrefix;
-
-       public void columnAdded() {
-               currentColumn++;
-               if (currentColumn > horizontalColumnsLimit) {
-
-                       currentColumn = 0;
-
-                       filesHtml.append("</TR>\n");
-               }
-       }
+       private IndexingContext indexingContext;
 
        @Override
-       public void enlistDirectory(final AbstractFile directory) {
+       public void enlistDirectory(final AbstractFile directory,
+                       final DirectoryMetadata parentDirectoryMetadata) {
                dirHtml.append("<TR>");
-               dirHtml.append("<TD><b><a href=\"" + indexer.getDirectoryUrl(directory)
-                               + "\"> ==&gt; " + directory.fileName + "</a></b></TD>");
+               dirHtml.append("<TD><b><a href=\""
+                               + indexer.getDirectoryUrl(directory, indexingContext)
+                               + "\"><h2> ==&gt; " + directory.fileName + "</h2></a></b></TD>");
                dirHtml.append("</TR>\n");
 
        }
 
        @Override
-       public void enlistFile(final AbstractFile file) {
-               finishRow();
+       public void enlistFile(final AbstractFile file,
+                       final DirectoryMetadata parentDirectoryMetadata) {
 
                final String fullFileName = file.fileName;
 
-               filesHtml.append("<TR>\n");
-               filesHtml.append("    <TD colspan=\""
-                               + String.valueOf(horizontalColumnsLimit) + "\"><a href=\""
-                               + UrlParamEncoder.encode(pathPrefix + fullFileName) + "\">"
-                               + fullFileName + "</a>\n");
+               filesHtml.append("<div style=\"clear: both;\"><a href=\""
+                               + indexingContext.getGlobalUrl()
+                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                               + fullFileName) + "\">" + fullFileName + "</a>\n");
                filesHtml.append("&nbsp;&nbsp;("
                                + FilePathParser.getFileSizeDescription(file.getFileLength())
-                               + ")</TD>\n");
-               filesHtml.append("</TR>\n");
+                               + ")</div><br/>\n");
 
        }
 
        @Override
-       public void enlistImage(final AbstractFile abstractFile) {
+       public void enlistImage(final Picture picture,
+                       final DirectoryMetadata parentDirectoryMetadata) {
                try {
+                       enlistImageInternal(picture);
+               } catch (final Exception e) {
+                       logger.error(
+                                       "Error generating thumbnails for image file: "
+                                                       + e.toString()
+                                                       + ", thumbnail generation skipped, enlisting as ordinary file instead.",
+                                       e);
+                       enlistFile(picture, parentDirectoryMetadata);
+               }
+       }
 
-                       final Picture picture = (Picture) abstractFile;
-
-                       final Dimension imageSize = picture.getDimensions();
-
-                       final List<Dimension> recommendedDimensions = Picture
-                                       .getThumbnailDimensions(imageSize);
-
-                       Dimension listingDimension = new Dimension(500, 500);
-
-                       if (listingDimension.width > imageSize.width)
-                               if (listingDimension.height > imageSize.height)
-                                       listingDimension = imageSize;
+       private String enlistImageDimensions(final Picture picture) {
+               final StringBuilder html = new StringBuilder();
+
+               final List<Dimension> recommendedDimensions = Picture
+                               .getThumbnailDimensions(picture.getDimensions());
+
+               int count = 0;
+               for (final Dimension dimension : recommendedDimensions) {
+                       count++;
+                       if (count > 1)
+                               html.append(", ");
+                       html.append("<a href=\""
+                                       + indexer.getThumbnailUrl(picture, dimension,
+                                                       indexingContext) + "\">");
+                       html.append(dimension.width + "x" + dimension.height);
+                       html.append("</a>");
+               }
 
-                       final String listingThumbnailPath = indexer.getThumbnailPath(
-                                       picture, listingDimension);
+               return html.toString();
+       }
 
-                       startcolumn();
+       private void enlistImageInternal(final Picture picture) {
 
-                       filesHtml.append("<TD><center><a href=\""
-                                       + UrlParamEncoder.encode(pathPrefix + picture.fileName)
-                                       + "\">\n");
+               filesHtml.append("<div style=\"float:left; margin: 10px;\">");
 
-                       filesHtml.append("<img border=\"0\" src=\""
-                                       + UrlParamEncoder.encode(listingThumbnailPath)
-                                       + "\"/></a>\n");
-                       filesHtml.append("<br/><b>"
-                                       + FilePathParser
-                                                       .getFileNameWithoutExtension(picture.fileName)
-                                       + "</b><br/>(");
+               // clickable image thumbnail
+               filesHtml.append("<a href=\""
+                               + indexingContext.getGlobalUrl()
+                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                               + picture.fileName) + "\">\n");
 
-                       int count = 0;
-                       for (final Dimension dimension : recommendedDimensions) {
-                               count++;
-                               if (count > 1)
-                                       filesHtml.append(", ");
-                               filesHtml.append("<a href=\""
-                                               + UrlParamEncoder.encode(indexer.getThumbnailPath(
-                                                               picture, dimension)) + "\">");
-                               filesHtml.append(dimension.width + "x" + dimension.height);
-                               filesHtml.append("</a>");
-                       }
+               filesHtml.append("<img border=\"0\" src=\""
+                               + getImageThumbnailUrl(picture) + "\"/></a><br/>\n");
 
-                       filesHtml.append(")</TD>\n");
+               // file name
+               filesHtml.append("<b>"
+                               + FilePathParser.getFileNameWithoutExtension(picture.fileName)
+                               + "</b><br/>");
 
-                       columnAdded();
+               // links to thumbnails of various sizes
+               filesHtml.append("(" + enlistImageDimensions(picture) + ")\n");
 
-               } catch (final Exception e) {
-                       logger.error(
-                                       "Error generating thumbnails for image file: "
-                                                       + e.toString()
-                                                       + ", thumbnail generation skipped, enlisting as ordinary file instead.",
-                                       e);
-                       enlistFile(abstractFile);
-               }
+               filesHtml.append("</div>");
        }
 
        /** {@inheritDoc} */
        @Override
-       public void enlistOgv(final AbstractFile abstractFile)
+       public void enlistOgv(final AbstractFile abstractFile,
+                       final DirectoryMetadata parentDirectoryMetadata)
                        throws UnsupportedEncodingException {
 
                final GeneralFile file = (GeneralFile) abstractFile;
 
-               finishRow();
+               filesHtml.append("<div style=\"margin: 30px; clear: both;\">");
 
+               // watchable video
                filesHtml
-                               .append("<TR style=\"background-color: #404040; text-align: center\">\n");
-               filesHtml.append("<TD style=\"text-align: center\" colspan=\""
-                               + String.valueOf(horizontalColumnsLimit) + "\">\n");
-
-               filesHtml.append("<video controls=\"controls\" tabindex=\"0\">\n");
+                               .append("<video preload=\"metadata\" controls=\"controls\" tabindex=\"0\">\n");
                filesHtml
                                .append("<source type=\"video/ogg\" codecs=\"theora, vorbis\" src=\""
-                                               + UrlParamEncoder.encode(pathPrefix + file.fileName)
-                                               + "\">\n");
+                                               + indexingContext.getGlobalUrl()
+                                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                                               + file.fileName) + "\">\n");
                filesHtml.append("</source>\n");
-
-               // if browser cannot play video directry, fall back to java Applet
-               filesHtml
-                               .append("<applet code=\"com.fluendo.player.Cortado.class\" archive=\"http://theora.org/cortado.jar\" width=\"800\" height=\"600\">\n");
-               filesHtml
-                               .append("    <param name=\"url\" value=\""
-                                               + UrlParamEncoder.encode(pathPrefix + file.fileName)
-                                               + "\"/>\n");
-               filesHtml.append("    <param name=\"keepAspect\" value=\"true\"/>\n");
-               filesHtml.append("    <param name=\"autoPlay\" value=\"false\"/>\n");
-               filesHtml.append("</applet>\n");
-
                filesHtml.append("</video>\n");
-
                filesHtml.append("<br/>\n");
 
+               // video title
                filesHtml
                                .append("Video: <b>"
                                                + FilePathParser
                                                                .getFileNameWithoutExtension(file.fileName)
                                                + "<b/>  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
-               filesHtml.append("<a href=\""
-                               + UrlParamEncoder.encode(pathPrefix + file.fileName)
-                               + "\">download as OGV</a>\n");
-
-               filesHtml.append("</TD></TR>\n");
 
-       }
+               // video download link
+               filesHtml.append("<a href=\""
+                               + indexingContext.getGlobalUrl()
+                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                               + file.fileName) + "\">download as OGV file</a>");
 
-       public void finishRow() {
+               filesHtml.append("</div>\n");
 
-               if (currentColumn == 0)
-                       return;
+               filesHtml.append("\n");
 
-               while (currentColumn <= horizontalColumnsLimit) {
-                       filesHtml.append("<TD></TD>");
-                       currentColumn++;
-               }
-               filesHtml.append("</TR>\n");
-               currentColumn = 0;
        }
 
        /** {@inheritDoc} */
@@ -211,74 +179,134 @@ public class MixedLayout implements Layout {
                return "";
        }
 
-       /** {@inheritDoc} */
+       /**
+        * {@inheritDoc}
+        *
+        * @throws IOException
+        */
        @Override
-       public String getHtml() {
+       public String getHtml(final boolean showTitle,
+                       final boolean doHtmlHeaderAndFooter,
+                       final DirectoryMetadata directory) {
 
                // assemble final page HTML
-               final StringBuffer finalHtml = new StringBuffer();
-
-               // page header
-               finalHtml.append("<HTML>\n");
-               finalHtml.append("<HEAD>\n");
-               finalHtml
-                               .append("    <meta HTTP-EQUIV=\"Content-Type\" CONTENT=\"text/html; charset=UTF-8\"/>\n");
-               finalHtml.append("</HEAD>\n");
-               finalHtml
-                               .append("<BODY bgcolor=\"#000000\" alink=\"#50ffff\" link=\"#50ffff\" vlink=\"#ff50ff\" text=\"#ffffff\">\n");
-               finalHtml.append("<!-- " + Constants.HTML_MAGIC_STRING + " -->\n");
-               finalHtml.append("<!-- " + Constants.HTML_MEMO + " -->\n");
-               finalHtml.append("<FONT color=\"#ffffff\">\n");
-               finalHtml.append("<CENTER><H1>" + galleryTitle + "</H1>\n");
-
-               finalHtml.append("<H2>");
-               for (final String p : path)
-                       finalHtml.append(" / " + p);
-               finalHtml.append("</H2></CENTER>\n");
+               final StringBuffer html = new StringBuffer();
+
+               if (doHtmlHeaderAndFooter) {
+                       // page header
+                       html.append("<HTML>\n");
+                       html.append("<HEAD>\n");
+                       html.append("    <meta HTTP-EQUIV=\"Content-Type\" CONTENT=\"text/html; charset=UTF-8\"/>\n");
+                       html.append("</HEAD>\n");
+                       html.append("<BODY bgcolor=\"#000000\" alink=\"#50ffff\" link=\"#50ffff\" vlink=\"#ff50ff\" text=\"#ffffff\">\n");
+                       html.append("<!-- " + Constants.HTML_MAGIC_STRING + " -->\n");
+                       html.append("<!-- " + Constants.HTML_MEMO + " -->\n");
+                       html.append("<font color=\"#ffffff\">\n");
+               }
 
-               // append directory listing
-               finalHtml.append("<TABLE>\n");
+               if (showTitle)
+                       html.append("<CENTER><H1>" + galleryTitle + "</H1></CENTER>\n");
 
-               if (path.length > 0) {
-                       finalHtml.append("<TR>");
-                       finalHtml
-                                       .append("<TD><b><a href=\"../index.html\"> &lt;== ..</a></b></TD>");
-                       finalHtml.append("</TR>\n");
-               }
+               html.append(showCurrentPath());
+               html.append(listDirectories());
+               html.append(directory.getHeaderMevizMetadataHtml());
+               html.append(filesHtml.toString());
 
-               finalHtml.append(dirHtml.toString());
-               finalHtml.append("\n<TR><TD><br></TD></TR>\n");
-               finalHtml.append("</TABLE>\n");
+               if (doHtmlHeaderAndFooter)
+                       html.append("</font></BODY></HTML>\n");
 
-               // append file listing
+               return html.toString();
+       }
 
-               finishRow();
-               finalHtml.append("<TABLE width=\"1100\">\n");
-               finalHtml.append(filesHtml.toString());
-               finalHtml.append("\n</TABLE>\n");
+       private String getImageThumbnailUrl(final Picture picture) {
+               final Dimension imageSize = picture.getDimensions();
 
-               finalHtml.append("</font></BODY></HTML>\n");
+               Dimension listingDimension = new Dimension(1500, 450);
 
-               return finalHtml.toString();
+               if (listingDimension.width > imageSize.width)
+                       if (listingDimension.height > imageSize.height)
+                               listingDimension = imageSize;
+
+               return indexer.getThumbnailUrl(picture, listingDimension,
+                               indexingContext);
        }
 
        @Override
-       public void init(final String galleryTitle, final String[] path,
-                       final AbstractIndexer indexer, final String pathPrefix) {
+       public void init(final String galleryTitle, final List<String> path,
+                       final AbstractIndexer indexer, final IndexingContext indexingContext) {
+
                this.indexer = indexer;
                this.galleryTitle = galleryTitle;
                this.path = path;
-               this.pathPrefix = pathPrefix;
+               this.indexingContext = indexingContext;
 
                dirHtml = new StringBuffer();
                filesHtml = new StringBuffer();
        }
 
-       public void startcolumn() {
-               if (currentColumn == 0) {
-                       filesHtml.append("<TR>");
-                       currentColumn = 1;
+       private String listDirectories() {
+               final StringBuilder html = new StringBuilder();
+               html.append("<TABLE>\n");
+
+               if (path.size() > 0) {
+                       html.append("<TR>");
+                       html.append("<TD><b><a href=\""
+                                       + indexer.getParentDirectoryUrl(indexingContext)
+                                       + "\"><h2> &lt;== parent directory</h2></a></b></TD>");
+                       html.append("</TR>\n");
                }
+
+               html.append(dirHtml.toString());
+               html.append("\n<TR><TD><br></TD></TR>\n");
+               html.append("</TABLE>\n");
+
+               return html.toString();
+       }
+
+       private String showCurrentPath() {
+               final StringBuilder html = new StringBuilder();
+               html.append("<CENTER><H2>");
+               for (final String p : path)
+                       html.append(" / " + p);
+               html.append("</H2></CENTER>\n");
+
+               return html.toString();
        }
 
+       @Override
+       public void enlistWebm(AbstractFile abstractFile,
+                       DirectoryMetadata directory) {
+               final GeneralFile file = (GeneralFile) abstractFile;
+
+               filesHtml.append("<div style=\"margin: 30px; clear: both;\">");
+
+               // watchable video
+
+               String fileUrl = indexingContext.getGlobalUrl()
+                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                               + file.fileName);
+
+               filesHtml.append("<video controls>\n");
+               filesHtml.append("  <source src=\"" + fileUrl
+                               + "\" type='video/webm;codecs=\"vp8, opus\"'/>\n");
+               filesHtml.append("</video>\n");
+               filesHtml.append("<br/>\n");
+
+               // video title
+               filesHtml
+                               .append("Video: <b>"
+                                               + FilePathParser
+                                                               .getFileNameWithoutExtension(file.fileName)
+                                               + "<b/>  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
+
+               // video download link
+               filesHtml.append("<a href=\""
+                               + indexingContext.getGlobalUrl()
+                               + Utils.urlEncode(indexingContext.getLocalUrl() + "/"
+                                               + file.fileName) + "\">download as WebM file</a>");
+
+               filesHtml.append("</div>\n");
+
+               filesHtml.append("\n");
+       }
 }