X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Foutput%2FHtml.java;h=da79466a40d9cc2fcf80872d77ef6e588398e732;hb=d66deb8d8b30cff6b54db352eef34a3508939f84;hp=29a0f32b6404e6b1c0822e6e45d11b6783601905;hpb=a6395bef99a8e917f67341ef1906917b87df24a4;p=nikiroo-utils.git diff --git a/src/be/nikiroo/fanfix/output/Html.java b/src/be/nikiroo/fanfix/output/Html.java index 29a0f32..da79466 100644 --- a/src/be/nikiroo/fanfix/output/Html.java +++ b/src/be/nikiroo/fanfix/output/Html.java @@ -1,36 +1,41 @@ package be.nikiroo.fanfix.output; +import java.io.BufferedWriter; import java.io.File; -import java.io.FileWriter; +import java.io.FileOutputStream; import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStreamWriter; import be.nikiroo.fanfix.Instance; -import be.nikiroo.fanfix.bundles.StringId; +import be.nikiroo.fanfix.bundles.Config; import be.nikiroo.fanfix.data.Chapter; +import be.nikiroo.fanfix.data.MetaData; import be.nikiroo.fanfix.data.Paragraph; import be.nikiroo.fanfix.data.Paragraph.ParagraphType; import be.nikiroo.fanfix.data.Story; +import be.nikiroo.utils.IOUtils; import be.nikiroo.utils.StringUtils; class Html extends BasicOutput { - protected FileWriter writer; + private File dir; + protected BufferedWriter writer; private boolean inDialogue = false; private boolean inNormal = false; @Override public File process(Story story, File targetDir, String targetName) throws IOException { + String targetNameOrig = targetName; + File target = new File(targetDir, targetName); target.mkdir(); + dir = target; - targetName = new File(targetName, "index").getPath(); - - String targetNameOrig = targetName; - targetName += getDefaultExtension(); - - target = new File(targetDir, targetName); + target = new File(targetDir, targetName + getDefaultExtension(true)); - writer = new FileWriter(target); + writer = new BufferedWriter(new OutputStreamWriter( + new FileOutputStream(target), "UTF-8")); try { super.process(story, targetDir, targetNameOrig); } finally { @@ -38,19 +43,64 @@ class Html extends BasicOutput { writer = null; } + // write a copy of the originals inside + InfoCover.writeInfo(dir, targetName, story.getMeta()); + InfoCover.writeCover(dir, targetName, story.getMeta()); + BasicOutput.getOutput(OutputType.TEXT, isWriteInfo(), isWriteCover()) + .process(story, dir, targetNameOrig); + + if (story.getMeta().getCover() != null) { + Instance.getInstance().getCache().saveAsImage(story.getMeta().getCover(), new File(dir, "cover"), true); + } + return target; } @Override - public String getDefaultExtension() { - return ".html"; + public String getDefaultExtension(boolean readerTarget) { + if (readerTarget) { + return File.separator + "index.html"; + } + + return ""; } @Override protected void writeStoryHeader(Story story) throws IOException { String title = ""; + String tags = ""; + String author = ""; + Chapter resume = null; if (story.getMeta() != null) { - title = story.getMeta().getTitle(); + MetaData meta = story.getMeta(); + title = meta.getTitle(); + resume = meta.getResume(); + if (meta.getTags() != null) { + for (String tag : meta.getTags()) { + if (!tags.isEmpty()) { + tags += ", "; + } + tags += tag; + } + + if (!tags.isEmpty()) { + tags = "(" + tags + ")"; + } + } + author = meta.getAuthor(); + } + + String format = Instance.getInstance().getConfig() + .getString(Config.FILE_FORMAT_IMAGE_FORMAT_COVER).toLowerCase(); + + InputStream inStyle = getClass().getResourceAsStream("html.style.css"); + if (inStyle == null) { + throw new IOException("Cannot find style.css resource"); + } + try { + IOUtils.write(inStyle, new File(dir, "style.css")); + } finally { + inStyle.close(); } writer.write(""); @@ -58,11 +108,39 @@ class Html extends BasicOutput { writer.write("\n"); writer.write("\n "); writer.write("\n "); + writer.write("\n "); writer.write("\n " + StringUtils.xmlEscape(title) + ""); writer.write("\n"); writer.write("\n\n"); - writer.write("

" + StringUtils.xmlEscape(title) + "

\n\n"); + writer.write("\n
"); + writer.write("\n

" + StringUtils.xmlEscape(title) + "

"); + writer.write("\n
" + StringUtils.xmlEscape(tags) + + "
"); + writer.write("\n
"); + writer.write("\n "); + writer.write("\n
"); + writer.write("\n
" + + StringUtils.xmlEscape(author) + "
"); + writer.write("\n
"); + + writer.write("\n

"); + + if (resume != null) { + for (Paragraph para : resume) { + writeParagraph(para); + } + if (inDialogue) { + writer.write(" \n"); + inDialogue = false; + } + if (inNormal) { + writer.write(" \n"); + inNormal = false; + } + } + + writer.write("\n
"); } @Override @@ -72,21 +150,40 @@ class Html extends BasicOutput { @Override protected void writeChapterHeader(Chapter chap) throws IOException { - String txt; + String nameOrNumber; if (chap.getName() != null && !chap.getName().isEmpty()) { - txt = Instance.getTrans().getString(StringId.CHAPTER_NAMED, - chap.getNumber(), chap.getName()); + nameOrNumber = chap.getName(); } else { - txt = Instance.getTrans().getString(StringId.CHAPTER_UNNAMED, - chap.getNumber()); + nameOrNumber = Integer.toString(chap.getNumber()); } - writer.write("

" + StringUtils.xmlEscape(txt) + "

\n\n"); + writer.write("\n

"); + writer.write("\n Chapter " + + chap.getNumber() + ": "); + writer.write("\n " + + StringUtils.xmlEscape(nameOrNumber) + ""); + writer.write("\n

"); + writer.write("\n "); + writer.write("\n
\n"); inDialogue = false; inNormal = false; } + @Override + protected void writeChapterFooter(Chapter chap) throws IOException { + if (inDialogue) { + writer.write("
\n"); + inDialogue = false; + } + if (inNormal) { + writer.write(" \n"); + inNormal = false; + } + + writer.write("\n "); + } + @Override protected void writeParagraphHeader(Paragraph para) throws IOException { if (para.getType() == ParagraphType.QUOTE && !inDialogue) { @@ -110,7 +207,7 @@ class Html extends BasicOutput { writer.write("
"); break; case BREAK: - writer.write("
"); + writer.write("
"); break; case NORMAL: writer.write(" ");