This is the first part of the Bookiza Abelone library.
Publish and distribute your books via the web. 🥳
Bookiza is a book-making tool for the web. It is a lightweight javascript framework with a browser shim that lets you publish scalable and deeply formatted long-form works using traditional publishing values and modern web principles that sit above-the-fold.
Print delightful digital books on the web that reach everyone, and not just those who own specialized expensive hardware to read your work.
Visit the Bookiza Website for more details.
Bookiza uses the Superbook format to control the editions and compile your manuscript into a production-ready (SPA-like) book.
Books created using Bookiza Abelone are supported on every major device, tablet, and desktop sporting a modern browser and an Internet connection.
Visit Bubblin Superbooks to view Books of different types with varying layouts, and features like intrinsic typesetting, line-tracking, and responsivity.
Despite ubiquity, we recommend tablets (any brand) in landscape mode to best experience our books.
- Documentation is available here.
- A free book on The Bookiza Framework.
A quick primer on the Superbook format is available here.
node > 18.3.0, git-scm, an api_key
from https://bubblin.io
and a unixy-style bash.
$ npm install -g bookiza
You'll need to install bookiza and shelljs as global.
Check installation with:
$ bookiza --version
bookiza
is shortened to alphabetb
on your terminal as CLI invoker. This is useful when you're creating a relatively longer body of text and it becomes increasingly painful to type full form commands into the abyss.
Next, register Bookiza client with:
$ bookiza register or $ b z
Provide your Bubblin credentials to connect to its sweet POST API. You're all set!
To check:
$ bookiza whoami or $ b w
To bootstrap new project, run:
$ bookiza new my-awesome-new-book --leafs 40 --template novella
# Creates a project with 40 fresh leafs (80 pages) inside the `manuscript/` folder and applies the responsive `novella` template on it with initial defaults.
cd
into the project and:
$ bookiza server # Open https://localhost:4567 on your browser!
Full vocabulary is available with:
$ bookiza --help
That's it.
Bookiza comes along with several FREE, responsive and scalable templates so that you don’t have to do the layouts yourself.
Feel free to fork and build new templates to kickstart your work in any way you like.
We accept new templates for different kinds of books and formatting options. PRs and new ideas are welcome.
Bookiza and Bubblin default to using only the building blocks of the web i.e. HTML, CSS & JavaScript. Bubblin maintains only the head version of your clean and compiled manuscript to render your work. No history is maintained at Bubblin at this time.
Bookiza lets you compose your manuscript with any preprocessor you like. There are two ways to configure Bookiza so as to cater to your needs depending on the type of content on your book.
Configuring Bookiza is very simple and its editing modes can be easily customized to suit your needs by setting the mode
according to your liking.
When you register the Bookiza client (with $ bookiza register
) in your local, it will automatically create and configure the following runcom file .bookizarc
at the root of your machine. You can set the processing modes of Bookiza on this arc
file and Bookiza will automatically pick up the desired processing mode for your manuscripts.
# $ vi .bookizarc
{
// ...
"mode": {
"HTML": "html", # markdown, haml, or pug etc.
"CSS": "css",
"JS": "js",
"HEAD": "html"
},
// ...
}
See full list of templating engines & preprocessors that are currently available.
Editing mode can also be set on per book basis using the .bookrc
configuration at the root of your project:
# $ vi .bookrc
{
// ...
"mode": {
"HTML": "html",
"CSS": "css",
"JS": "js",
"HEAD": "html"
}
// ...
}
In case of conflict between modes on .bookrc
and .bookizarc
the book level configuration i.e. via .bookrc
shall prevail.
- PR branches must work everywhere: i.e. should have been tested manually on all browsers and all operating systems i.e. MacOS, Windows, and at least one distribution of Linux.
- Commit messages must be self explanatory. Please do pepper your submissions with comments!
- Provide system related information of the dev machine (OS/Browser/Screen) you developed your PR on.
TBD. UNLICENSED