public static final String encoding = "UTF-8";
- int currentColumn = 0;
-
- int horizontalColumnsLimit = 2;
-
private AbstractIndexer indexer;
private IndexingContext indexingContext;
- public void columnAdded() {
- currentColumn++;
- if (currentColumn > horizontalColumnsLimit) {
-
- currentColumn = 0;
-
- filesHtml.append("</TR>\n");
- }
- }
-
@Override
public void enlistDirectory(final AbstractFile directory) {
dirHtml.append("<TR>");
dirHtml.append("<TD><b><a href=\""
+ indexer.getDirectoryUrl(directory, indexingContext)
- + "\"> ==> " + directory.fileName + "</a></b></TD>");
+ + "\"><h2> ==> " + directory.fileName + "</h2></a></b></TD>");
dirHtml.append("</TR>\n");
}
@Override
public void enlistFile(final AbstractFile file) {
- finishRow();
final String fullFileName = file.fileName;
- filesHtml.append("<TR>\n");
- filesHtml.append(" <TD colspan=\""
- + String.valueOf(horizontalColumnsLimit)
- + "\"><a href=\""
+ filesHtml.append("<div style=\"clear: both;\"><a href=\""
+ indexingContext.getGlobalUrl()
+ UrlParamEncoder.encode(indexingContext.getLocalUrl() + "/"
+ fullFileName) + "\">" + fullFileName + "</a>\n");
filesHtml.append(" ("
+ 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) {
try {
- final Picture picture = (Picture) abstractFile;
-
final Dimension imageSize = picture.getDimensions();
final List<Dimension> recommendedDimensions = Picture
.getThumbnailDimensions(imageSize);
- Dimension listingDimension = new Dimension(500, 500);
+ Dimension listingDimension = new Dimension(1500, 450);
if (listingDimension.width > imageSize.width)
if (listingDimension.height > imageSize.height)
final String listingThumbnailUrl = indexer.getThumbnailUrl(picture,
listingDimension, indexingContext);
- startcolumn();
-
- filesHtml.append("<TD><center><a href=\""
+ filesHtml.append("<div style=\"float:left; margin: 10px;\">");
+ filesHtml.append("<a href=\""
+ indexingContext.getGlobalUrl()
+ UrlParamEncoder.encode(indexingContext.getLocalUrl()
+ "/" + picture.fileName) + "\">\n");
+ "\"/></a>\n");
filesHtml.append("<br/><b>"
+ FilePathParser
- .getFileNameWithoutExtension(picture.fileName)
+ .getFileNameWithoutExtension(picture.fileName)
+ "</b><br/>(");
int count = 0;
filesHtml.append("</a>");
}
- filesHtml.append(")</TD>\n");
-
- columnAdded();
+ filesHtml.append(")\n");
+ filesHtml.append("</div>");
} 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);
+ e);
+ enlistFile(picture);
}
}
final GeneralFile file = (GeneralFile) abstractFile;
- finishRow();
-
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("<div style=\"margin: 30px; clear: both;\">"
+ + "<video preload=\"metadata\" controls=\"controls\" tabindex=\"0\">\n");
filesHtml
- .append("<source type=\"video/ogg\" codecs=\"theora, vorbis\" src=\""
- + indexingContext.getGlobalUrl()
- + UrlParamEncoder.encode(indexingContext.getLocalUrl()
- + "/" + file.fileName) + "\">\n");
+ .append("<source type=\"video/ogg\" codecs=\"theora, vorbis\" src=\""
+ + indexingContext.getGlobalUrl()
+ + UrlParamEncoder.encode(indexingContext.getLocalUrl()
+ + "/" + file.fileName) + "\">\n");
filesHtml.append("</source>\n");
filesHtml.append("</video>\n");
filesHtml.append("<br/>\n");
filesHtml
- .append("Video: <b>"
- + FilePathParser
- .getFileNameWithoutExtension(file.fileName)
- + "<b/> ");
+ .append("Video: <b>"
+ + FilePathParser
+ .getFileNameWithoutExtension(file.fileName)
+ + "<b/> ");
filesHtml.append("<a href=\""
+ indexingContext.getGlobalUrl()
+ UrlParamEncoder.encode(indexingContext.getLocalUrl() + "/"
- + file.fileName) + "\">download as OGV</a>\n");
+ + file.fileName) + "\">download as OGV</a></div>\n");
- filesHtml.append("</TD></TR>\n");
+ filesHtml.append("\n");
}
- public void finishRow() {
-
- if (currentColumn == 0)
- return;
-
- while (currentColumn <= horizontalColumnsLimit) {
- filesHtml.append("<TD></TD>");
- currentColumn++;
- }
- filesHtml.append("</TR>\n");
- currentColumn = 0;
- }
-
/** {@inheritDoc} */
@Override
public String getFileNameSuffix() {
finalHtml.append("<HTML>\n");
finalHtml.append("<HEAD>\n");
finalHtml
- .append(" <meta HTTP-EQUIV=\"Content-Type\" CONTENT=\"text/html; charset=UTF-8\"/>\n");
+ .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");
+ .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");
if (showTitle)
finalHtml
- .append("<CENTER><H1>" + galleryTitle + "</H1></CENTER>\n");
-
- finalHtml.append("<CENTER><H2>");
- for (final String p : path)
- finalHtml.append(" / " + p);
- finalHtml.append("</H2></CENTER>\n");
-
- // append directory listing
- finalHtml.append("<TABLE>\n");
-
- if (path.size() > 0) {
- finalHtml.append("<TR>");
- finalHtml.append("<TD><b><a href=\""
- + indexer.getParentDirectoryUrl(indexingContext)
- + "\"> <== ..</a></b></TD>");
- finalHtml.append("</TR>\n");
- }
+ .append("<CENTER><H1>" + galleryTitle + "</H1></CENTER>\n");
- finalHtml.append(dirHtml.toString());
- finalHtml.append("\n<TR><TD><br></TD></TR>\n");
- finalHtml.append("</TABLE>\n");
+ showCurrentPath(finalHtml);
- // append file listing
+ listDirectories(finalHtml);
- finishRow();
- finalHtml.append("<TABLE width=\"1100\">\n");
finalHtml.append(filesHtml.toString());
- finalHtml.append("\n</TABLE>\n");
if (doHtmlHeaderAndFooter)
finalHtml.append("</font></BODY></HTML>\n");
filesHtml = new StringBuffer();
}
- public void startcolumn() {
- if (currentColumn == 0) {
- filesHtml.append("<TR>");
- currentColumn = 1;
+ private void listDirectories(final StringBuffer finalHtml) {
+ finalHtml.append("<TABLE>\n");
+
+ if (path.size() > 0) {
+ finalHtml.append("<TR>");
+ finalHtml.append("<TD><b><a href=\""
+ + indexer.getParentDirectoryUrl(indexingContext)
+ + "\"><h2> <== parent directory</h2></a></b></TD>");
+ finalHtml.append("</TR>\n");
}
+
+ finalHtml.append(dirHtml.toString());
+ finalHtml.append("\n<TR><TD><br></TD></TR>\n");
+ finalHtml.append("</TABLE>\n");
+ }
+
+ private void showCurrentPath(final StringBuffer finalHtml) {
+ finalHtml.append("<CENTER><H2>");
+ for (final String p : path)
+ finalHtml.append(" / " + p);
+ finalHtml.append("</H2></CENTER>\n");
}
}