Skip to content

Commit

Permalink
docs: cleanup and deploy from readme
Browse files Browse the repository at this point in the history
Documentation updates
  • Loading branch information
ganeshh123 authored Feb 14, 2023
2 parents 4a5461f + 8362d23 commit d21917d
Show file tree
Hide file tree
Showing 5 changed files with 85 additions and 322 deletions.
190 changes: 84 additions & 106 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,181 +2,159 @@

A tool to allow batch PDF export for free Notion users. You can export as HTML with subpages and then use this tool to convert those into PDFs.

# Download

Get the latest download for Windows and Mac from the releases page:
- [Download](#download)
- [Usage](#usage)
- [Building](#building)
- [Source Code](#source-code)
- [Running the Project on Node](#running-the-project-on-node)
- [Compiling an Executable](#compiling-an-executable)
- [Installing nexe](#installing-nexe)
- [To Install Automatically:](#to-install-automatically)
- [To Install Manually:](#to-install-manually)
- [Compiling Executables](#compiling-executables)
- [Compile Automatically](#compile-automatically)
- [Compile Manually](#compile-manually)
- [Credits](#credits)
- [wkhtmltopdf](#wkhtmltopdf)
- [Assets](#assets)

## Download

Get the latest download for Windows and macOS from the releases page:

[https://github.com/ganeshh123/notion-pdf-export/releases](https://github.com/ganeshh123/notion-pdf-export/releases/latest)

[Download for Windows](https://github.com/ganeshh123/notion-pdf-export/releases/download/1.3.0/notion-pdf-export_windows_1.3.0.zip)

[Download for Mac](https://github.com/ganeshh123/notion-pdf-export/releases/download/1.3.0/notion-pdf-export_mac_1.3.0.zip)
[Download for macOS](https://github.com/ganeshh123/notion-pdf-export/releases/download/1.3.0/notion-pdf-export_mac_1.3.0.zip)

# Usage
## Usage

[![video guide](https://i.ytimg.com/vi/txKhyzwkAus/maxresdefault.jpg)](http://www.youtube.com/watch?v=txKhyzwkAus "video_guide")
[Video Guide](https://youtu.be/txKhyzwkAus)


1. Download the tool and extract.

![downloaded_program](docs/downloaded_program.jpg)

2. In [Notion](https://notion.so), place all the pages you wish to export into one page and click Export, choose 'HTML' and ensure 'Include Subpages' is on.

![notion-export](docs/notion-export.jpg)

3. Extract the export to find a list of HTML files and folders for each page. Place the HTML files with folders containing images in the same folder as 'notion-pdf-export.exe' (Windows) or 'notion-pdf-export' (Mac).

3. Extract the export to find a list of HTML files and folders for each page. Place the HTML files with folders containing images in the same folder as 'notion-pdf-export.exe' (Windows) or 'notion-pdf-export' (macOS).
![placing-markdown-files](docs/placing-html-files.jpg)

4. Double Click 'notion-pdf-export.exe' (Windows) or 'notion-pdf-export' (Mac) and wait for the process to be completed.

4. Double Click 'notion-pdf-export.exe' (Windows) or 'notion-pdf-export' (macOS) and wait for the process to be completed.
![running-program](docs/running-program.jpg)

If nothing happens, you may need to go to macOS security settings and click 'Open Anyway':

![macOS_security](docs/macos_security.jpg)

5. All the individual pages can be found converted into PDF Documents inside the pdfs folder.

![created_pdfs](docs/created_pdfs.jpg)

---

# Building
## Building

## Running the Project on Node
### Source Code
- Repository: [ganeshh123/notion-pdf-export](https://github.com/ganeshh123/notion-pdf-export)
- HTTPS Clone: `https://github.com/ganeshh123/notion-pdf-export.git`
- SSH Clone: `[email protected]:ganeshh123/notion-pdf-export.git`

1. Clone/Download the project and run the command in the project root directory:
### Running the Project on Node

1. Clone/Download the project and run the command in the project root directory:
```bash
npm install
```
2. Run this command to run the script:

```bash
node index.js
```

## Compiling an Executable
### Compiling an Executable

This is tricky. A lot of adjustments had to be made so that it can run without node.

### Installing nexe
#### Installing nexe

Executables are compiled with a very [specific version of nexe](https://github.com/cspotcode/nexe/tree/fix-vfs) that allows access to the filesystem, which has a tricky setup procedure.

#### To Install Automatically:

Run **install_nexe_win.bat** as admin on **Windows**, will take about 5 minutes to install fully.

Or

Run **install_nexe_mac** on **Mac**, will take about 5 minutes to install, and you will need to enter password. This sometimes doesn't seem to work properly, so might be worth doing manual install if there's problems.
##### To Install Automatically:

#### To Install Manually:
- **Windows** - Run `install_nexe_win.bat` as admin, will take about 5 minutes to install fully.
- **macOS** - Run the `install_nexe_mac` shell script, will take about 5 minutes to install, and you will need to enter an admin password. This sometimes doesn't seem to work properly, so might be worth doing manual install if there's problems.

1. Firstly, install the general [nexe](https://www.npmjs.com/package/nexe) globally with the command:

```bash
npm install -g nexe
```
##### To Install Manually:

In Windows with Command Prompt running as Admin. Or:

```bash
sudo npm install -g nexe
```

In Mac in the terminal

2. In the project root folder build some executables with this version of nexe to download node binaries for Windows and Mac:
1. Firstly, install the general [nexe](https://www.npmjs.com/package/nexe) package globally:
- **Windows** (in command prompt must be running as admin):
```bash
npm install -g nexe
```
- **macOS** (in the terminal):
```bash
sudo npm install -g nexe
```

2. In the project root folder build some executables with this version of nexe to download node binaries for Windows and macOS:
```bash
nexe . --target win32-x86-10.13.0
nexe . -t macos-10.13.0
```

This will download the binaries we need for later, delete the executables built with this for now.

3. Now we need to install a [specific version of nexe](https://github.com/cspotcode/nexe/tree/fix-vfs) that allows access to the filesystem:

Run the command:
- **Windows** (in command prompt must be running as admin):
```bash
npm install -g cspotcode/nexe#19a5046
```
- **macOS** (in the terminal):
```bash
sudo npm install -g cspotcode/nexe#19a5046
```
Now we should have the correct version of nexe for building. Confirm by running:

```bash
npm install -g cspotcode/nexe#19a5046
nexe -v
```
Check that the version is `4.0.0-beta.4`

In Windows with Command Prompt running as Admin. Or:

```bash
sudo npm install -g cspotcode/nexe#19a5046
```

Now we should have the correct version of nexe for building.

Confirm by running:

```bash
nexe -v
```

![nexe-version](docs/nexe-version.jpg)

Check that the version is `4.0.0-beta.4`

### Compiling Executables

#### Compile Automatically

Run **build_win32.bat** on **Windows** to build a Windows Executable. This can be found in /dist/win32 and everything in that folder must be distributed together.
#### Compiling Executables

Run **build_macos** on **Mac** to build a Mac Executable. This can be found in /dist/macos and everything in that folder must be distributed together.
##### Compile Automatically
- **Windows** (on a Windows system):
Run the batch script `build_win32.bat` to build a Windows executable. This can be found in `/dist/win32` and everything in that folder must be distributed together.
- **macOS** (on a macOS system):
Run the shell script `build_macos` to build a macOS executable. This can be found in `/dist/macos` and everything in that folder must be distributed together.

If you wish to compile for Mac on Windows or Vice Versa, you can do so using the manual method below. This is trickier and will require obtaining a phantomjs binary built for the desired platform and placing it in the correct place.
If you wish to compile for macOS on Windows or vice versa, you can do so using the manual method below.


#### Compile Manually

To build a Windows Executable, run the command:
```bash
nexe . --target win32-x86-10.13.0 -o ./dist/win32/notion-pdf-export.exe
```
in the root directory of the project.

To build a Mac executable, run the command:
```bash
nexe . -t macos-10.13.0 -o ./dist/macos/npe
```
in the root directory of the project. Note that this is built under the name 'npe' which is done for a reason.

To distribute the Windows Executable, place it in a directory with the following:

- The original 'utils' folder from the source code


To distribute the Mac Executable (npe), place it in a directorywith the following:

- The original 'utils' folder from the source code
- An executable unix shell script with the following contents, called 'notion-pdf-export':
##### Compile Manually
- To build a **Windows** executable, in the root directory of the project, run the command:
```bash
nexe . --target win32-x86-10.13.0 -o ./dist/win32/notion-pdf-export.exe
```
When distributing the executable `notion-pdf-export.exe` must be placed in a directory with the original `utils` folder from the source.

- To build a **macOS** executable, in the root directory of the project, run the command:
```bash
nexe . -t macos-10.13.0 -o ./dist/macos/npe
```
Note that this is built under the name `npe` due to an issue with accessing the current directory.
When distributing, place the `npe` executable it in a directory with the following:
- The original `utils` folder from the source code
- An executable unix shell script with the following contents, with the file name of `notion-pdf-export`:
```bash
#/bin/bash
cd "$0"/..
./npe
```
This can be obtained from `mac_script.sh` or found inside `/dist/macos` This script is needed to set the current directory before the `npe` executable is run.

This can be obtained from 'mac_script.sh' or found inside /dist/macos

# Credits
## Credits

## wkhtmltopdf
### wkhtmltopdf

This project uses wkhtmltopdf for the conversions. This brilliant tool was created by [Jakob Truelsen](https://github.com/antialize) and is now maintained by [Ashish Kulkarni](https://github.com/ashkulz). Version `0.12.6` has been used, and can be [downloaded here](https://wkhtmltopdf.org/downloads.html).

wkhtmltopdf is released under the LGPL-3.0 License which can be found at `utils/wkhtmltopdf/LICENSE`. The source code is available at the [wkhtmltopdf repository](https://github.com/wkhtmltopdf/wkhtmltopdf).
wkhtmltopdf is released under the LGPL-3.0 License which can be found at `utils/wkhtmltopdf/LICENSE`. The source code is available at the [wkhtmltopdf repository](https://github.com/wkhtmltopdf/wkhtmltopdf).

## Assets
### Assets

<a href="https://iconscout.com/icons/notion" target="_blank">Notion Icon</a> by <a href="https://iconscout.com/contributors/Rengised">Alex Martinov</a> on <a href="https://iconscout.com">Iconscout</a>
Icon by [Alex Martynov](https://dribbble.com/Rengised) obtained from [IconScout](https://iconscout.com/icon/notion-3220890).
1 change: 1 addition & 0 deletions _config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
remote_theme: ganeshh123/gh-pages-custom-theme
Loading

0 comments on commit d21917d

Please sign in to comment.