remix-save-game

SKILL.md

Integrate Save Game State Workflow

Overview

This skill guides you through integrating save game state into an HTML game on the Remix platform. Save game state lets players persist progress across sessions -- scores, unlocked levels, inventory, and more -- using the RemixSDK.

Prerequisites

  • The game must include the RemixSDK script tag:
    <script src="https://cdn.jsdelivr.net/npm/@remix-gg/sdk@latest/dist/index.min.js"></script>
    
  • The game must already be playable (follow the game-creation workflow first if starting from scratch).

Steps

1. Initialize the SDK

Call await window.RemixSDK.ready() before the game loop starts. This ensures the SDK is loaded and any existing saved state is available.

await window.RemixSDK.ready();

2. Load Existing State

Read window.RemixSDK.gameState to get previously saved data. It returns Record<string, unknown> | null | undefined -- always check for null before using it.

const savedState = window.RemixSDK.gameState;

Use the saved state to restore game progress, or fall back to defaults if the player is starting fresh:

const state = savedState ?? { score: 0, level: 1 };

3. Save State During Gameplay

Call saveGameState whenever the player reaches a meaningful checkpoint. The gameState value must be a JSON-serializable object.

window.RemixSDK.singlePlayer.actions.saveGameState({
  gameState: { score: player.score, level: player.level },
});

Examples

Simple Clicker Game

<script>
  let clicks = 0;

  async function init() {
    await window.RemixSDK.ready();

    // Load
    const gameState = window.RemixSDK.gameState;
    if (gameState && typeof gameState.clicks === "number") {
      clicks = gameState.clicks;
    }

    document.getElementById("count").textContent = clicks;
    document.getElementById("btn").addEventListener("click", () => {
      clicks++;
      document.getElementById("count").textContent = clicks;

      // Save after every click
      window.RemixSDK.singlePlayer.actions.saveGameState({
        gameState: { clicks },
      });
    });
  }

  init();
</script>

Platformer with Level Progression

<script>
  let level = 1;
  let coins = 0;

  async function init() {
    await window.RemixSDK.ready();

    // Load
    const saved = window.RemixSDK.gameState;
    if (saved) {
      level = saved.level ?? 1;
      coins = saved.coins ?? 0;
    }

    startLevel(level);
  }

  function onLevelComplete() {
    level++;
    coins += 10;

    // Save at level transitions
    window.RemixSDK.singlePlayer.actions.saveGameState({
      gameState: { level, coins },
    });

    startLevel(level);
  }

  init();
</script>

Tips

  • Keep state small. Only save what's needed to restore the session -- avoid storing large arrays or transient UI state.
  • Save at meaningful moments -- level completion, checkpoints, purchases -- not every frame.
  • State must be JSON-serializable. No functions, class instances, or circular references.
  • Always guard against null. The first time a player loads the game there is no saved state.
Weekly Installs
10
GitHub Stars
6
First Seen
14 days ago
Installed on
claude-code10
opencode4
github-copilot4
codex4
kimi-cli4
gemini-cli4