118 lines
7.6 KiB
Markdown
Raw Normal View History

2021-02-25 21:54:49 +03:30
2021-04-18 19:22:25 +04:30
| Build | Stable | Preview | Support Server |
|-------|----------|---------|---------|
2021-04-18 20:52:59 +04:30
| ![CI](https://github.com/Suwayomi/Tachidesk/actions/workflows/build_push.yml/badge.svg) | [![stable release](https://img.shields.io/github/release/Suwayomi/Tachidesk.svg?maxAge=3600&label=download)](https://github.com/Suwayomi/Tachidesk/releases) | [![preview](https://img.shields.io/badge/dynamic/json?url=https://github.com/Suwayomi/Tachidesk/raw/preview/index.json&label=download&query=$.latest&color=blue)](https://github.com/Suwayomi/Tachidesk/tree/preview/latest_pointer) | [![Discord](https://img.shields.io/discord/801021177333940224.svg?label=discord&labelColor=7289da&color=2c2f33&style=flat)](https://discord.gg/DDZdqZWaHA) |
2021-04-18 19:22:25 +04:30
# Tachidesk
2021-04-18 20:05:58 +04:30
<img src="https://github.com/Suwayomi/Tachidesk/raw/master/server/src/main/resources/icon/faviconlogo.png" alt="drawing" width="200"/>
2021-01-22 11:13:25 +03:30
A free and open source manga reader that runs extensions built for [Tachiyomi](https://tachiyomi.org/).
Tachidesk is an independent Tachiyomi compatible software, **not a Fork** of Tachiyomi.
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-03-28 06:00:34 +04:30
- A decent chapter reader.
2021-02-22 01:23:44 +03:30
- Ability to download Mangas for offline read(This partially works)
2021-04-10 01:18:15 +04:30
- Backup and restore support powered by Tachiyomi Legacy Backups
2021-02-22 01:23:44 +03:30
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
2021-03-24 19:24:50 +04:30
Anyways, for more info checkout [finished milestone #1](https://github.com/Suwayomi/Tachidesk/issues/2) and [milestone #2](https://github.com/Suwayomi/Tachidesk/projects/1) to see what's implemented in more detail.
2021-02-22 01:23:44 +03:30
2021-02-22 01:28:13 +03:30
## Downloading and Running the app
2021-03-16 16:04:29 +03:30
### All Operating Systems
You should have The Java Runtime Environment(JRE) 8 or newer and a modern browser installed. Also an internet connection is required as almost everything this app does is downloading stuff.
2021-04-10 10:09:25 +04:30
Download the latest "Stable" jar release from [the releases section](https://github.com/Suwayomi/Tachidesk/releases) or a preview jar build from [the preview branch](https://github.com/Suwayomi/Tachidesk/tree/preview).
2021-03-16 23:24:14 +03:30
2021-04-10 10:13:56 +04:30
Double click on the jar file or run `java -jar Tachidesk-vX.Y.Z-rxxx.jar` (or `java -jar Tachidesk-latest.jar` if you have the latest preview) 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-03-16 23:14:36 +03:30
### Windows
2021-03-24 19:24:50 +04:30
Download the latest win32 release from [the releases section](https://github.com/Suwayomi/Tachidesk/releases).
2021-03-16 23:24:14 +03:30
The Windows specific build has java bundled inside, 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 works like the previous section.
2021-02-13 21:25:49 +03:30
2021-03-16 23:13:44 +03:30
### Arch Linux
You can install Tachidesk from the AUR
```
yay -S tachidesk
```
2021-03-16 23:14:36 +03:30
### 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-04-15 15:57:42 +04:30
If the app breaks, make sure that it's not running(right click on tray icon and quit or kill it through the way your Operating System provides), delete the directory below and re-run the app (**This procedure will delete all your data!**) and if the problem persists open an issue or ask for help on discord.
2021-02-22 01:23:44 +03:30
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-03-14 20:28:23 +03:30
On Windows 7 and later : `C:\Users\<Account>\AppData\Local\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
2021-04-18 19:40:25 +04:30
Join Tachidesk's [discord server](https://discord.gg/DDZdqZWaHA) to hang out with the community and to receive support and help.
2021-02-22 01:23:44 +03:30
## 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
2021-03-24 19:24:50 +04:30
### Prerequisite: Get Android stubs jar
2021-01-19 21:40:44 +03:30
#### Manual download
2021-03-24 19:24:50 +04:30
Download [android.jar](https://raw.githubusercontent.com/Suwayomi/Tachidesk/android-jar/android.jar) and put it under `AndroidCompat/lib`.
2021-04-10 10:16:24 +04:30
#### Automated download
2021-03-24 20:34:32 -04:00
Run `AndroidCompat/getAndroid.sh`(MacOS/Linux) or `AndroidCompat/getAndroid.ps1`(Windows) from project's root directory to download and rebuild the jar file from Google's repository.
2021-03-25 01:03:51 +04:30
### Prerequisite: Software dependencies
You need this software packages installed in order to build this project:
- Java Development Kit and Java Runtime Environment version 8 or newer(both Oracle JDK and OpenJDK works)
- Nodejs LTS or latest
- Yarn
2021-04-30 06:15:56 +04:30
- Git
2021-03-24 19:24:50 +04:30
### building the full-blown jar
2021-03-30 20:21:58 +04:30
Run `./gradlew :webUI:copyBuild server:shadowJar`, the resulting built jar file will be `server/build/Tachidesk-vX.Y.Z-rxxx.jar`.
### building without `webUI` bundled(server only)
Delete the `server/src/main/resources/react` directory if exists from previous runs, then run `./gradlew server: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-03-30 20:21:58 +04:30
Run `./gradlew :server:windowsPackage` to build a server only bundle and `./gradlew :webUI:copyBuild :server:windowsPackage` to get a full bundle , 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
2021-03-30 20:21:58 +04:30
Follow [Get Android stubs jar](#prerequisite-get-android-stubs-jar) then run `./gradlew :server:run --stacktrace` to run the server
2021-01-22 00:23:53 +03:30
### `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)
2021-03-30 20:21:58 +04:30
then `yarn start` to start the development server, if a new browser window doesn't get opned 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-03-25 18:32:31 +04:30
This project is a spiritual successor of [TachiWeb-Server](https://github.com/Tachiweb/TachiWeb-server), Many of the ideas and the groundwork adopted in this project comes from TachiWeb.
2021-03-25 18:21:14 +04:30
2021-03-14 01:02:43 +03:30
The `AndroidCompat` module 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
Copyright (C) Contributors to the Suwayomi project
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/.