Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akawashiro/jendeley
jendeley is a JSON-based document organizing software.
https://github.com/akawashiro/jendeley
nodejs paper pdf react
Last synced: 7 days ago
JSON representation
jendeley is a JSON-based document organizing software.
- Host: GitHub
- URL: https://github.com/akawashiro/jendeley
- Owner: akawashiro
- License: mit
- Created: 2022-11-23T07:28:11.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-16T23:05:44.000Z (about 1 month ago)
- Last Synced: 2025-01-10T18:15:40.201Z (14 days ago)
- Topics: nodejs, paper, pdf, react
- Language: TypeScript
- Homepage: https://akawashiro.github.io/jendeley/
- Size: 9.25 MB
- Stars: 129
- Watchers: 2
- Forks: 1
- Open Issues: 34
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# jendeley
`jendeley` is a JSON-based document organizing software.
- `jendeley` is JSON-based. You can see and edit your database quickly.
- `jendeley` works locally. Your important database is owned only by you. No cloud.
- `jendeley` is browser-based. You can run it anywhere node.js runs.## Table of Contents
- [Why jendeley?](#why-jendeley)
- [Quickstart](#quickstart)
- [Install](#install)
- [Generate JSON database file](#generate-json-database-file)
* [Recommended filename style](#recommended-filename-style)
* [When `jendeley` fails to scan your PDFs](#when-jendeley-fails-to-scan-your-pdfs)
- [Launch the service daemon and open the web user interface](#launch-the-service-daemon-and-open-the-web-user-interface)
* [Launch `jendeley` automatically](#launch-jendeley-automatically)
+ [Linux](#linux)
+ [Windows](#windows)
- [Use the web user interface](#use-the-web-user-interface)
* [Add a webpage](#add-a-webpage)
* [Add a PDF file on the Web](#add-a-pdf-file-on-the-web)
* [Upload a PDF file](#upload-a-pdf-file)
* [Use tags and comments](#use-tags-and-comments)
- [Advanced topics](#advanced-topics)
* [Check and edit your database (advanced)](#check-and-edit-your-database-advanced)
* [Check source code (advanced)](#check-source-code-advanced)
* [Use LLM (Large Language Model) to generate tags (advanced)](#use-llm-large-language-model-to-generate-tags-advanced)
- [Contact me](#contact-me)
- [Support me](#support-me)## Why jendeley?
As programmers, we need various documents in different formats, such as recent machine learning papers, classic compiler books, CPU and accelerator specification documents, programming language documents, and informative blog articles. To efficiently manage these documents, it's essential to categorize and classify them. Additionally, we need to ensure that they are saved and accessible long-term, as we never know when we need them.To address these challenges, I developed `jendeley`. It allows you to register both PDFs and webpages in the same database, making categorization easy through the use of tags. Moreover, the database is stored as a plain text JSON file, making it easily editable using your preferred editor. This means that even if `jendeley`'s development process ends, you can still access your information and create alternative applications to manage it.
## Quickstart
```console
$ npm install @a_kawashiro/jendeley -g
$ jendeley scan --papers_dir
$ jendeley launch --db /jendeley_db.json
```
Then you can see a screen like this!
![image](https://akawashiro.github.io/jendeley/blog100/top.png)## Install
```console
$ npm install @a_kawashiro/jendeley -g
```
You can find the latest package at [npm page](https://www.npmjs.com/package/@a_kawashiro/jendeley).## Generate JSON database file
```console
$ jendeley scan --papers_dir
```
This command outputs the database to `/jendeley_db.json`. If you have no PDF file, please specify an empty directory as ``.If `jendeley` encounters an issue scanning some PDFs, it generates a shell script named `edit_and_run.sh.` Please refer to the following subsection to learn how to rename the files accordingly, so that jendeley can properly recognize them.
### Recommended filename style
`jendeley` uses a filename to find the document ID (e.g., [DOI](https://www.doi.org/) or [ISBN](https://en.wikipedia.org/wiki/ISBN))). `jendeley` recognizes parts of a filename that are not enclosed by `[` and `]` as the title of the file. So I recommend you to name the file accordingly, for example,
- `RustHorn CHC-based Verification for Rust Programs.pdf`
- When the document's title includes spaces, the filename should include spaces.
- `RustHorn CHC-based Verification for Rust Programs [matushita].pdf`
- If you want to write additional information in a filename, please enclose it by `[` and `]`.### When `jendeley` fails to scan your PDFs
`jendeley` heavily relies on [DOI](https://www.doi.org/) or [ISBN](https://en.wikipedia.org/wiki/ISBN) to find the title, authors and the year of publication of PDFs. When DOI or ISBN can not be automatically found by `jendeley`, you can manually specify DOI of the PDF using the filename.- To specify DOI, change the filename to include `[jendeley doi ]`.
- For example, `cyclone [jendeley doi 10_1145_512529_512563].pdf`.
- To specify ISBN, change the filename to include `[jendeley isbn ]`.
- For example, `Types and Programming Languages [jendeley isbn 0262162091].pdf`.
- When the PDF doesn't have any DOI or ISBN, you can specify it by `[jendeley no id]`.
- For example, `ARM reference manual [jendeley no id].pdf`.## Launch the service daemon and open the web user interface
```
jendeley launch --db /jendeley_db.json
```
This command launches the jendeley daemon and opens the web user interface in your web browser at [http://localhost:5000](http://localhost:5000). You have the option to change the default port by using the --port option.### Launch `jendeley` automatically
#### Linux
When using Linux, you can set up `jendeley` to start automatically by using `systemd`. To do this, create a file named `~/.config/systemd/user/jendeley.service` with the following contents, and then run `systemctl --user enable jendeley && systemctl --user start jendeley`. Then, you can access `jendeley` at [http://localhost:5000](http://localhost:5000). Logs are accessible with the command `journalctl --user -f -u jendeley.service`.
```
# jendeley.service
[Unit]
Description=jendeley JSON-based document organization software[Service]
ExecStart=jendeley launch --db[Install]
WantedBy=default.target
```
#### Windows
When using Windows, you can set up `jendeley` to launch automatically at startup. To do this, first open the startup directory by pressing `Windows+R` and typing `shell:startup` and then pressing `Enter`.And make `autorun-jendeley.bat` with the following contents using `notepad.exe`.
```
:: autorun-jendeley.bat
jendeley launch --db >>
```## Use the web user interface
When `jendeley` launches, `jendeley` opens the web user interface automatically. If not, please access `http://localhost:5000/`.![image](./blog100/top.png)
### Add a webpage
You can add a webpage to the database using `REGISTER WEBPAGE` button. When you register, you can write tags or comments. Tags are just commas (`,`) separated text. By the way, the date tags are automatically added to the database.![Register webpage](./blog100/register_webpage.png "Register webpage")
### Add a PDF file on the Web
You can add a PDF file to the web by using the `REGISTER PDF FROM URL` button. When you add the file, `jendeley` will attempt to locate its [Digital object identifier (DOI)](https://www.doi.org/) or [International Standard Book Number (ISBN)](https://en.wikipedia.org/wiki/ISBN) and register the meta information, such as the author's name or publication date, to the database. In some cases, `jendeley` may not be able to find the DOI or ISBN for the PDF, or there may not be a corresponding DOI or ISBN for it. In such situations, you can specify the DOI or ISBN by using the filename. For more information, please refer to the [Recommended filename style](#recommended-filename-style) section.![Register PDF from URL](./blog100/register_pdf_from_url.png "Register PDF from URL")
### Upload a PDF file
You can upload a PDF file in your computer using `UPLOAD PDF` button.### Use tags and comments
You can edit tags or comments after you register. You can edit tags or comments by double-clicking them. Comments are interpreted as Markdown.![Edit comments](./blog100/comments-markdown.png "Edit comments")
Furthermore, you can filter the database using tags or comments.
![Filter by tag](./blog100/filter_by_tag.png "Filter by tag")## Advanced topics
### Check and edit your database (advanced)
Because `jendeley` is fully JSON-based, you can quickly check the database's contents.
```console
$ cat jendeley_db.json | jq '.' | head
{
"jendeley_meta": {
"idType": "meta",
"version": "0.0.17"
},
"doi_10.1145/1122445.1122456": {
"path": "/A Comprehensive Survey of Neural Architecture Search.pdf",
"idType": "doi",
"tags": [],
"comments": "",
```You can edit your database using your preferred editor. However, after making the changes, it is important to verify that your database is still valid as a `jendeley` database using the command `jendeley validate --db `.
### Check source code (advanced)
You can check the source code [https://github.com/akawashiro/jendeley](https://github.com/akawashiro/jendeley) here. We welcome your pull request.### Use LLM (Large Language Model) to generate tags (advanced)
You can use LLM to generate tags for your documents.
Launch the LLM server by running the following command.
```console
$ ./run_ollama.sh
```
You can find `./run_ollama.sh` at [run_ollama.sh](https://github.com/akawashiro/jendeley/tree/main/jendeley-backend/run_ollama.sh).Then, you can enable automatic tagging by setting the `--experimental_use_ollama_server` option when launching `jendeley`.
For example,
```console
$ jendeley launch --db /jendeley_db.json --experimental_use_ollama_server
```To run the LLM server automatically, you can use the following `systemd` service file.
```console
$ cat ~/.config/systemd/user/ollama-jendeley.service
# jendeley.service
[Unit]
Description=jendeley JSON-based document organization software[Service]
ExecStart=/node/v18.16.0/lib/node_modules/@a_kawashiro/jendeley/run_ollama.sh[Install]
WantedBy=default.target
$ systemctl --user enable ollama-jendeley
$ systemctl --user start ollama-jendeley
```To check the LLM server's status, you can use the following command.
```console
$ journalctl --user -f -u ollama-jendeley.service
```## Contact me
You can find me on Twitter at [https://twitter.com/a_kawashiro](https://twitter.com/a_kawashiro) and on Mastodon at [https://mstdn.jp/@a_kawashiro](https://mstdn.jp/@a_kawashiro). Additional contact information can be found on my website at [https://akawashiro.github.io/#links](https://akawashiro.github.io/#links). Also, feel free to create an issue or submit a pull request on [the repository](https://github.com/akawashiro/jendeley).## Support me
Please star [akawashiro/jendeley](https://github.com/akawashiro/jendeley). It encourages me a lot.