Skip to content

Latest commit

 

History

History
171 lines (135 loc) · 8.59 KB

README.md

File metadata and controls

171 lines (135 loc) · 8.59 KB

Decky QuickStart Template

A modified version of the Decky Plugin Template that helps you get up and running faster, and includes a variety of quality of life changes.

Features

  • Global state, backend interop, logging, and intialization are all already set up.
  • Automatic changelog generation and plugin building with GitHub Actions.
  • Intuitive project structure.
  • Helpful comments throughout.
  • Examples of patching.

Examples of Plugins Made with QuickStart

  • Deck P2P - A Steamdeck plugin for Peer-2-Peer networking in gamemode.

Developing Your Plugin

Setup

  1. Install the recommended VSCode extensions for this repository
  2. Enable SSH on your steamdeck. I recommend this guide. I also find that automatically starting the ssh server is incredibly useful during dev
  3. Get your deck's ip address with hostname -I or in the settings in game mode
  4. In VSCode, go to the Remote Explorer tab, and add a new target. Enter your_deck_user@ip_address in the field, and then connect with your sudo password
  5. Once you've connected, open the Desktop directory of your Steamdeck (you'll need to enter your password again)
  6. (Optional) make a directory to store your in dev plugins in (ex: I made a dev-plugins directory)
  7. Run sudo ln -s ~/Desktop/dev-plugins/YourPluginName ~/homebrew/plugins (This is to avoid having to authenticate every time you edit your plugin)

Deploying

  1. In your plugin directory (on your machine), run pnpm build
  2. Copy plugin.json, package.json, LICENSE, main.py into the directory on your Steamdeck you made earlier
  3. Copy dist/index.js into the same directory (it should look like ~/Desktop/dev-plugins/YourPluginName/dist/index.js)
  4. If you have files in ./defaults, copy those into the directory as well (ex: ./defaults/docs becomes ~/Desktop/dev-plugins/YourPluginName/docs)
  5. Run sudo systemctl restart plugin_loader on your deck

Debugging

  • Backend: logs are output to ~/homebrew/logs/YourPluginName/logs (the log files are organized by date and time). These are useful for checking for debugging your python files
  • Frontend: logs are output to the CEF console (if you use the LogController, they are also sent to the backend log file). For more details on using the CEF debugger, check the deckbrew wiki

Components of a Decky Plugin

Configuration

plugin.json

This is the core config file for your plugin

{
  "name": "", // The name of your plugin
  "author": "", // Your name/username
  "flags": [], // Flags for your plugin. Most common ones include "debug" and "root"
  "publish": {
    "tags": [], // These tags will show up on the decky store. Put key terms for your plugin here
    "description": "", // The store description for your plugin
    "image": "" // The store image for your plugin
  }
}

package.json

Your typical Node.js package.json. Contains info about the project, the author, where to report bugs, etc.

The definePlugin Method

This method contains additional configuration options for your plugin

export default definePlugin((serverAPI: ServerAPI) => {
  // This function is run when the plugin is initialized. See index.tsx for more info.

  return {
    title: <div className={staticClasses.Title}>Your Plugin's Name</div>, // The name to show in the QAM
    content: <QuickAccessContent />, // A react component containing the plugin's QAM content.
    icon: <LuPartyPopper />, // A react icon that represents the plugin
    alwaysRender: false, // Whether the plugin's state should be preserved while the QAM is closed.
    onDismount: () => {
      // Function to run when the plugin dismounts
    }
  };
});

Resources

Any additional files your plugin uses (such as bash scripts, images, etc) can be put in the defaults directory. These files/folders will be moved to the root of the plugin during install. For example, ./YourPlugin/defaults/myScript.sh becomes ./YourPlugin/myScript.sh when installed.

The Frontend

This is where the majority of a plugin usually goes. You can add custom routes and modals, modify the SteamOS UI, and much much more. This is all done with the help of the Decky Frontend Lib.

The Backend

Python

The core of a plugin's backend is written in Python. This is where any interaction with the filesystem and hardware as well as saving/loading settings will occur. This can be left extremely barebones if you don't need it, but most plugins at least use main.py for setting up logging and settings.

Compiled Binaries

I'm not very familiar with this process but effectively you can write your backend in another language and run the compiled binary from python. Take a look at Powertools for a good reference.

Your TODO

  • package.json
    • Change the plugin name
    • Change the the author name
    • Change the description
    • Change all git urls
    • Change the keywords
  • plugin.json
    • Change the plugin name
    • Change the the author name
    • Change description
    • Change the tags
  • src/index.tsx
    • Change the display name on line #48
  • src/components/QuickAccessContent.tsx
    • Change QuickStart on line line #30
    • Change the Git and Discord Urls starting on line #35
  • src/components/styles/QamStyles.tsx
    • Change all instances of quick-start to your plugin's name
  • src/lib/PluginController.tsx
    • Change the name and color used for the Logger on line #24
  • main.py
    • Change the name QuickStart on line #109
    • Define your settings getters on line #47
    • Define your settings setters on line #65
    • Load your settings initially on line #61
  • .github/workflows/release.yml
    • replace QuickStart with your plugin's name on line #49
    • replace QuickStart with your plugin's name on line #82
    • replace QuickStart with your plugin's name on line #136
    • replace QuickStart with your plugin's name on line #152
    • replace QuickStart with your plugin's name on line #163
  • Remove any files you dont need

Publishing Your Plugin

  1. Create a logo and place it in ./assets/. (I recommend overlaying it over a screenshot of the plugin)
  2. Fork decky-plugin-database and make a new branch with the name of your plugin
  3. Open up your fork on your computer, and add your plugin as a Git Submodule (see below)
  4. Push the changes
  5. Make a Pull Request to the decky-plugin-database repository

Making Updates

  1. Sync the branch of your decky-plugin-database fork
  2. Open up your fork on your computer, and update the Git Submodule for your plugin (see below)
  3. Push the changes
  4. Make a Pull Request to the decky-plugin-database repository

Good Practices

  • All custom styling rules should be wrapped in a scoping class with the name of your plugin in it
  • Use @decky/ui where ever possible, to reduce maintenance required for your plugin
  • If you find new components, PR them to @decky/ui so others can use them and they won't break in the future
  • Notify users when errors occur in your plugin
  • Validate your settings after they are loaded on the frontend, sometimes weird things happen to your settings file, or users try to edit them by hand
  • Always define fallbacks for settings when loading them, and check for errors

Adding a Git Submodule

  1. git submodule add <plugin git url> "plugins/YourPluginName"
  2. git submodule update --init "plugins/YourPluginName"

Updating a Git Submodule

  1. git submodule update --init "plugins/YourPluginName"
  2. git submodule update --remote "plugins/YourPluginName"

Other Good Resources

Licensing

This program is licensed under the GNU General Public License Version 3 and BSD 3-Clause License