Skip to main content

TUI Ebook Reader

Project description

baca: TUI E-book Reader

baca_screenshots

Meet baca, epy's lovely sister who lets you indulge in your favorite e-books in the comfort of your terminal. But with a sleek and contemporary appearance that's sure to captivate you!

Features

  • Formats supported: Epub, Epub3, Mobi & Azw
  • Remembers last reading position
  • Show images as ANSI image & you can click it for more detail
  • Scroll animations
  • Clean & modern looks
  • Text justification
  • Dark & light color scheme
  • Regex search
  • Hyperlinks

Requirements

  • python>=3.10

Installation

  • Via pip: pip install baca
  • Via git: pip install git+https://github.com/wustho/baca
  • Via AUR: yay -S baca-ereader-git

Usage

# to read an ebook
baca path/to/your/ebook.epub

# to read your last read ebook, just run baca without any argument
baca

# to see your reading history use -r as an argument
baca -r

# say you want to read an ebook from your reading history,
# but you forgot the path to your ebook
# just type any words you remember about your ebook
# and baca will try to match it to path or title+author
baca doc ebook.epub
baca alice wonder lewis carroll

Opening an Image

To open an image, when you encounter an ANSI image (when ShowImageAsANSI=yes) or some thing like this (if ShowImageAsANSI=no):

┌──────────────────────────────────────────────────────────────────────────────┐
│                                    IMAGE                                     │
└──────────────────────────────────────────────────────────────────────────────┘

just click on it using mouse and it will open the image using system app. Yeah, I know you want to use keyboard for this, me too, but bear with this for now.

"Why show the images as ANSI images instead of render it directly on terminal like ranger does?"

  1. The main reason is that currently, rendering images directly on the terminal doesn't allow for partial scrolling of the image. This means that we can't display only a portion (e.g., 30%) of the image when scrolling, resulting in a broken and non-seamless scrolling experience.

  2. My primary intention in developing this app is for reading fiction e-books rather than technical ones, and most fiction e-books don't contain many images.

  3. Displaying images on the terminal requires different implementations for various terminal emulators, which requires a lot of maintenance.

Configurations

pretty_yes_no_cap

Configuration file available at ~/.config/baca/config.ini for linux users. Here is the default:

[General]
# pick your favorite image viewer
PreferredImageViewer = auto

# int or css value string like 90%%
# (escape percent with double percent %%)
MaxTextWidth = 80

# 'justify', 'center', 'left', 'right'
TextJustification = justify

# currently using pretty=yes is slow
# and taking huge amount of memory
Pretty = no

PageScrollDuration = 0.2

# either show image as ansii image
# or text 'IMAGE' as a placehoder
# (showing ansii image will affect
# performance & resource usage)
ShowImageAsANSII = yes

[Color Dark]
Background = #1e1e1e
Foreground = #f5f5f5
Accent = #0178d4

[Color Light]
Background = #f5f5f5
Foreground = #1e1e1e
Accent = #0178d4

[Keymaps]
ToggleLightDark = c
ScrollDown = down,j
ScrollUp = up,k
PageDown = ctrl+f,pagedown,l,space
PageUp = ctrl+b,pageup,h
Home = home,g
End = end,G
OpenToc = tab
OpenMetadata = M
OpenHelp = f1
SearchForward = slash
SearchBackward = question_mark
NextMatch = n
PreviousMatch = N
Confirm = enter
CloseOrQuit = q,escape
Screenshot = f12

Known Limitations

  • When searching for specific phrases in baca, keep in mind that it may not be able to find them if they span across two lines, much like in the search behavior of editor vi(m).

    For example, baca won't be able to find the phrase "for it" because it is split into two lines in this example.

    ...
    she had forgotten the little golden key, and when she went back to the table for
    it, she found she could not possibly reach it: she could see  it  quite  plainly
    ...
    

    Additionally, baca may struggle to locate certain phrases due to adjustments made for text justification. See the example above, "see_it" may become "see__it" due to adjusted spacing between words. In this case, it may be more effective to use a regex search for "see +it" or simply search for the word "see" alone.

    Overall, baca's search feature is most effective for locating individual words rather than phrases that may be split across multiple lines or impacted by text justification.

  • Compared to epy, currently baca has some missing features. But these are planned to be implemented to baca in the near future:

    • TODO Bookmarks
    • TODO FictionBook support
    • TODO URL reading support

Credits

License

GPL-3

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

baca-0.1.17.tar.gz (112.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

baca-0.1.17-py3-none-any.whl (126.9 kB view details)

Uploaded Python 3

File details

Details for the file baca-0.1.17.tar.gz.

File metadata

  • Download URL: baca-0.1.17.tar.gz
  • Upload date:
  • Size: 112.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/6.2.0-39-generic

File hashes

Hashes for baca-0.1.17.tar.gz
Algorithm Hash digest
SHA256 568fd577cdaad49c5a1161f399ee2a96cc1f1e6ccaa704eb9cad9c0a2ac2d1af
MD5 4f160e90195b49ae116c44ae21de64df
BLAKE2b-256 0f3430b330e354fe6c0275060b83cccd0012edaf0ad50adb4e894af8ef41959a

See more details on using hashes here.

File details

Details for the file baca-0.1.17-py3-none-any.whl.

File metadata

  • Download URL: baca-0.1.17-py3-none-any.whl
  • Upload date:
  • Size: 126.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/6.2.0-39-generic

File hashes

Hashes for baca-0.1.17-py3-none-any.whl
Algorithm Hash digest
SHA256 8a8da0848794bd03cab69a19051cfae8c9400be7dbcbedee0e3d96c5201494e7
MD5 3df5198ffe82a0ab69e634b2edef35dd
BLAKE2b-256 bf3f0713b3f4e14ad4831235b4c65f9a815a22f897ca42db7528c6dcf236227f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page