InDesign CS5 is currently my favorite tool for generating EPUB files from existing documents. It's probably no coincidence that I'm a long time InDesign user in general, quite comfortable with its features and idiosyncracies. In fact, I don't use a standalone word processor at all. I hadn't bought Word for years until I needed it for examples for my latest book. I use InDesign even for the most basic letters. And InDesign's EPUB generation is pretty good: it generates all the persnickety XML files and exports a fair bit of the design from your original document.
But it could do so much more.
Here's why I currently have to crack open InDesign files (solutions to all these problems are in my book). Let's hope the next version of InDesign does all this for me!
1. First and foremost, because the EPUB doesn't validate. To do so, I must add the
dc:date
element.2. Because InDesign doesn't properly designate an image or given page as a cover. This is huge!
3. To add metadata. Without standard, accurate metadata, you might as well not publish an ebook because no-one will be able to find it.
4. In order to apply text wrap to images and sidebars. Since InDesign supports the creation of text wrap, around images by themselves, groups of images and captions, and sidebars of text, it should also be able to export it into the EPUB (especially considering that only small adjustments in resulting XHTML and CSS are required).
5. To wrap text around drop caps.
6. To format first line of text (what in InDesign is a Nested Style) so that it maintains formatting in EPUB.
7. To specify which paragraphs should be kept together, for example, images with captions, headers with first paragraph following, etc. Again, InDesign supports keep together but doesn't export to EPUB.
8. To specify page breaks. Although iBooks does not yet support page breaks (which is incredible in itself), other ereaders do. This is a major concern of ebook publishers.
9. To specify widows and headers. One more instance where InDesign already has the functionality but does not support it in export to EPUB. Hugely important for ebook publishers (even though not yet supported in iBooks, it is supported by other ereaders).
10. Because Apple says, on page 15 of their Publishing Guidelines, that "All book elements (for example, the cover, table of contents, first chapter, index, and so on
must be identified in the <guide> block." Note the use of the word "must". Note that <guide> is optional according to the current version of EPUB, and Apple has not yet rejected books without <guide> blocks, to my knowledge.
11. To add pagination guidelines, so that readers can find passages from a particular page of a print edition in their ebook edition (e.g., in a college class).
12. To eliminate erroneous default values that InDesign applies to non-specified properties (which mess up CSS inheritance).
13. To correct/use font names supported by the iPad.
14. To add Zapf Dingbats (which must be added as UTF-8).
15. To add text in foreign languages, like Hebrew, Arabic, Thai, Chinese, Japanese, etc.
16. To fix the spacing bug that occurs when exporting headers (see page 163 in the print edition of my EPUB book).
17. To force iBooks to support left-aligned text (by inserting a
span
tag within every p
element). Granted, this is a hack, but text will continue to look really awful when fully justified until we have decent hyphenation dictionaries in ereaders.18. To change spacing and margin units from ems to percentages in order to adapt to smaller screens. This is a complicated issue, and will probably get more complicated, but also hugely important.
19. To deal with hyphenation.
20. To fix or insert links. Currently, EPUB export breaks if you try to export a link that contains an ampersand, and most links to Amazon to buy books contain ampersands! <strong>Update (3/Oct/2011): CS5.5 exports links from multiple chapters correctly! </strong>
21. To insert video or audio. I would recommend following Apple's lead on this, using HTML5 tags, but allowing for different formats.
22. To maintain the inheritance among styles in the InDesign document in the generated styles in the CSS. I know this is complicated, but if I can do it with a little bit of GREP, couldn't ID do it automatically?
Most of these issues are described (and solved with workarounds) in my EPUB book. But wouldn't it be nice if InDesign just did this for us? What do you wish InDesign could do?