1# asciidoctor-chunker
2
3[![npm version](https://badge.fury.io/js/asciidoctor-chunker.svg)](https://badge.fury.io/js/asciidoctor-chunker)
4[![Node.js CI](https://github.com/wshito/asciidoctor-chunker/actions/workflows/node.js.yml/badge.svg)](https://github.com/wshito/asciidoctor-chunker/actions/workflows/node.js.yml)
5[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
6
7Generates chunked (multi-page) HTML from Asciidoctor's single HTML file with the support of fine-tuned splits by chapters, sections, or any depth of subsections.  Here is [the sample output.](http://www.seinan-gu.ac.jp/~shito/asciidoctor/html_chunk/index.html)  Each chapter can have different levels of extraction depth.  See [What it does](#what-it-does) for details.
8
9## News
10
11- 2021/8/3 [Ver 1.0.4](https://github.com/wshito/asciidoctor-chunker/releases) Added the keyboard shortcuts for the page navigation with arrow keys.  Added the accessibility labels on the page navigation for screen readers.
12- 2021/6/25 [Ver 1.0.3](https://github.com/wshito/asciidoctor-chunker/releases) Fixed the security vulnerabilities in the dependencies.
13- 2021/5/9 [Ver 1.0.2](https://github.com/wshito/asciidoctor-chunker/releases) The toc item for the titlepage can be configured with `--titlePage` option (thanks to [@johnthad](https://github.com/johnthad)).
14- 2021/3/17 [Ver 1.0.1](https://github.com/wshito/asciidoctor-chunker/releases) The script contains shebang and can be invoked directly.  Published on [npm](https://www.npmjs.com/package/asciidoctor-chunker).  You can install via npm.  See [Installation](#installation).
15- 2021/2/27 [Ver 1.0.0 Released!](https://github.com/wshito/asciidoctor-chunker/releases)
16  - Non opinionated page navigation at the bottom of each page is available.
17  - You can insert custom css from the command line with `--css` option.
18  - If you have any custom elements inserted in the source html, they are handled in non-strict mode by setting `--no-strictMode` option.
19  - Gives warning if no relative links are available in tocs.
20  - The current page toc is highlighted and scrolled into view.
21- 2021/2/20  Ver 0.9 is released!  This is a complete re-write from the previous Lisp version.  **It is re-implemented in JavaScript!**  So it is super easy to setup with NodeJS!  The fine tuned split options are available.  Oh, and it runs a lot faster than the previous version!��
22- 2021/2/10  Started work on the more enhanced version in `javascript` branch.  Please wait a couple of weeks.  The new version can control any depth of sections to split.  And even more, each chapter can have a different depth extraction level.   The new version is written in JavaScript so it will be a lot easier to install!
23- 2018/7/11  Locally linked files with `link` and `script` tags with relative paths are copied to the destination directory keeping the structure of the relative path.  So the custom CSS and script files should be properly copied by `asciidoctor-chunker`.
24
25## What it does
26
27Asciidoctor-Chunker generates chunked HTML from a single HTML generated by Asciidoctor.
28
291. Splits part preambles and chapters (or any depth of section level) into separate files. Each chapter can be configured to have a different depth for extractions.
301. Extracts css inside the style element into a separate file so the browser can cache and share it among all the pages.
311. Places footnotes in the file they belong to.  This also means that the multiply referred footnotes are placed in every referrer's files and sets the link back to the referrer's id within the page.
321. Re-writes the relative links in order to point to the appropriate chunked files.
331. Copies the local images and linked files (with `link`, `script` and `img` tags) whose paths are relative, to the directory relative to the chunked html output.  Files are only copied if they are new or modified compared to the previously copied one.
341. Adds a titlepage link in the toc and page navigation at the bottom of each page.
351. Adds non-opinionated page navigation.
361. Highlights the current page toc items and they get scrolled into the viewport.
37
38Here is [the sample output](http://www.seinan-gu.ac.jp/~shito/asciidoctor/html_chunk/index.html) created from the [Asciidoctor User Manual](https://asciidoctor.org/docs/user-manual/).  The footer on the sample page is added by setting the asciidoctor attribute and is not added by asciidoctor-chunker.
39
40
41## Installation
42
43Asciidoctor-Chunker is written in JavaScript and runs with NodeJS.
44
451. Install [Node.js](https://nodejs.org/), the JavaScript runtime.  This will install `npm`, the package manager CLI for Node.js.
461. If you want to install globally, invoke the following;
47   ```
48   npm install -g asciidoctor-chunker
49   ```
50   You can install locally under the current directory as;
51   ```
52   npm install asciidoctor-chunker
53   ```
541. Or alternatively you can download the pre-built program from the [release](https://github.com/wshito/asciidoctor-chunker/releases).
55
56## Usage
57
58If you installed globally:
59   ```
60   asiidoctor-chunker [single-html-file] -o [output-directory]
61   ```
62If you installed locally invoke the following under the directory you installed:
63   ```
64   npx asciidoctor-chunker [single-html-file] -o [output-directory]
65   ```
66If you installed the prebuild program simply run the script as:
67   ```
68   ./asciidoctor-chunker.js [single-html-file] -o [output-directory]
69   ```
70`[single-html-file]` is the single HTML file generated by [Asciidoctor](https://asciidoctor.org) from the book doctype.  If the output directory is not specified, the default is `html_chunks` under the current directory.
71
72More description of usage is available with `--help` option.
73
74## How to Configure the Depth of Extraction
75
76You can list the multiple settings by connecting each specifier with a comma.  Each specifier is consisted of either a single number or a collon separated with two numbers.
77
78The single number sets the default level of extraction.  Number 1 is the application's default and it extracts the chapter level.  Number 2 for section extraction, 3 for subsection, and so on to 6 which is the maximum section level of Asciidoctor.
79
80The list of collon separated numbers, `chap:level`, can change the extraction depth for specific chapters, so `3:2` means chapter 3 is extracted down to 2 levels (ie. section level).  You can use a hyphen to specify the range of chapters to set as `chapFrom-chapTo:level`, so `1-3:5` means chapter 1 through 5 should be extracted with the depth level 5.
81
82Example:
83```
84  --depth 2          The default level 2, all the chapters and
85                     sections will be extracted.
86  --depth 3,1:2,8:5  The default level 3, level 2 for Chap 1,
87                     level 5 for Chap 8.
88  --depth 1,3-8:2    The default level 1, level 2 for Chap 3 to 8.
89  --depth 3-8:3      No default is set so default level is 1, and
90                     level 3 for chap3 to 8.`
91```
92
93## Custom CSS
94
95By default `asciidoctor-chunker.css` is included in the output directory.  It provides the non-opinionated page navigation at the bottom of every chunked page.  You can override this by giving a comma separated list of paths to your custom css files.  They are copied into the output directory so the paths must be accessible by `asciidoctor-chunker`.
96
97## About Strict Mode
98
99If you have any custom elements inserted under `<div id=#content></div>` in the source single html, `asciidoctor-chunker` ignores it by default.  If you want them to be included into the chunked html, set the option `--no-strictMode`.
100The element will be copied to every chunked page.
101
102## Customizing Titlepage
103
104The `index.html` created by `asciidoctor-chunker` is selected by clicking the word **Titlepage** in the table of contents. To change the default value, use the option `--titlePage [string]` where `[string]` is the desired text.
105
106## Example
107
108The project contains the `example` directory where you can generate the chunked html for the [Asciidoctor User Manual](https://asciidoctor.org/docs/user-manual/) by invoking `make`.  Simply go into the `example` directory and invoke `make`.  This will clone the asciidoctor project from the github for the first time, then the chunked html will be generated under `test/output-chunk/html_chunk/` directory.  The `index.html` is the first page.
109
110```
111$ cd example
112$ make
113```
114
115## License
116
117MIT
118
119## Developer's Memo
120
121- Unit test uses `test/resources/output/single/sample.html` generated from `test/resources/sample.adoc`.
122- `npm install cheerio commander`
123- `npm install --save-dev ava webpack webpack-cli webpack-shebang-plugin`
124