GithubHelp home page GithubHelp logo

popsulfr / decky-loader Goto Github PK

View Code? Open in Web Editor NEW

This project forked from steamdeckhomebrew/decky-loader

0.0 1.0 0.0 956 KB

A plugin loader for the Steam Deck

Home Page: https://deckbrew.xyz

License: GNU General Public License v2.0

Shell 8.78% JavaScript 2.07% Python 35.44% TypeScript 53.71%

decky-loader's Introduction

Deckbrew logo
Decky Loader
Download decky



Decky screenshot

๐Ÿ“– About

Decky Loader is a homebrew plugin launcher for the Steam Deck. It can be used to stylize your menus, change system sounds, adjust your screen saturation, change additional system settings, and more.

For more information about Decky Loader as well as documentation and development tools, please visit our wiki.

๐ŸŽจ Features

๐Ÿงน Clean injecting and loading of multiple plugins.
๐Ÿ”’ Stays installed between system updates and reboots.
๐Ÿ”— Allows two-way communication between plugins and the loader.
๐Ÿ Supports Python functions run from TypeScript React.
๐ŸŒ Allows plugins to make fetch calls that bypass CORS completely.

๐Ÿค” Common Issues

  • Crankshaft is incompatible with Decky Loader. If you are using Crankshaft, please uninstall it before installing Decky Loader.
  • Syncthing may use port 8080 on Steam Deck, which Decky Loader needs to function. If you are using Syncthing as a service, please change its port to something else.
  • If you are using any software that uses port 1337 or 8080, please change its port to something else or uninstall it.

๐Ÿ’พ Installation

  • This installation can be done without an admin/sudo password set.
  1. Prepare a mouse and keyboard if possible.
    • Keyboards and mice can be connected to the Steam Deck via USB-C or Bluetooth.
    • Many Bluetooth keyboard and mouse apps are available for iOS and Android.
    • The Steam Link app is available on Windows, macOS, and Linux. It works well as a remote desktop substitute.
    • If you have no other options, use the right trackpad as a mouse and press + to open the on-screen keyboard as needed.
  2. Press the button and open the Power menu.
  3. Select "Switch to Desktop".
  4. Navigate to this Github page on a browser of your choice.
  5. Press the 'Download' button at the top of the page.
  6. Run the downloaded file by clicking on it in Dolphin (the file manager).
  7. Either type your admin password or allow Decky to temporarily set your password to Decky!
  8. Choose the version of Decky Loader you want to install.
    • Latest Release
      Intended for most users. This is the latest stable version of Decky Loader.
    • Latest Pre-Release
      Intended for plugin developers. Pre-releases are unlikely to be fully stable but contain the latest changes. For more information on plugin development, please consult the wiki page.
  9. Open the Return to Gaming Mode shortcut on your desktop.
  • There is also a fast install for those who can use Konsole. Run curl -L https://github.com/SteamDeckHomebrew/decky-installer/releases/latest/download/install_release.sh | sh and type your password when prompted.

๐Ÿ‘‹ Uninstallation

We are sorry to see you go! If you are considering uninstalling because you are having issues, please consider opening an issue or joining our Discord so we can help you and other users.

  1. Press the button and open the Power menu.
  2. Select "Switch to Desktop".
  3. Run the installer file again, and select uninstall decky loader
  • There is also a fast uninstall for those who can use Konsole. Run curl -L https://github.com/SteamDeckHomebrew/decky-installer/releases/latest/download/uninstall.sh | sh and type your password when prompted.

๐Ÿš€ Getting Started

Now that you have Decky Loader installed, you can start using plugins. Each plugin is maintained by a different developer and has its own uses, but most follow a general structure outlined below.

๐Ÿ“ฆ Plugins

  1. Press the button and navigate to the icon. This is the Decky menu used for interacting with plugins and the loader itself.
  2. Select the icon to open the Plugins Browser. This is where you can find and install plugins.
    • You can also install from URL in the Settings menu. We do not recommend installing plugins from untrusted sources.
  3. To install a plugin, select the "Install" button on the plugin you want. You can also select a version from a dropdown menu, but this is not recommended.
  4. To update, uninstall, and reload plugins, navigate to the Decky menu and select the icon.
    • Keep in mind that uninstalling a plugin will only remove its plugin files, not any other files it may have created.

๐Ÿ› ๏ธ Plugin Development

There is no complete plugin development documentation yet. However a good starting point is the plugin template repository. Consider joining our Discord if you have any questions.

๐Ÿค Contributing

Please consult the wiki page regarding development for more information on installing development versions of Decky Loader. You can also install the Steam Deck UI on a Windows or Linux computer for testing by following this YouTube guide.

  1. Clone the repository using the latest commit to main before starting your PR.
  2. In your clone of the repository, run these commands.
    pnpm i
    pnpm run build
  3. If you are modifying the UI, these commands will need to be run before deploying the changes to your Steam Deck.
  4. Use the VS Code tasks or deck.sh script to deploy your changes to your Steam Deck to test them.
  5. You will be testing your changes with the Python script version. You will need to build, deploy, and reload each time.

โš ๏ธ If you are recieving build errors due to an out of date library, you should run this command inside of your repository.

pnpm update decky-frontend-lib --latest

Source control and deploying plugins are left to each respective contributor for the cloned repos in order to keep dependencies up to date.

๐Ÿ“œ Credits

The original idea for the plugin loader concept is based on the work of marios8543's Steam Deck UI Inject project.

decky-loader's People

Contributors

aagaming00 avatar beebls avatar botatooo avatar danburkhardt avatar dependabot[bot] avatar eddiedover avatar emerald0874 avatar frogthefrog avatar ggppjj avatar godev87 avatar hulkrelax avatar joamjoamjoam avatar johnnycrazy avatar jurassicplayer avatar liamdawe avatar marios8543 avatar ngnius avatar omgduke avatar partywumpus avatar patkub avatar popsulfr avatar proendreeper avatar rodoma92 avatar scrumplex avatar spyrexde avatar suchmememanyskill avatar toyvo avatar traindoctor avatar ttay24 avatar werwolv avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.