Skip to content
John Factotum edited this page Sep 14, 2019 · 25 revisions

Table of Contents

Reading progress slider not showing up?

In order to display the slider, Epub.js must generate locations for the entire book. For books with lots of pages, this could take a while. In the meantime, you can still read the book and use all other functionalities normally.

Once the locations are generated, the info is cached (in ~/.cache/com.github.johnfactotum.Foliate) and should load instantly next time you open the book.

How are notes and bookmarks stored?

Your reading progress, bookmarks, and annotations are saved in ~/.local/share/com.github.johnfactotum.Foliate

If you're using the flatpak version, they should be in ~/.var/app/com.github.johnfactotum.Foliate/data/com.github.johnfactotum.Foliate

The data for each book is stored in a JSON file named after the book's identifier. If you'd like to sync or backup your progress and notes, simply copy these files and everything should just work™.

Inside the JSON file, the structure looks like this:

{
  "lastLocation": "epubcfi(/6/12[main2]!/4/2/2/2/1:0)", // your reading progress
  "annotations": [
    {
      "value": "epubcfi(/6/12[main2]!/4/2/2/2,/1:0,/1:286)",
      // highlight color
      "color": "aqua",
      // the highlighted text
      "text": "Good sense is, of all things among men, the most equally distributed; for every one thinks himself so abundantly provided with it, that those even who are the most difficult to satisfy in everything else, do not usually desire a larger measure of this quality than they already possess.",
      // ... and your note
      "note": "Very droll, René."
    },
    "bookmarks": [] // bookmarks are stored here
    "metadata": { /* the book's metadata is provided here for convenience, starting from v1.5.0 */ }
  ]
}

The "epubcfi(...)" parts are EPUB Canonical Fragment Identifiers, which is the "standardized method for referencing arbitrary content within an EPUB® Publication."

How to use text-to-speech?

Foliate supports espeak/espeak-ng and festival. The exact command can be configured in the preference dialog.

Other speech synthesis programs can be used, but Foliate expects the following interface:

  1. The program would read text from stdin and speak them
  2. Return when finished speaking
  3. Stop speaking when SIGINT is received

How to use custom themes?

The themes can be configured from the preferences. You can also manually edit the file /home/user/.config/com.github.johnfactotum.Foliate/themes.json (or create the file if does not already exists).

If you're using the flatpak version, the file should be placed in ~/.var/app/com.github.johnfactotum.Foliate/config/com.github.johnfactotum.Foliate.

The themes are specified like this (using the Nord colors as an example):

{
    "themes": {
        "Light": {
            "color": "#000",
            "background": "#fff",
            "link": "blue",
            "darkMode": false,
            "invert": false
        },
        "Nord": {
            "color": "#d8dee9",
            "background": "#2e3440",
            "link": "#88c0d0",
            "darkMode": true,
            "invert": false
        },
        "Nord Invert": {
            "color": "#171f27",
            "background": "#c0c8d1",
            "link": "#467381",
            "darkMode": true,
            "invert": true
        }
    }
}

Note that you can set invert to true, and it'll just be like invert mode except with your custom colors! But it's actually invert and hue-rotate by 180 degrees. In this example, GIMP was used to invert and rotate the colors. It won't be exactly the same as the original colors, though, see this question.

My book is not displayed properly!

You can help by testing out whether it's a problem with Epub.js, or a problem specific to Foliate:

  1. Go to https://futurepress.github.io/epub.js/examples/input.html (It's best to test with a WebKit-based browser, as there are sometimes WebKit specific issues)
  2. Use the input button at the top of that page to choose your file. Note that the button might not show if your viewport is too small. Try resizing the window or zooming out if you don't see the button.
  3. The prev/next button on their example is currently broken. However, if you open your browser's developer tools, you should be able to use the console and run rendition.next() and rendition.prev().
  4. If it doesn't work, consider reporting the issue upstream. If it only fails in Foliate, you can report it here.

Known issues

Books with vertical text are not currently supported. This has been reported upstream.

Clone this wiki locally