X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Fhtmlindexer%2Flayouts%2FMixedLayout.java;h=986fe339d570e288025f8871ecb9c198f097b3de;hb=5d6cdd532d23ef8a0e8aa379e6170d382740717e;hp=345cd40a6b5cd3ff476a9c0c4db86cf2b580dbd0;hpb=bc5af7e323346f34d0e551b8be67e458d43271e6;p=meviz.git
diff --git a/src/main/java/eu/svjatoslav/meviz/htmlindexer/layouts/MixedLayout.java b/src/main/java/eu/svjatoslav/meviz/htmlindexer/layouts/MixedLayout.java
index 345cd40..986fe33 100755
--- a/src/main/java/eu/svjatoslav/meviz/htmlindexer/layouts/MixedLayout.java
+++ b/src/main/java/eu/svjatoslav/meviz/htmlindexer/layouts/MixedLayout.java
@@ -1,284 +1,271 @@
/*
- * 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.
+ * Meviz - Various tools collection to work with multimedia. Author: Svjatoslav Agejenko.
+ * This project is released under Creative Commons Zero (CC0) license.
*/
-package eu.svjatoslav.meviz.htmlindexer.layouts;
-
-import java.io.UnsupportedEncodingException;
-import java.util.List;
-import org.apache.log4j.Logger;
+package eu.svjatoslav.meviz.htmlindexer.layouts;
import eu.svjatoslav.commons.file.FilePathParser;
-import eu.svjatoslav.commons.network.UrlParamEncoder;
-import eu.svjatoslav.meviz.htmlindexer.AbstractIndexer;
+import eu.svjatoslav.meviz.htmlindexer.indexer.AbstractIndexer;
import eu.svjatoslav.meviz.htmlindexer.Constants;
-import eu.svjatoslav.meviz.htmlindexer.Layout;
+import eu.svjatoslav.meviz.htmlindexer.IndexingContext;
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;
+import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.Video;
+import org.apache.log4j.Logger;
-public class MixedLayout implements Layout {
-
- Logger logger = Logger.getLogger(MixedLayout.class);
-
- StringBuffer dirHtml = new StringBuffer();
-
- StringBuffer filesHtml = new StringBuffer();
-
- String galleryTitle;
-
- String[] path;
-
- public static final String encoding = "UTF-8";
-
- int currentColumn = 0;
-
- int horizontalColumnsLimit = 2;
-
- private AbstractIndexer indexer;
-
- private String pathPrefix;
-
- public void columnAdded() {
- currentColumn++;
- if (currentColumn > horizontalColumnsLimit) {
-
- currentColumn = 0;
-
- filesHtml.append("\n");
- }
- }
+import java.io.IOException;
+import java.util.List;
- @Override
- public void enlistDirectory(final AbstractFile directory) {
- dirHtml.append("
");
- dirHtml.append(" ==> " + directory.fileName + " | ");
- dirHtml.append("
\n");
+import static eu.svjatoslav.commons.file.FilePathParser.getFileNameWithoutExtension;
+import static eu.svjatoslav.meviz.htmlindexer.Utils.urlEncode;
- }
+public class MixedLayout implements Layout {
- @Override
- public void enlistFile(final AbstractFile file) {
- finishRow();
+ public static final String encoding = "UTF-8";
- final String fullFileName = file.fileName;
+ private final Logger logger = Logger.getLogger(MixedLayout.class);
- filesHtml.append("\n");
- filesHtml.append(" "
- + fullFileName + "\n");
- filesHtml.append(" ("
- + FilePathParser.getFileSizeDescription(file.getFileLength())
- + ") | \n");
- filesHtml.append("
\n");
+ private StringBuffer dirHtml = new StringBuffer();
- }
+ private StringBuffer filesHtml = new StringBuffer();
- @Override
- public void enlistImage(final AbstractFile abstractFile) {
- try {
+ private String galleryTitle;
- final Picture picture = (Picture) abstractFile;
+ private List path;
- final Dimension imageSize = picture.getDimensions();
+ private AbstractIndexer indexer;
- final List recommendedDimensions = Picture
- .getThumbnailDimensions(imageSize);
+ private IndexingContext indexingContext;
+
+ @Override
+ public void enlistDirectory(final AbstractFile directory,
+ final DirectoryMetadata parentDirectoryMetadata) {
+ dirHtml.append("");
+ dirHtml.append(" ==> " + directory.fileName + " | ");
+ dirHtml.append("
\n");
+
+ }
+
+ @Override
+ public void enlistFile(final AbstractFile file,
+ final DirectoryMetadata parentDirectoryMetadata) {
+
+ final String fullFileName = file.fileName;
+
+ filesHtml.append("" + fullFileName + "\n");
+ filesHtml.append(" ("
+ + FilePathParser.getFileSizeDescription(file.getFileLength())
+ + ")
\n");
- Dimension listingDimension = new Dimension(500, 500);
+ }
+
+ @Override
+ 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);
+ }
+ }
+
+ private String enlistImageDimensions(final Picture picture) {
+ final StringBuilder html = new StringBuilder();
+
+ final List recommendedDimensions = Picture
+ .getThumbnailDimensions(picture.getDimensions());
+
+ int count = 0;
+ for (final Dimension dimension : recommendedDimensions) {
+ count++;
+ if (count > 1)
+ html.append(", ");
+ html.append("");
+ html.append(dimension.width + "x" + dimension.height);
+ html.append("");
+ }
+
+ return html.toString();
+ }
+
+ private void enlistImageInternal(final Picture picture) {
+
+ filesHtml.append("");
+
+ // clickable image thumbnail
+ filesHtml.append("
\n");
+
+ filesHtml.append("\n");
+
+ // file name
+ filesHtml.append("
"
+ + getFileNameWithoutExtension(picture.fileName)
+ + "");
+
+ // links to thumbnails of various sizes
+ filesHtml.append("(" + enlistImageDimensions(picture) + ")\n");
+
+ filesHtml.append("
");
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ public String getFileNameSuffix() {
+ return "";
+ }
+
+ /**
+ * {@inheritDoc}
+ *
+ * @throws IOException
+ */
+ @Override
+ public String getHtml(final boolean showTitle,
+ final boolean doHtmlHeaderAndFooter,
+ final DirectoryMetadata directory) {
+
+ // assemble final page HTML
+ final StringBuilder html = new StringBuilder();
+
+ if (doHtmlHeaderAndFooter)
+ appendHtmlHeader(html);
+
+ if (showTitle)
+ html.append("" + galleryTitle + "
\n");
+
+ html.append(showCurrentPath());
+ html.append(listDirectories());
+ html.append(directory.getHeaderMevizMetadataHtml());
+ html.append(filesHtml.toString());
+
+ if (doHtmlHeaderAndFooter)
+ appendHtmlFooter(html);
+
+ return html.toString();
+ }
+
+ private void appendHtmlFooter(StringBuilder html) {
+ html.append("