94 lines
5.4 KiB
Markdown
Raw Normal View History

2021-02-25 21:54:49 +03:30
![image](https://github.com/AriaMoradi/Tachidesk/raw/master/server/src/main/resources/icon/faviconlogo.png)
# Tachidesk
2021-01-22 11:13:25 +03:30
A free and open source manga reader that runs extensions built for [Tachiyomi](https://tachiyomi.org/).
2021-01-22 11:25:11 +03:30
Tachidesk is as multi-platform as you can get. Any platform that runs java and/or has a modern browser can run it.
2021-01-22 00:34:49 +03:30
Ability to read and write Tachiyomi compatible backups and syncing is a planned feature.
2021-02-22 01:23:44 +03:30
## Is this application usable? Should I test it?
Here is a list of current features:
- Installing and executing Tachiyomi's Extensions, So you'll get the same sources.
- A library to save your mangas and categories to put them into.
2021-02-22 14:48:17 +03:30
- Searching and browsing installed sources.
2021-02-22 14:49:17 +03:30
- A minimal chapter reader.
2021-02-22 01:23:44 +03:30
- Ability to download Mangas for offline read(This partially works)
2021-02-22 01:28:13 +03:30
**Note:** Keep in mind that Tachidesk is alpha software and can break rarely and/or with each update, so you may have to delete your data to fix it. See [General troubleshooting](#general-troubleshooting) and [Support and help](#support-and-help) if it happens.
2021-02-22 01:23:44 +03:30
Anyways, for more info checkout [finished milestone #1](https://github.com/AriaMoradi/Tachidesk/issues/2) and [milestone #2](https://github.com/AriaMoradi/Tachidesk/projects/1) to see what's implemented in more detail.
2021-02-22 01:28:13 +03:30
## Downloading and Running the app
2021-01-23 00:23:40 +03:30
#### Prerequisites
2021-02-05 11:47:17 +03:30
You should have The Java Runtime Environment(JRE) 8 or newer (if you're not planning to use the Windows specific build) and a modern browser installed. Also an internet connection is required as almost everything this app does is downloading stuff.
2021-01-23 00:23:40 +03:30
2021-02-13 17:18:31 +03:30
#### Download the app
Download the latest jar or windows(win32) release from [the releases section](https://github.com/AriaMoradi/Tachidesk/releases).
2021-01-22 00:23:53 +03:30
2021-02-13 17:18:31 +03:30
#### Running pre-built jar packages
Double click on the jar file or run `java -jar Tachidesk-vX.Y.Z-rxxx.jar` from a Terminal/Command Prompt window to run the app which will open a new browser window automatically. Also the System Tray Icon is your friend if you need to open the browser window again or close Tachidesk.
2021-02-05 00:46:46 +03:30
2021-02-05 11:47:17 +03:30
#### Running pre-built Windows packages
2021-02-13 17:18:31 +03:30
Windows specific builds have java bundled inside them, so you don't have to install java to use it. Unzip `Tachidesk-vX.Y.Z-rxxx-win32.zip` and run `server.exe`, the rest will work like the jar release.
2021-02-13 21:25:49 +03:30
#### Running on Docker
Check [arbuilder's repo](https://github.com/arbuilder/Tachidesk-docker) out for more details and the dockerfile.
2021-02-13 21:25:49 +03:30
2021-02-22 01:28:13 +03:30
## General troubleshooting
2021-02-22 01:23:44 +03:30
If the app breaks try deleting the directory below and re-running the app (**This will delete all your data!**) and if the problem persists open an issue.
On Mac OS X : `/Users/<Account>/Library/Application Support/Tachidesk`
2021-02-22 01:29:55 +03:30
2021-02-22 14:51:39 +03:30
On Windows XP : `C:\Documents and Settings\<Account>\Application Data\Local Settings\Tachidesk`
2021-02-22 01:29:55 +03:30
2021-02-22 14:54:04 +03:30
On Windows 7 and later : `C:\Users\<Account>\AppData\Tachidesk`
2021-02-22 01:29:55 +03:30
2021-02-22 01:23:44 +03:30
On Unix/Linux : `/home/<account>/.local/share/Tachidesk`
## Support and help
Join Tachidesk's [discord server](https://discord.gg/wgPyb7hE5d) to hang out with the community and receive support and help.
## How does it work?
This project has two components:
1. **server:** contains the implementation of [tachiyomi's extensions library](https://github.com/tachiyomiorg/extensions-lib) and uses an Android compatibility library to run apk extensions. All this concludes to serving a REST API to `webUI`.
2. **webUI:** A react SPA project that works with the server to do the presentation.
2021-01-22 00:23:53 +03:30
## Building from source
### Get Android stubs jar
2021-01-19 21:40:44 +03:30
#### Manual download
Download [android.jar](https://raw.githubusercontent.com/AriaMoradi/Tachidesk/android-jar/android.jar) and put it under `AndroidCompat/lib`.
2021-02-05 11:44:24 +03:30
#### Automated download(needs `bash`, `curl`, `base64`, `zip` to work)
2021-01-22 00:23:53 +03:30
Run `scripts/getAndroid.sh` from project's root directory to download and rebuild the jar file from Google's repository.
2021-01-20 03:17:43 +03:30
### building the jar
2021-02-05 00:46:46 +03:30
Run `./gradlew shadowJar`, the resulting built jar file will be `server/build/Tachidesk-vX.Y.Z-rxxx.jar`.
2021-02-05 11:46:29 +03:30
### building the Windows package
2021-02-05 00:46:46 +03:30
Run `./gradlew windowsPackage`, the resulting built zip package file will be `server/build/Tachidesk-vX.Y.Z-rxxx-win32.zip`.
2021-01-22 01:45:14 +03:30
## Running for development purposes
2021-01-22 00:23:53 +03:30
### `server` module
Run `./gradlew :server:run -x :webUI:copyBuild --stacktrace` to run the server
### `webUI` module
How to do it is described in `webUI/react/README.md` but for short,
2020-12-24 22:36:39 +03:30
first cd into `webUI/react` then run `yarn` to install the node modules(do this only once)
2020-12-24 15:46:42 +03:30
then `yarn start` to start the client if a new browser window doesn't start automatically,
then open `http://127.0.0.1:3000` in a modern browser. This is a `create-react-app` project
and supports HMR and all the other goodies you'll need.
2021-01-21 13:41:03 +03:30
## Credit
2021-01-21 13:58:49 +03:30
The `AndroidCompat` module and `scripts/getAndroid.sh` was originally developed by [@null-dev](https://github.com/null-dev) for [TachiWeb-Server](https://github.com/Tachiweb/TachiWeb-server) and is licensed under `Apache License Version 2.0`.
2021-01-21 13:42:17 +03:30
Parts of [tachiyomi](https://github.com/tachiyomiorg/tachiyomi) is adopted into this codebase, also licensed under `Apache License Version 2.0`.
2021-01-21 13:41:03 +03:30
2021-01-29 19:11:38 +03:30
You can obtain a copy of `Apache License Version 2.0` from http://www.apache.org/licenses/LICENSE-2.0
2021-01-26 23:07:54 +03:30
2021-01-29 19:11:38 +03:30
Changes to both codebases is licensed under `MPL v. 2.0` as the rest of this project.
2021-01-26 23:02:04 +03:30
## License
2021-01-21 13:58:15 +03:30
Copyright (C) 2020-2021 Aria Moradi and contributors
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
2021-01-03 03:16:17 +03:30
file, You can obtain one at http://mozilla.org/MPL/2.0/.