<p align="center">
  <img src="https://github.com/cchrkk/NSLOSD-DL/raw/main/logo.svg" width=40% height=auto
</p>

<h1 align="center">
NonSteamLaunchers ๐Ÿš€
</h1>

This script installs the latest GE-Proton, installs NonSteamLaunchers under one unique Proton prefix folder in your compatdata folder path called "NonSteamLaunchers" and adds them to your Steam Library. 
So you can use them on Desktop or in Game Mode.

<h1 align="center">
Features  โœ…
</h1>

- Automatic installation of the most popular launchers in your Steam Deck ๐ŸŽฎ
- Handle automatically the download and installation of your chosen launchers โŒš
- MicroSD Support ๐Ÿ’พ This script supports moving the entire prefix to a microSD. The script will install launchers and games to your SD card, and the launchers in Steam will point to the SD card installation. This allows you to save internal storage space on your Steam Deck!

<h1 align="center">
Supported Stores ๐Ÿ›
</h1>

- Amazon Games Launcher โœ”๏ธ
- Battle.net โœ”๏ธ
- EA App โœ”๏ธ
- Epic Games โœ”๏ธ
- GOG Galaxy โœ”๏ธ
- Humble Games Collection โœ”๏ธ
- IndieGala โœ”๏ธ
- Itch.io โœ”๏ธ
- Legacy Games โœ”๏ธ
- Origin (only working way) โœ”๏ธ
- Rockstar Games Launcher โœ”๏ธ
- Ubisoft Connect โœ”๏ธ
- Glyph โœ”๏ธ
- Minecraft โœ”๏ธ
- Playstation Plus โœ”๏ธ
- DMM Games Player โœ”๏ธ
- VK Play โœ”๏ธ

<h1 align="center">
Supported Streaming Sites for games and as well as any website. ๐ŸŒ
</h1>

- Shortcut Creator โœ”๏ธ
- Xbox Game Pass โœ”๏ธ
- GeForce Now โœ”๏ธ
- Amazon Luna โœ”๏ธ
- Netflix โœ”๏ธ
- Amazon Prime Video โœ”๏ธ
- Disney+ โœ”๏ธ
- Hulu โœ”๏ธ
- Youtube โœ”๏ธ
- Twitch โœ”๏ธ

<h1 align="left">
Find Games
</h1>

Use the "Find Games" button to load [Boilr](https://github.com/PhilipK/BoilR) this will open Boilr for you to set your settings so you can find your games easier. 

"NSLGameScanner.service" is also live when you use this script and continues after the script is closed and even works after your Steam Deck has restarted. This works in the background as a service file to automatically add your games to your library on every Steam restart. Currently only adds Epic Games Launcher and Ubisoft Connect games.

<h1 align="center">
How to Install ๐Ÿ”ง
</h1>

<p align="center">
  <a name="download button" href="https://github.com/cchrkk/NSLOSD-DL/releases/download/DlLinkFix/NonSteamLaunchers.desktop"><img src="https://user-images.githubusercontent.com/98482469/242361563-33f31d3d-9a69-4fca-a928-207a5d17a98f.png"  alt="Download NonSteamLaunchers" width="350px" style="padding-top: 15px;"></a>
</p>
<!--- Thanks https://github.com/Heus-Sueh -->

* Go to desktop mode, right click the download button above and save the .desktop file to your Steam Deck desktop. 
* Go to your desktop, click the NonSteamLaunchers icon, it will download and run the latest NonSteamLaunchers.sh from this repository and run it.
* You will simply have to choose which launcher to install and let the script handle the rest. ๐Ÿ’ป No files are left in your "Downloads" they are deleted after installation.
* After running the script, launch Steam on your Steam Deck. You'll find the new launchers in your library under the non-steam tab. Click a launcher to see your installed games from that store, and launch them directly from Steam! Even in gamemode ๐Ÿฅณ

<!--- TODO: handful of broken icons (cf. ๐Ÿกบ๐Ÿกบ๐Ÿกบ ); probably should remove or replace them with more common font to handle unicode-->

<p align="center">
โ–ถ๏ธ YouTube Tutorial ๐Ÿกบ๐Ÿกบ๐Ÿกบ https://www.youtube.com/watch?v=svOj4MTEAVc ๐Ÿกธ๐Ÿกธ๐Ÿกธ โ–ถ๏ธ
</p>
<p align="center">
๐Ÿ“– Step-by-step Article ๐Ÿกบ๐Ÿกบ๐Ÿกบ https://www.steamdeckgaming.net/post/easy-launchers-install-on-steam-deck ๐Ÿกธ๐Ÿกธ๐Ÿกธ ๐Ÿ“–
</p>

<h1 align="center">
How to Uninstall ๐Ÿ—‘
</h1>

+ Just run the script, select which launchers to remove. Press OK.
+ That's it.

<h1 align="center">
Currently Working On ๐Ÿ‘ทโ€โ™‚๏ธ
</h1>

* Decky Loader Plugin โŒ 
* Integrate better with [BoilR](https://github.com/PhilipK/BoilR) โŒ 

<h1 align="center">
Contributing ๐Ÿค
</h1>

If you have any suggestions or improvements for this script, feel free to open an issue or submit a pull request.

You can donate to me on [ko-fi](https://ko-fi.com/moraroy), [liberapay](https://liberapay.com/moraroy), or [sponsor me on github](https://github.com/sponsors/moraroy)

## Development Environment

### Dev Container

Install [Docker](https://docs.docker.com/compose/install/). Once installed, a clean dev environment with a Docker container [native to VSCode](https://code.visualstudio.com/docs/devcontainers/create-dev-container#_dockerfile) is spun up automatically. 

* [Command palette](https://code.visualstudio.com/docs/getstarted/userinterface#_command-palette) (โ‡งโŒ˜P) > Dev Containers: Reopen in Container
* F5 for debug
    * May need to select interpreter (e.g., `/opt/venv/bin/python`) first

**VSCode Extensions (Dev Container)**

* [Atom Keymap](https://marketplace.visualstudio.com/items?itemName=ms-vscode.atom-keybindings)
* [Bash IDE](https://marketplace.visualstudio.com/items?itemName=mads-hartmann.bash-ide-vscode)
* [Better Comments](https://marketplace.visualstudio.com/items?itemName=aaron-bond.better-comments)
* [Docker](https://marketplace.visualstudio.com/items?itemName=ms-azuretools.vscode-docker)
* [EditorConfig](https://marketplace.visualstudio.com/items?itemName=EditorConfig.EditorConfig)
* [GitHub Copilot](https://marketplace.visualstudio.com/items?itemName=GitHub.copilot)
* [GitHub Copilot Chat](https://marketplace.visualstudio.com/items?itemName=GitHub.copilot-chat)
* [gitignore](https://marketplace.visualstudio.com/items?itemName=codezombiech.gitignore)
* [GitLens](https://marketplace.visualstudio.com/items?itemName=eamodio.gitlens)
* [Markdown All in One](https://marketplace.visualstudio.com/items?itemName=yzhang.markdown-all-in-one)
* [MS Visual Studio Live Share](https://marketplace.visualstudio.com/items?itemName=MS-vsliveshare.vsliveshare)
* [Python](https://marketplace.visualstudio.com/items?itemName=ms-python.python)
* [Shellcheck](https://marketplace.visualstudio.com/items?itemName=timonwong.shellcheck)

### Manual Docker Instance

If VSCode isn't present or only the python portion (cf. `__init__.py`) is being worked on, it's possible to just run a Docker container on its own. The container installs the correct version of python and any dependencies (e.g., ipython, rich) in `requirements.txt`.

```bash
# navigate to directory with Dockerfile
cd .devcontainer/

# build image
docker build -t nonsteamlaunchers .

# run container
docker run -it --rm --name=mynonsteamlaunchers --workdir=/app -v $(pwd):/app nonsteamlaunchers bash

# exit container
exit
```

### Python virtual environment

Useful for the python module(s), but extra compared to the [dev container](#dev-container) portion that covers the core shell script.

```bash
# create virtual environment
python -m venv .venv

# activate virtual environment
source .venv/bin/activate

# install dependencies
python -m pip install -r requirements.txt 
```

### Additional tooling

Additional tooling includes but is not limited to:

#### asdf

* Install [asdf](https://asdf-vm.com/guide/getting-started.html#_2-download-asdf)
* Usage
    ```bash
    # add python plugin
    asdf plugin-add python

    # install stable python
    asdf install python <latest|3.11.4>

    # set stable to system python
    asdf global python latest

    # add poetry asdf plugin
    asdf plugin-add poetry https://github.com/asdf-community/asdf-poetry.git

    # install latest version via asdf
    asdf install poetry <latest|1.5.1>

    # set latest version as default
    asdf global poetry latest
    ```

#### shellcheck

`.shellcheckrc` excludes various [bash language rules](https://github.com/koalaman/shellcheck/wiki/Ignore#ignoring-one-or-more-types-of-errors-forever). Useful to control noise vs. legitimate warnings/errors when using the shellcheck extension.

<h1 align="center">
License ๐Ÿ“
</h1>

This project is licensed under the MIT License. See the `LICENSE` file for more information.