+
+#define PIN_DPAD_UP 2
+#define PIN_DPAD_DOWN 3
+#define PIN_DPAD_LEFT 4
+#define PIN_DPAD_RIGHT 5
+#define PIN_BUTTON_B1 6
+#define PIN_BUTTON_B2 7
+#define PIN_BUTTON_B3 8
+#define PIN_BUTTON_B4 9
+#define PIN_BUTTON_L1 10
+#define PIN_BUTTON_R1 11
+#define PIN_BUTTON_L2 26
+#define PIN_BUTTON_R2 27
+#define PIN_BUTTON_S1 16
+#define PIN_BUTTON_S2 17
+#define PIN_BUTTON_L3 18
+#define PIN_BUTTON_R3 19
+#define PIN_BUTTON_A1 20
+#define PIN_BUTTON_A2 21
+#define PIN_BUTTON_TURBO -1
+#define PIN_SLIDER_LS -1
+#define PIN_SLIDER_RS -1
+
+#define DEFAULT_SOCD_MODE SOCD_MODE_NEUTRAL
+#define BUTTON_LAYOUT BUTTON_LAYOUT_ARCADE
+```
+
+#### RGB LEDs
+
+GP2040-CE supports per-button WS2812 and similar RGB LEDs.
+
+The following RGB LED options are available in the `BoardConfig.h` file:
+
+| Name | Description | Required? |
+| ------------------------------------------ | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------- |
+| **BUTTON_LAYOUT** | The layout of controls/buttons for use with per-button LEDs and external displays.
Available options are:
`BUTTON_LAYOUT_STICKLESS`
`BUTTON_LAYOUT_WASD` | Yes |
+| **BOARD_LEDS_PIN** | Data PIN for your LED strand | Yes |
+| **LED_FORMAT** | The color data format for the LED chain.
Available options are:
`LED_FORMAT_GRB`
`LED_FORMAT_RGB`
`LED_FORMAT_GRBW`
`LED_FORMAT_RGBW` | No, default value `LED_FORMAT_GRB` |
+| **LEDS_PER_PIXEL** | The number of LEDs per button. | Yes |
+| **LED_BRIGHTNESS_MAXIMUM** | Max brightness value, `uint8_t` 0-255. | Yes |
+| **LED_BRIGHTNESS_STEPS** | The number of brightness steps when using the up/down hotkey. | Yes |
+| **LEDS*DPAD*_X_**
**LEDS*BUTTON*_X_** | The index of the button on the LED chain. Replace the _`X`_ with GP2040-CE button or DPad direction. | Yes |
+| **LEDS_BASE_ANIMATION_INDEX** | The default LED animation index. | No, defaults to `1` |
+| **LEDS_STATIC_COLOR_INDEX** | The default color index for the static color theme | No, defaults to `2` |
+| **LEDS_BUTTON_COLOR_INDEX** | The default color index for the pressed button color | No, defaults to `1` |
+| **LEDS_THEME_INDEX** | The default theme index for static themes | No, defaults to `0` |
+| **LEDS_RAINBOW_CYCLE_TIME** | The color cycle time for rainbow cycle theme | No, defaults to `40` |
+| **LEDS_CHASE_CYCLE_TIME** | The animation speed for the rainbow chase theme | No, defaults to `85` |
+
+An example RGB LED setup in the `BoardConfig.h` file:
+
+```cpp
+// BoardConfig.h
+
+#include "gp2040.h"
+#include "NeoPico.hpp"
+
+#define BUTTON_LAYOUT BUTTON_LAYOUT_STICKLESS
+
+#define BOARD_LEDS_PIN 22
+
+#define LED_BRIGHTNESS_MAXIMUM 100
+#define LED_BRIGHTNESS_STEPS 5
+#define LED_FORMAT LED_FORMAT_GRB
+#define LEDS_PER_PIXEL 2
+
+#define LEDS_DPAD_LEFT 0
+#define LEDS_DPAD_DOWN 1
+#define LEDS_DPAD_RIGHT 2
+#define LEDS_DPAD_UP 3
+#define LEDS_BUTTON_B3 4
+#define LEDS_BUTTON_B4 5
+#define LEDS_BUTTON_R1 6
+#define LEDS_BUTTON_L1 7
+#define LEDS_BUTTON_B1 8
+#define LEDS_BUTTON_B2 9
+#define LEDS_BUTTON_R2 10
+#define LEDS_BUTTON_L2 11
+```
+
+#### Player LEDs
+
+GP2040-CE supports PWM and RGB player LEDs (PLEDs) and can be configured in the `BoardConfig.h` file.
+
+:::note
+
+RGB PLEDs require [RGB LEDs](#rgb-leds) to be configured.
+
+:::
+
+The following PLED options are available in the `BoardConfig.h` file:
+
+| Name | Description | Required? |
+| ------------- | ------------------------------------------------------------------------------------------ | --------- |
+| **PLED_TYPE** | Configures the type of PLEDs.
Available options are: `PLED_TYPE_PWM`, `PLED_TYPE_RGB` | Yes |
+| **PLED1_PIN** | (PWM) The GPIO pin for PLED #1.
(RGB) The index of PLED #1 on the LED chain. | Yes |
+| **PLED2_PIN** | (PWM) The GPIO pin for PLED #2.
(RGB) The index of PLED #2 on the LED chain. | Yes |
+| **PLED3_PIN** | (PWM) The GPIO pin for PLED #3.
(RGB) The index of PLED #3 on the LED chain. | Yes |
+| **PLED4_PIN** | (PWM) The GPIO pin for PLED #4.
(RGB) The index of PLED #4 on the LED chain. | Yes |
+
+An example PLED setup in the `BoardConfig.h` file:
+
+```cpp
+// BoardConfig.h
+
+#include "PlayerLEDs.h"
+
+#define PLED_TYPE PLED_TYPE_RGB
+#define PLED1_PIN 12
+#define PLED2_PIN 13
+#define PLED3_PIN 14
+#define PLED4_PIN 15
+```
+
+#### I2C Displays
+
+GP2040-CE supports 128x64 monochrome displays that run on the SSD1306, SH1106 or SH1107 drivers. The following options are available for displays:
+
+| Name | Description | Required? |
+| -------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------- |
+| **BUTTON_LAYOUT** | The layout of controls/buttons for use with per-button LEDs and external displays.
Available options are:
`BUTTON_LAYOUT_STICKLESS`
`BUTTON_LAYOUT_WASD` | Yes |
+| **HAS_I2C_DISPLAY** | Flag to indicate the controller contains an I2C display module. | No |
+| **DISPLAY_I2C_ADDR** | The I2C address of the display. | No, defaults to `0x3C` |
+| **I2C_SDA_PIN** | The GPIO pin for the I2C SDA line. | If `HAS_I2C_DISPLAY` is enabled |
+| **I2C_SCL_PIN** | The GPIO pin for the I2C SCL line. | If `HAS_I2C_DISPLAY` is enabled |
+| **I2C_BLOCK** | The I2C block on the Pico. Refer to the [Pico Pinout Diagram](https://datasheets.raspberrypi.com/pico/Pico-R3-A4-Pinout.pdf) to identify which block is in use based on the SDA and SCL pins being used.
Available options are:
`i2c0`
`i2c1` | No, defaults to `i2c0` |
+| **I2C_SPEED** | The speed of the I2C bus. `100000` is standard mode, while `400000` is used for fast mode communication. Higher values may be used but will require testing the device for support. | No, defaults to `400000` |
+| **DISPLAY_FLIP** | Flag to flip the rendered display output. Set to `1` to enable. | No, defaults to `0` |
+| **DISPLAY_INVERT** | Flag to invert the rendered display output. Set to `1` to enable. | No, defaults to `0` |
+
+An example I2C display setup in the `BoardConfig.h` file:
+
+```cpp
+#define BUTTON_LAYOUT BUTTON_LAYOUT_WASD
+#define HAS_I2C_DISPLAY 1
+#define I2C_SDA_PIN 0
+#define I2C_SCL_PIN 1
+#define I2C_BLOCK i2c0
+#define I2C_SPEED 800000
+```
+
+#### I2C Display Splash
+
+The firmware also has a splash display feature. The default splash image has been defined in `headers/add-ons/i2cdisplay.h`. The data for the splash image are bytes representing the bitmap to be displayed on the OLED screen. The splash image can be set via the web-config. If you would like to change the default version of the splash image (to preserve it beyond data wipe), it can be customized with a C define named `DEFAULT_SPLASH` in the active `BoardConfig.h` file.
+The instructions on how to generate those bytes are as follows:
+
+1. Navigate to [Bitmap Converter web utility](https://marlinfw.org/tools/u8glib/converter.html)
+2. Configure generated code
+ - Select Marlin 2.x and Bitmap, untick all the rest.
+3. Upload the splash image file
+ - Set the image file after clicking on "Choose file". The image file needs to be preprocessed to your liking and cropped to 128x64. This should populate a code block below.
+4. Use the generated code
+
+ - Copy the hex numbers inside the curly braces from the code block.
+ - Navigate to the `BoardConfig.h` of your choice and at the end of the file right before `#endif`. Create a C define like so:
+
+ ```cpp
+ #define DEFAULT_SPLASH \
+ ```
+
+ - Then paste what you copied below what you just typed. Be sure to edit the array of bytes as follows:
+
+ ```cpp
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \ // First line
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \ // Second line
+ ... // All lines below previous ones end in \ similar to those above
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 // Last line doesn't have an \ to escape the new line
+ ```
+
+ - Here's a sample entry from Pico `BoardConfig.h`:
+
+ ```cpp
+ #define DEFAULT_SPLASH \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x20,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0x80,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xE0,0xDF,0xC0, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x02,0xC1,0xFF,0xA0, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x1F,0xCF,0xFE,0x80, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x3F,0xFF,0xE0,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xAB,0xC0,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x2C,0x00,0x00,0xFB,0x83,0xFF,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0C,0x01,0xFF,0x00,0x01,0xF3,0x07,0xFC,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x1C,0x07,0xFF,0x00,0x03,0xE0,0x3F,0xF4,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x2C,0x38,0x0A,0xE7,0x80,0x03,0xC0,0x5F,0x80,0x00, \
+ 0x00,0x00,0x00,0x20,0x07,0x81,0xFF,0x39,0xC3,0xC7,0x01,0xD7,0x80,0x3F,0x00,0x00, \
+ 0x00,0x00,0x00,0xE0,0x1F,0xE7,0xFF,0x79,0xC7,0x87,0x9F,0xA7,0x80,0x6E,0x3C,0x00, \
+ 0x00,0x00,0xA0,0xC0,0x3F,0xEA,0xE7,0xF3,0xEF,0x07,0x7F,0xC7,0x01,0xCF,0xFF,0x80, \
+ 0x00,0x03,0x8F,0xFC,0x7F,0xC3,0xC7,0x7F,0xFE,0x0F,0x7E,0x8F,0x87,0xDF,0xFC,0x00, \
+ 0x00,0x0F,0xFF,0xFF,0x73,0xC7,0x87,0xFF,0xDE,0x0E,0x50,0x07,0x1F,0x1F,0xD0,0x00, \
+ 0x00,0x1F,0x57,0xFF,0xE7,0x8F,0x07,0xFF,0x1C,0x3E,0x00,0x0F,0xFF,0x7F,0x00,0x00, \
+ 0x00,0x7E,0x0B,0x8F,0x8F,0x8E,0x0F,0xFF,0x9E,0x7C,0x00,0x07,0xFD,0xFC,0x00,0x00, \
+ 0x00,0x7C,0x37,0x9F,0x1F,0x1E,0x0F,0x87,0x1E,0xF8,0x00,0x07,0xF0,0x30,0x00,0x00, \
+ 0x00,0xF1,0xF7,0xFE,0x1E,0x1C,0x3E,0x0E,0x1F,0xF0,0x00,0x01,0x40,0x28,0x00,0x00, \
+ 0x01,0xEF,0xE7,0xF8,0x3C,0x3E,0x7C,0x0F,0x1F,0xE0,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x03,0xFF,0x8F,0xF0,0x7F,0xFE,0xF8,0x0E,0x0F,0x80,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x03,0xFF,0xCF,0xC0,0xFF,0xFF,0xF0,0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0x8B,0xFF,0x01,0xFF,0x8F,0xC0,0x06,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0x87,0xFE,0x01,0xFE,0x0F,0x80,0x04,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0x1F,0xDE,0x03,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0xBF,0x9E,0x01,0xC0,0x00,0x00,0x04,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0xFF,0x9C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x07,0xFB,0x38,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x03,0xE7,0x30,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x01,0x47,0x28,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x0E,0x20,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x04,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x08,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, \
+ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
+ ```
+
+5. Test and verify
+ - Compile, if you did everything right, it should compile fine
+ - Load the UF2 after the compile. Check and verify in the web-config, if you have set a custom image before, you might need to reset data.
diff --git a/versioned_docs/version-0.7.7/development/templates.mdx b/versioned_docs/version-0.7.7/development/templates.mdx
new file mode 100644
index 0000000..7663adb
--- /dev/null
+++ b/versioned_docs/version-0.7.7/development/templates.mdx
@@ -0,0 +1,156 @@
+---
+title: Templates
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "PAGE DESCRIPTION"
+---
+
+# Templates
+
+## Configuration Templates
+
+### README Template
+
+```md
+# Board Name
+
+![Image of Board](site/docs/assets/gp2040-ce-placeholder.png)
+
+Basic description of the board
+
+(RP2040 Pinout as a markdown table)
+| GPIO Pin | Input/Function |
+|:--------:|:--------------:|
+| 0 | |
+| 1 | |
+| 2 | |
+| 3 | |
+| 4 | |
+| 5 | |
+| 6 | |
+| 7 | |
+| 8 | |
+| 9 | |
+| 10 | |
+| 11 | |
+| 12 | |
+| 13 | |
+| 14 | |
+| 15 | |
+| 16 | |
+| 17 | |
+| 18 | |
+| 19 | |
+| 20 | |
+| 21 | |
+| 22 | |
+| 23 | |
+| 24 | |
+| 25 | |
+| 26 | |
+| 27 | |
+| 28 | |
+| 29 | |
+
+Device Maintainer: [Name, Username, or Business Name](https://github.com/username)
+Supported Hardware Variations: List versions/variations that share this configuration
+Hardware Availability: List where one can purchase the boards that share this configuration
+```
+
+## Documentation Templates
+
+### Page Template
+
+```md
+---
+title: TITLE
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "PAGE DESCRIPTION"
+---
+
+# Document Title
+
+CONTENT
+```
+
+### Add-On Template
+
+```md
+---
+title: ADD-ON NAME
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "PAGE DESCRIPTION"
+---
+
+# Add-On Name
+
+Purpose: The intended function and purpose of this add-on for an end user.
+
+![Web Configurator Image](../assets/gp2040-ce-placeholder.png)
+
+## Web Configurator Options
+
+- Web Configurator Option 1
+- Web Configurator Option 2
+- Web Configurator Option 3
+
+## Hardware
+
+### Requirements
+
+TODO: List any hardware that is required for the intended functioning of this add-on.
+
+### Installation
+
+TODO: List instructions on how to install the hardware for use with this add-on.
+
+## Miscellaneous Notes
+
+TODO: Provide any miscellaneous notes that an end user may want or need to know with regard to this add-on.
+```
+
+### Downloads Page Configurations
+
+#### Microcontroller Boards
+
+```tsx
+{
+ name: 'Microcontroller Board Name',
+ configName: 'ConfigName',
+ pinout: null,
+ website: 'http://www.example.com/index.html',
+ image: require('@site/docs/assets/gp2040-ce-placeholder.png').default,
+ supported: true,
+ desc: () => (
+
+ Description of Microcontroller board and manufacturer
+
+ ),
+},
+
+```
+
+#### Controllers
+
+```tsx
+{
+ name: 'Controller Name',
+ configName: 'ConfigName',
+ pinout: null,
+ website: 'http://www.example.com/index.html',
+ image: require('@site/docs/gp2040-ce-placeholder.png').default,
+ category: 'official/open/closed/legacy',
+ desc: () =>
+
+ Description of the device and maker.
+
,
+},
+```
diff --git a/versioned_docs/version-0.7.7/downloads/download-page.mdx b/versioned_docs/version-0.7.7/downloads/download-page.mdx
new file mode 100644
index 0000000..bf7bfdf
--- /dev/null
+++ b/versioned_docs/version-0.7.7/downloads/download-page.mdx
@@ -0,0 +1,48 @@
+---
+title: Downloads
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "Pre-compiled firmware builds for supported devices. Verify that a firmware build (.uf2) is compatible with your device before flashing."
+---
+
+import {
+ Microcontrollers,
+ OfficialDevices,
+ OpenSourceDevices,
+ ClosedSourceDevices,
+ LegacyDevices,
+} from "@site/src/components/Download.tsx";
+
+# Downloads
+
+## Microcontroller Boards
+
+
+
+## Official Project Boards
+
+
+
+## Open Source Community Devices
+
+
+
+## Closed Source Community Devices
+
+
+
+## Legacy Devices
+
+GP2040-CE builds for these devices have been deprecated due to one or more of the following reasons:
+
+- The manufacturer already provides a custom build of GP2040-CE
+- The device is no longer available for purchase
+- The operation of the device running an updated GP2040-CE build cannot be verified by the development team
+
+These builds remain available, however legacy devices are not supported by the GP2040-CE team.
+
+Please ensure you have a backup of the original firmware and your settings before updating your device!
+
+
diff --git a/versioned_docs/version-0.7.7/downloads/flash_nuke.uf2 b/versioned_docs/version-0.7.7/downloads/flash_nuke.uf2
new file mode 100644
index 0000000..31291e6
Binary files /dev/null and b/versioned_docs/version-0.7.7/downloads/flash_nuke.uf2 differ
diff --git a/versioned_docs/version-0.7.7/downloads/force_webconfig.uf2 b/versioned_docs/version-0.7.7/downloads/force_webconfig.uf2
new file mode 100644
index 0000000..8a0f40e
Binary files /dev/null and b/versioned_docs/version-0.7.7/downloads/force_webconfig.uf2 differ
diff --git a/versioned_docs/version-0.7.7/faq/faq-console-compatibility.mdx b/versioned_docs/version-0.7.7/faq/faq-console-compatibility.mdx
new file mode 100644
index 0000000..a5ae3f0
--- /dev/null
+++ b/versioned_docs/version-0.7.7/faq/faq-console-compatibility.mdx
@@ -0,0 +1,209 @@
+---
+title: Console Compatibility
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+toc_min_heading_level: 2
+toc_max_heading_level: 4
+description: "FAQ related to Console Compatibility. Now supports Playstation 4, Playstation 5, Xbox One, Xbox Series S, and Xbox Series S"
+---
+
+# FAQ: Console Compatibility
+
+GP2040-CE supports a wide variety of consoles and the most common questions regarding console compatibility are listed below.
+
+## General
+
+### Is there additional latency when using the PS Passthrough or Xbox One Passthrough add-ons?
+
+As long as PS/Xbox One Passthrough is configured correctly and the passthrough authentication device is properly plugged into the controller, there should be no additional latency. The passthrough authentication device is used solely for authentication without processing inputs and inputs come directly from the GP2040-CE firmware.
+
+### How do I plug in my passthrough authentication device for PS/Xbox One Passthrough?
+
+When using converters and adapters with PS/Xbox One Passthrough add-ons, you plug the device directly into the controller through a USB host port. You do not plug anything else into the converter/adapter.
+
+```mermaid
+graph LR
+Converter/Adapter/Dongle -- USB Port
on controller --> Controller([Controller]) -- USB Port
on console --> Console{{Console}}
+```
+
+
+
+:::caution Incorrect Usage of Converters/Adapters with Passthrough Add-ons
+
+Many users incorrectly plug their controllers into the converters/adapters and then plug the converter/adapter into the console. This is not how Passthrough is intended to be used and will result in additional latency as inputs are processed by the converter/adapter.
+
+Do not plug the converter/adapter as shown below.
+
+```mermaid
+graph LR
+Controller([Controller]) -- USB Port
on Converter --> Converter/Adapter/Dongle -- USB Port
on console --> Console{{Console}}
+```
+
+:::
+
+## Playstation
+
+### Why does my controller stop responding after a while on PS4 or PS5?
+
+PlayStation 4 and PlayStation 5 use an authentication mechanism to ensure only authorized controllers are used on the console. If a device doesn't implement this authentication mechanism the controller is subject to an 8-minute timeout.
+
+Using PS4 mode on a PC does not result in any timeout behavior, but note that XInput is the suggested mode on PC for best compatibility.
+
+### What is the 8-Minute Timeout?
+
+The 8-minute timeout works like this:
+
+1. Plug your controller into the PS4/5
+2. Press the PS button to initialize the controller
+3. Play for roughly 8 minutes
+4. Console rejects the controller due to failed authentication
+5. User unplugs their non-functional controller
+6. Go back to step 1 and repeat
+
+### How do I avoid the 8-Minute Timeout?
+
+GP2040-CE provides multiple methods for you to avoid the 8-Minute Timeout. The recommended method will depend on whether you are using your controller on Playstation 4 or Playstation 5.
+
+For PS4, you can either use the [PS4 Mode add-on](../add-ons/ps4-mode.mdx) or the [PS Passthrough add-on](../add-ons/ps-passthrough.mdx).
+
+For PS5 you can **only** use the [PS Passthrough add-on](../add-ons/ps-passthrough.mdx).
+
+### How do I get my GP2040-CE unit to work on a Playstation 4 or Playstation 5?
+
+For Playstation 4 compatibility, you will need to use either the [PS4 Mode add-on](../add-ons/ps4-mode.mdx) or the [PS Passthrough add-on](../add-ons/ps-passthrough.mdx). If you use PS Passthrough, you will need to disable the PS4 Mode add-on and enable the PS Passthrough add-on. You will also need to ensure that under the `Settings` section you have chosen `PS4` as your input mode and either `Controller` or `Arcade Stick`.
+
+For Playstation 5 compatibility, you **cannot** use the PS4 Mode add-on. You will need to disable the PS4 Mode add-on and then enable the PS Passthrough add-on. You will also need to ensure that under the `Settings` section you have chosen `PS4` as your input mode and picked if you want the GP2040-CE unit to function as a `Arcade Stick`.
+
+:::note
+
+Setting it as `Controller` will not work on Playstation 5 using the PS Passthrough add-on.
+
+:::
+
+### What is PS4 Mode?
+
+PS4 mode is an add-on that grants GP2040-CE compatibility with the Playstation 4 console. Using this add-on requires a few files that can be acquired from a legitimate DualShock 4 controller.
+
+- Private Key
+- Serial Number
+- Signature
+
+It was built using the efforts of another open source firmware project named [Passing Link](https://github.com/passinglink/passinglink). The team behind Passing Link are in no way affiliated with the GP2040-CE project, however the work and information they've made available was greatly appreciated so we could bring this highly-requested feature to our users.
+
+For more information, refer to [PS4 Mode](../add-ons/ps4-mode.mdx) in the `Web Configurator - Add-ons` section of the documentation.
+
+#### How do I get the necessary keys and files for the PS4 Mode add-on?
+
+The GP2040-CE project will not provide **_any_** files or information related to acquiring these keys and files.
+
+:::danger
+
+**Do not ask via any of communication channels (e.g. social media, direct messages, Github Issues, GP2040-CE Discord) as this will result in a permanent blacklist/ban.**
+
+:::
+
+#### How do I know the PS4 Mode add-on is working?
+
+If you're using an OLED display, the input mode will change from `PS4` to `PS4:AS` to indicate your device has successfully authenticated with the PS4/PS5 console. Otherwise the only way to tell is to plug the controller into a PS4 and wait 8 minutes to verify that the controller is still responding afterwards.
+
+### What is PS Passthrough?
+
+:::note Additional Hardware Required
+
+- [USB Host Port](../controller-build/usb-host.mdx)
+- PS4/PS5 Authentication Device
+
+:::
+
+PS Passthrough is an add-on that grants GP2040-CE compatibility with the Playstation 4 or Playstation 5 console by using another controller or dongle to answer authentication
+
+For more information, refer to [PS Passthrough](../add-ons/ps-passthrough.mdx) in the `Web Configurator - Add-ons` section of the documentation.
+
+#### What controller or dongle do I use for PS Passthrough?
+
+:::note
+
+The list of devices is shared between PS4 and PS5 as the controller is authenticating as a licensed, "categorized" PS4 controller. If it works for PS5, it will work for PS4 as well.
+
+:::
+
+There are a number of devices that the PS5 recognizes as a "categorized" controller (e.g. arcade stick, racing wheel, flight sim joystick, etc.) where the developer of the game has supported the use of "categorized" controllers. These devices have the `NXP7105` chips that allow them to authenticate with PS5 consoles.
+
+Any USB device that works as a categorized PS4 controller (arcade stick/racing wheel/flight sim joystick) or a USB dongle that allows a controller to authenticate should work with PS Passthrough. Note that this functionality is not present in all games, but is common in fighting games and racing simulators.
+
+Some devices that do work for PS5 include, but are not limited to;
+
+- [MagicBoots FPS Adapter Joystick Converter for PS4 v1.1](https://www.mayflash.com/product/MAGPS4.html)
+- [N5 for PXN Game Steering Wheel](https://pxn-game.com/products/n5-for-pxn-game-steering-wheel)
+- Licensed PS4 Arcade Sticks
+
+Because your experience and purchased products may vary, GP2040-CE will not provide additional specific recommendations beyond these known working devices.
+
+:::caution Incompatible Controllers
+
+The following controllers are not supported at all with the PS Passthrough add-on
+
+- DualShock 4
+- DualSense
+- DualSense Edge
+- Other licensed PS5 controllers
+
+:::
+
+#### How do I know the PS Passthrough add-on is working?
+
+Because of the numerous devices to be used for passthrough authentication, there is not just one way to verify that the add-on is working without plugging the controller into a PS4 or PS5 and waiting 8 minutes to verify that the controller is still responding afterwards.
+
+For the MagicBoots Adapter and N5 listed above, there is an indicator light on the dongle that should flash on boot and then become solid after a moment. If the indicator light is on and solid, your controllers _should_ be compatible with PS5 at that point and not time out.
+
+#### Can I remove the PS Passthrough authentication device once I have plugged in my controller?
+
+Playstation consoles repeatedly send authorization requests every 30 seconds or so. If the request fails (i.e. there is no passthrough authentication device plugged in), in about 8 minutes, the controller will stop responding. Once this happens, the only option is to either reset the controller or unplug and then plug the controller back into the console.
+
+## Xbox
+
+### How do I get my GP2040-CE unit to work on a Xbox One, Xbox Series S, or Xbox Series X?
+
+For Xbox One, Xbox Series S, or Xbox Series X compatibility, you will need to use the [Xbox One Passthrough add-on](../add-ons/xbox-one-passthrough.mdx).
+
+### What is Xbox One Passthrough?
+
+:::caution Additional Hardware Required
+
+- [USB Host Port](../controller-build/usb-host.mdx)
+- Xbox One Authentication Device
+
+:::
+
+Xbox One Passthrough is an add-on that grants GP2040-CE compatibility with the Xbox One, Xbox Series S, or Xbox Series X by using another controller or dongle to answer authentication
+
+For more information, refer to [Xbox One add-on](../add-ons/xbox-one-passthrough.mdx) in the `Web Configurator - Add-ons` section of the documentation.
+
+### What controller or dongle do I use for Xbox One Passthrough?
+
+Some devices that do work for Xbox One Passthrough are currently limited to the following;
+
+- [MagicBoots FPS Adapter Joystick Converter for Xbox One](https://www.mayflash.com/product/MAGONE.html)
+- [Magic-X Wireless Bluetooth USB Adapter](https://www.mayflash.com/product/magic_x.html)
+
+Because your experience and purchased products may vary, GP2040-CE will not provide additional specific recommendations beyond these known working devices.
+
+:::caution Xbox One Controllers
+
+Xbox Wireless Controllers, Xbox One Elite Controllers, and other licensed Xbox One controllers will not work with this add-on.
+
+:::
+
+### How do I know the Xbox One Passthrough add-on is working?
+
+Because of the numerous devices to be used for passthrough authentication, there is not just one way to verify that the add-on is working without plugging the controller into a console and attempting to use it.
+
+For the MagicBoots Adapter listed above, there is an indicator light on the dongle that should flash on boot and then become solid after a moment. If the indicator light is on and solid, your controllers _should_ be compatible and you may use your controller as intended.
+
+For the Magic-X Adapter listed above, there is an indicator light on the dongle that will continue flashing after the controller boots, unlike the MagicBoots Adapter.
+
+### Can I remove the Xbox One Passthrough authentication device once I have plugged in my controller?
+
+Xbox One, Xbox Series S, and Xbox Series X consoles only perform the authentication process once when the controller is plugged into the console. Once this occurs, the passthrough authentication device can be removed. However, it is still recommended to keep the device plugged in.
diff --git a/versioned_docs/version-0.7.7/faq/faq-general.mdx b/versioned_docs/version-0.7.7/faq/faq-general.mdx
new file mode 100644
index 0000000..ee63d37
--- /dev/null
+++ b/versioned_docs/version-0.7.7/faq/faq-general.mdx
@@ -0,0 +1,81 @@
+---
+title: General FAQ
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "General FAQ related to the GP2040-CE project"
+---
+
+# General FAQ
+
+## General Questions
+
+### Which input mode should I use?
+
+This will depend on the platform you will be playing on:
+
+- Use `XInput Mode` as the preferred mode for compatibility with PC games and 3rd party console adapters
+- Use `PS4 Mode` on PS4, and on PS4 games on PS5 systems
+- Use `PS3 Mode` on PS3, and on PS4 with games that support legacy controllers
+- Use `Switch Mode` on Nintendo Switch
+- Use `Keyboard Mode` for MAME cabinets, PC rhythm games, etc.
+
+If you have a configured USB Host port, Passthrough enabled, and an appropriate authentication device, you can use a GP2040-CE controller in the following situations.
+
+- Use `PS4 Mode` with [PS Passthrough](../add-ons/ps-passthrough.mdx) on PS5 games on PS5 systems that support "categorized" controller (e.g. arcade stick, racing wheel, flight sim joystick, etc.)
+- Use `Xbox One Mode` with [Xbox One Passthrough](../add-ons/xbox-one-passthrough.mdx) on Xbox One, Xbox Series X, and Xbox Series S.
+
+If you are using a Classic or Mini console, there are additional USB input modes to use with these emulated consoles.
+
+- `Sega Genesis/MegaDrive Mini`
+- `NEOGEO Mini`
+- `PC Engine/Turbografx 16 Mini`
+- `EGRET II Mini`
+- `ASTROCITY Mini`
+- `Playstation Classic`
+
+### Does GP2040-CE natively support PS5, Xbox One, or Xbox Series consoles?
+
+These consoles implement security measures that prevent unauthorized accessories from being used. The process of cracking or bypassing that security may not be legal everywhere. These consoles are supported in the future if a user-friendly and completely legal implementation method is found, such as the implementation of [PS4 Mode](../add-ons/ps4-mode.mdx).
+
+Currently PS5, Xbox One, and Xbox Series consoles are supported through passthrough authentication
+
+- PS5 is at present supported using passthrough authentication only; see [PS Passthrough](../add-ons/ps-passthrough.mdx).
+- Xbox One, and Xbox Series consoles are supported using passthrough authentication only; see [Xbox One Passthrough](../add-ons/xbox-one-passthrough.mdx)
+
+### Can I use multiple controllers with GP2040-CE on the same system?
+
+Yes! Each GP2040-CE board is treated as a separate controller. Be sure to only run the embedded web configurator for each controller one at a time.
+
+If you're installing boards with GP2040-CE in an arcade cabinet, check out the [Player Number add-on](../add-ons/player-number.mdx) to force each board to a specific player number.
+
+### Does GP2040-CE really have less than 1 ms of input latency?
+
+Yes! If your platform supports 1000 Hz USB polling, input latency will be less than 1ms. GP2040-CE is configured for 1000 Hz / 1 ms polling by default in all modes, however some systems override or ignore the polling rate the controller requests. The 1000 Hz polling rate is confirmed to work on PC and MiSTer. Even if your platform doesn't support high rate USB polling, GP2040-CE is still reading and processing your inputs as fast as the target system will allow.
+
+### Do the additional features like RGB LEDs, Player LEDs, and OLED displays affect performance?
+
+Not at all! The RP2040 processor of the Pico has two cores. GP2040-CE dedicates one of these cores strictly to reading, processing and sending player inputs. All secondary functions such as LEDs and displays are run on the secondary core. No matter how crazy the feature set becomes, GP2040-CE is unlikely to introduce any additional input latency.
+
+### Why do the buttons have weird labels like B3, A1, S2, etc.?
+
+GP2040-CE uses a generic system for handling button inputs that resembles a traditional PlayStation controller layout with a few extra buttons.
+
+- 4 face buttons (B1-B4)
+- 4 shoulder buttons (L1, L2, R1, R2)
+- Select and Start (S1, S2), 2 stick buttons (L3, R3)
+- 2 auxiliary buttons (A1, A2) for things like Guide, PS and Touchpad, or Home and Capture.
+
+The GP2040-CE documentation and web configurator both provide a dropdown to change the button labels to more familiar controller layouts. You can refer to the button mapping table on the [GP2040-CE Usage](../usage.mdx#buttons) page.
+
+## Technical Questions
+
+### What kind of voodoo is that built-in web configurator?
+
+There's no magic here, just a few cool libraries working together:
+
+- Single page application using React and Bootstrap is embedded in the GP2040-CE firmware
+- TinyUSB library provides virtual network connection via RNDIS
+- lwIP library provides an HTTP server which serves up the embedded React app and the web configuration API
+- ArduinoJson library is used for serialization and deserialization of web API requests
diff --git a/versioned_docs/version-0.7.7/faq/faq-troubleshooting.mdx b/versioned_docs/version-0.7.7/faq/faq-troubleshooting.mdx
new file mode 100644
index 0000000..a928360
--- /dev/null
+++ b/versioned_docs/version-0.7.7/faq/faq-troubleshooting.mdx
@@ -0,0 +1,159 @@
+---
+title: Troubleshooting
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "FAQ related to user-side troubleshooting of common issues"
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+import HotkeyNote from "../snippets/_hotkey-note.mdx";
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+## Input Issues
+
+### Why are my buttons out of order?
+
+There are many different reasons why this could be the case.
+
+#### Incorrect Mapping in Steam
+
+Verify that your controller settings in Steam are correctly set, both global settings and the per-game settings. See [Steam Support](https://partner.steamgames.com/doc/features/steam_controller/getting_started_for_players) for more information on how to resolve this issue.
+
+#### Incorrect Input Mode
+
+Verify that you are using the correct input mode as different modes may swap the mapping of inputs (e.g. Switch vs XInput, PS3/PS4, etc). See [GP2040-CE Usage](../usage.mdx#input-modes) for more information on how to change input modes.
+
+#### Incorrect Button Wiring
+
+Verify that your buttons are correctly connected to the controller board according to the GPIO pin mapping provided by the vendor of your controller board.
+
+#### Incorrect Firmware
+
+Firmware is built to assume a specific GPIO pin out and there may be a mismatch between what the firmware expects and what you expect the controls to be. You can either update the GPIO pin mappings in the [Web Configurator](../web-configurator/menu-pages/02-pin-mapping.mdx) or install the correct firmware onto this device.
+
+See [Incorrect Firmware](#incorrect-firmware-for-a-supported-device) below for more information on how to resolve this issue.
+
+### Why does my button not register when I press it?
+
+Check your wiring. The button should have two terminals where one side goes to the GPIO pin and the other to ground. Test whether wiring is working properly by touching the wires together and verifying that an input is received.
+
+There might also be an issue with your button. Try using different buttons.
+
+### Why do I keep getting an input even though the button is not being pressed?
+
+Check your wiring. There may be an unintended short where the signal wire is in contact with ground (GND) or a wire connected to GND.
+
+There might also be an issue with your button. Try using different buttons.
+
+### Up/Down or Left/Right have been swapped. How do I fix this?
+
+You've likely activated [Invert Y-Axis](../hotkeys.mdx#invert-y-axis) or [Invert X-Axis](../hotkeys.mdx#invert-x-axis) hotkey on your controller. Activate the hotkey again to disable the feature.
+
+
+
+### My SOCD cleaning changed. How do I get it back to X cleaning mode?
+
+You've likely activated one of the following SOCD cleaning mode hotkeys on your controller. Activate the hotkey again to disable the feature.
+
+- [SOCD Up Priority](../hotkeys.mdx#socd-up-priority)
+- [SOCD Neutral](../hotkeys.mdx#socd-neutral)
+- [SOCD Last Win](../hotkeys.mdx#socd-last-win)
+- [SOCD First Wins](../hotkeys.mdx#socd-first-wins)
+- [SOCD Cleaning Off](../hotkeys.mdx#socd-cleaning-off)
+
+
+
+### Why is my DPad stuck outputting directions on the Left/Right Analog Joystick?
+
+You've likely activated [DPad Left Analog](../hotkeys.mdx#dpad-left-analog) or [DPad Right Analog](../hotkeys.mdx#dpad-right-analog) hotkey on your controller. Activate the hotkey again to disable the feature.
+
+
+
+## Connection Issues
+
+### Why is the controller connected to the PC/Console not being recognized?
+
+There are a number of reasons this could be happening. Check for the following issues.
+
+#### Keyboard Mode
+
+Check that the input mode of the device is not in keyboard mode. This will cause your computer to only recognize your controller as a keyboard and not as a gamepad.
+
+#### Web Configurator
+
+When booting into the Web Configurator, the controller initializes as a RNDIS device and will not be recognized by the PC/Console as a controller. Check that the controller is not booting into the Web Configurator and is not being activated while booting.
+
+### Why does my controller not connect to the PC/console when using a USB Type C-C?
+
+Depending on how your device hardware is designed, it may not be set up to use a reversible USB Type C. Try reversing the cable. If that does not work, try using a USB 2.0 Type C-C cable or a USB 2.0 Type C-A cable with an adapter.
+
+### Why does my controller stop responding on Playstation 4 or Playstation 5?
+
+Regarding PS4 disconnection issues, verify that you have the [PS4 Mode](../add-ons/ps4-mode.mdx) add-on is enabled with valid authentication files or the [PS Passthrough](../add-ons/ps-passthrough.mdx) add-on is enabled with a valid passthrough authentication device.
+
+Regarding PS5 disconnection issues. [PS Passthrough](../add-ons/ps-passthrough.mdx) add-on is enabled with a valid passthrough authentication device.
+
+For more information, refer to the [PS4/PS5 Compatibility FAQ](../faq/faq-console-compatibility.mdx).
+
+## Configuration Issues
+
+### Why can't I access the Web Configurator?
+
+If the Web Configurator page is timing out, verify that the controller is booting into Web Configurator Mode.
+
+Test that you are holding when booting, using a using the website like [Gamepad Tester](https://gamepad-tester.com/), or in another application such as the Steam Input Overlay. to verify that you are pressing the correct button.
+
+### Why does PS Passthrough not work on my device?
+
+#### USB Host Port not configured correctly
+
+Verify that your USB host port is correctly configured in the Web Configurator. The specific pins for Data+ and Data- may differ between devices and device manufacturers so check with the documentation provided by the vendor.
+
+For more information, refer to the [PS Passthrough](../add-ons/ps-passthrough.mdx) add-on documentation.
+
+#### Incompatible Controller/Dongle is being used
+
+Only compatible devices will allow the use of a GP2040-CE controller with PS Passthrough to work on PS4 and not all devices will work with PS5.
+
+For more information, refer to the [PS4/PS5 Compatibility FAQ](../faq/faq-console-compatibility.mdx).
+
+### Why are my RGB LEDs the wrong color?
+
+Verify that the `LED Format` is correctly set as different LEDs may have a different order to the Red, Green, and Blue data being sent.
+
+For more information, refer to the [RGB LED Button Order](../web-configurator/menu-pages/05-led-configuration.mdx#rgb-led-button-order) section of the Web Configurator menu.
+
+### Why are my RGB LEDs out of order?
+
+The order of RGB LEDs can be set in the Web Configurator and the correct configuration is determined by the hardware, how the user wires up the LED chain or the device designer set the LED chain on the board.
+
+For more information, refer to the [RGB LED Button Order](../web-configurator/menu-pages/05-led-configuration.mdx#rgb-led-button-order) section of the Web Configurator menu.
+
+### When I updated my device, why did my controller stop working?
+
+If you updated your device and suddenly your inputs aren't correct and your OLED Display or RGB LED stopped working, it's likely that the incorrect compiled firmware was flashed onto your device or your device is not supported and thus the precompiled builds on the [Downloads](../downloads/download-page.mdx) page may not work for your device.
+
+#### Incorrect Firmware for a Supported Device
+
+If your device is supported and the incorrect firmware was flashed, follow the [firmware installation](../installation.mdx) instructions and reflash the correct firmware, verifying that the name of the firmware file matches your device.
+
+#### Unsupported Devices
+
+If your device is not supported, please speak with the vendor you purchased the device from for the proper firmware file to flash onto your device using the [firmware installation](../installation.mdx) instructions.
+
+If your vendor is incapable of supporting their device, you will need to perform some investigative work to properly set up your device.
+
+1. Flash the compiled **Pico** GP2040 firmware from the downloads page using the [firmware installation](../installation.mdx) instructions.
+2. Repeat those steps **_without flash nuking your device_**, flashing this [firmware file](../downloads/force_webconfig.uf2). This will force your device to boot into Web Configurator mode on boot.
+3. Go to Configuration>Pin Mapping
+4. For each gamepad input, use the “Press Button to Map” feature to map the input to a GPIO Pin connected to that button. Repeat for all inputs
+5. For any additional features (e.g. RGB LED, OLED display, USB Host Port, etc.), you will need to determine what GPIO pin is associated. This can be done by tracing physical copper paths on the PCB to the button/component.
+
+No further assistance can be supplied as this last step is entirely determined by the manufacturer and how they designed the PCB, which is unsupported.
diff --git a/versioned_docs/version-0.7.7/getting-help-support.mdx b/versioned_docs/version-0.7.7/getting-help-support.mdx
new file mode 100644
index 0000000..4d5648e
--- /dev/null
+++ b/versioned_docs/version-0.7.7/getting-help-support.mdx
@@ -0,0 +1,27 @@
+---
+title: Getting Help/Support
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "How to get help on issues with GP2040-CE"
+---
+
+# Getting Help/Support
+
+## Discord
+
+If you need help with something, the best place to get quick support is our [Discord Server](https://discord.gg/k2pxhke7q8). Once you've read the [pinned post](https://discord.com/channels/1049366310389289001/1132450634243772519), create a post in the [support channel](https://discord.com/channels/1049366310389289001/1132447732662018089) with the following information.
+
+1. What is the name of the device are you using?
+2. Where did you buy it? Provide a link to sales page.
+3. What version of the firmware are you currently running? Check this via the Web Configurator (e.g. 0.4.3, 0.5.0, 0.7.4, etc.)
+4. Which distribution of the firmware are you currently running? Provide the exact file name (e.g. GP2040-CE_X.X.X_Pico.uf2).
+5. What is the problem that you are having?
+6. What troubleshooting steps have you already done?
+
+If this is a custom device, a hardware issue or you believe the firmware issue may be caused by hardware include any images .
+
+## Github Issues
+
+You can open an [issue on Github](https://github.com/OpenStickCommunity/GP2040-CE/issues/new/choose).
diff --git a/versioned_docs/version-0.7.7/home.mdx b/versioned_docs/version-0.7.7/home.mdx
new file mode 100644
index 0000000..9909c1f
--- /dev/null
+++ b/versioned_docs/version-0.7.7/home.mdx
@@ -0,0 +1,12 @@
+---
+slug: "/"
+hide_title: true
+title: "Home"
+pagination_next: null
+pagination_prev: null
+description: "Homepage for GP2040-CE"
+---
+
+import README from "@site/README.md";
+
+
diff --git a/versioned_docs/version-0.7.7/hotkeys.mdx b/versioned_docs/version-0.7.7/hotkeys.mdx
new file mode 100644
index 0000000..a764e0c
--- /dev/null
+++ b/versioned_docs/version-0.7.7/hotkeys.mdx
@@ -0,0 +1,226 @@
+---
+title: Hotkeys
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "Hotkey descriptions available for use with GP2040-CE"
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+
+# Hotkeys
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+
+:::note
+
+All of the following hotkey bindings can be changed or assigned to different button combinations in [Hotkeys Settings](./web-configurator/menu-pages/01-settings.mdx#hotkey-settings) section of the Web Configurator.
+
+:::
+
+## No Action
+
+This hotkey does nothing. Use this hotkey to disable a specific hotkey combination.
+
+## DPad Digital
+
+This hotkey changes the DPad mode such the directions to be read as digital inputs on the DPad.
+
+**Default**:
+
+## DPad Left Analog
+
+This hotkey changes the DPad mode to such the directions to be read as inputs on the Left analog joystick. The directional input is always the minimum, maximum, or zero value on that axis.
+
+**Default**:
+
+## DPad Right Analog
+
+This hotkey changes the DPad mode to such the directions to be read as inputs on the Right analog joystick. The directional input is always the minimum, maximum, or zero value on that axis.
+
+**Default**:
+
+## Home Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+**Default**:
+
+## Capture Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## SOCD Up Priority
+
+This hotkey changes the SOCD cleaning method to resolve to a neutral input (no input) on the X-axis, but prioritize the `Up` input on the Y-axis when both directions are pressed simultaneously.
+
+**Default**:
+
+| 1st Input + 2nd Input | Result |
+| :-------------------: | :-----: |
+| Left + Right | Neutral |
+| Right + Left | Neutral |
+| Up + Down | Up |
+| Down + Up | Up |
+
+## SOCD Neutral
+
+This hotkey changes the SOCD cleaning method to resolve to a neutral input (no input) on both the X-axis and Y-axis when both directions are pressed simultaneously.
+
+**Default**:
+
+| 1st Input + 2nd Input | Result |
+| :-------------------: | :-----: |
+| Left + Right | Neutral |
+| Right + Left | Neutral |
+| Up + Down | Neutral |
+| Down + Up | Neutral |
+
+## SOCD Last Win
+
+This hotkey changes the SOCD cleaning method to prioritize the second directional input on both the X-axis and Y-axis when both directions are pressed simultaneously.
+
+**Default**:
+
+| 1st Input + 2nd Input | Result |
+| :-------------------: | :----: |
+| Left + Right | Right |
+| Right + Left | Left |
+| Up + Down | Down |
+| Down + Up | Up |
+
+## SOCD First Wins
+
+This hotkey changes the SOCD cleaning method to prioritize the first directional input on both the X-axis and Y-axis when both directions are pressed simultaneously.
+
+| 1st Input + 2nd Input | Result |
+| :-------------------: | :----: |
+| Left + Right | Left |
+| Right + Left | Right |
+| Up + Down | Up |
+| Down + Up | Down |
+
+## SOCD Cleaning Off
+
+This hotkey changes the SOCD cleaning method to not resolve any directional inputs on both the X-axis and Y-axis when both directions are pressed simultaneously. The controller will send both directional inputs.
+
+:::note
+
+This cleaning mode is only available in XInput mode as PS3/DirectInput, PS4 and Nintendo Switch modes do not support setting SOCD Cleaning to Off and will default to Neutral SOCD Cleaning mode.
+
+:::
+
+| 1st Input + 2nd Input | Result |
+| :-------------------: | :------------: |
+| Left + Right | Left and Right |
+| Right + Left | Left and Right |
+| Up + Down | Up and Down |
+| Down + Up | Up and Down |
+
+## Invert X Axis
+
+This hotkey will invert the X-axis of your controller (i.e. pressing the Right button will result a Left input and vice versa).
+
+## Invert Y Axis
+
+This hotkey will invert the Y-axis of your controller (i.e. pressing the Up button will result in a Down input and vice versa).
+
+## Toggle 4-Way Joystick Mode
+
+This hotkey will prevent non-cardinal directions from registering. When a second cardinal direction input is received, the gamepad direction will change to the newest cardinal direction, similar to [SOCD Last Win](#socd-last-win).
+
+## Toggle DDI 4-Way Joystick Mode
+
+This hotkey will alter the behavior of the directional buttons mapped with the [Dual Direction Input](./add-ons/dual-direction-input.mdx) add-on to prevent non-cardinal directions from registering. When a second cardinal direction input is received, the gamepad direction will change to the newest cardinal direction, similar to [SOCD Last Win](#socd-last-win).
+
+## Load Profile #1-4
+
+This hotkey will load various input to pin mapping profiles set in [Profile Settings](./web-configurator/menu-pages/02-pin-mapping.mdx#profile-settings) in the Web Configurator.
+
+:::caution Multiple Load Profile Hotkeys
+
+It is recommended that multiple `Load Profile` hotkeys be configured so as to prevent you from changing profiles without any way to change the profiles back.
+
+:::
+
+## L3 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## R3 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## Touchpad Button
+
+This hotkey emulates a press of the Touchpad button as not all controllers may have this button natively on the controller.
+
+:::note
+
+The Touchpad Button is distinct from the [A1 Button](#a1-button) hotkey as this hotkey will trigger the Touchpad button regardless of whether the toggle for `Switch Touchpad and Share` is on or off.
+
+:::
+
+## Restart GP2040-CE
+
+This hotkey will restart the controller without pressing the hardware reset button on the board (if present) or requiring the controller to be unplugged from the PC or game console.
+
+## B1 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## B2 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## B3 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## B4 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## L1 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## R1 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## L2 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## R2 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## S1 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## S2 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+## A1 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
+
+:::note
+
+The A1 Button hotkey is distinct from the [Touchpad Button](#touchpad-button) hotkey as this hotkey will trigger either the Touchpad button or Share button depending on whether the toggle for [`Switch Touchpad and Share`](./web-configurator/menu-pages/01-settings.mdx#additional-ps4-settings) is on or off.
+
+:::
+
+## A2 Button
+
+This hotkey emulates a press of the button as not all controllers may have this button natively on the controller.
diff --git a/versioned_docs/version-0.7.7/installation.mdx b/versioned_docs/version-0.7.7/installation.mdx
new file mode 100644
index 0000000..2296446
--- /dev/null
+++ b/versioned_docs/version-0.7.7/installation.mdx
@@ -0,0 +1,84 @@
+---
+title: Firmware Installation
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "How to install firmware onto devices"
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+
+# Firmware Installation
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+## General Process
+
+> If the device has been previously used for something other than GP2040-CE, you will need to follow the [Flash Nuke Process](#flash-nuke-process) below first to clear the memory entirely in preparation for installing GP2040-CE.
+
+1. Download the compiled firmware (.uf2 file) for your device
+2. Unplug your device.
+3. Put your device into Bootsel/USB mode. If successful, a new removable drive named `RPI-RP2` should appear in your file explorer.
+
+:::info How to get into Bootsel Mode
+
+- Holding the BootSel button while plugging in
+- Holding while plugging in
+- Holding for 5 seconds.
+
+:::
+
+4. Drag and drop the compiled firmware (.uf2 file) downloaded in step 1 into the removable drive
+5. Wait for the device to automatically disconnect.
+
+Congratulations! The board is now running the GP2040-CE firmware and will appear as a controller on your computer. You can test it in a game, using the website like [Gamepad Tester](https://gamepad-tester.com/), or in another application such as the Steam Input Overlay.
+
+If you would like to customize your device, check out the built-in [Web Configurator](./web-configurator/web-configurator.mdx).
+
+### Example Process (Raspberry Pi Pico)
+
+**The instructions will slightly vary based on your device. These instructions are for a Raspberry Pi Pico.**
+
+1. Download the latest `GP2040-CE_X.X.X_Pico.uf2` file for the Raspberry Pi Pico from the [Download](./downloads/download-page.mdx) page.
+2. Unplug your Pico.
+3. Put your device into Bootsel/USB mode. If successful, a new removable drive named `RPI-RP2` should appear in your file explorer.
+
+:::info How to get into Bootsel Mode
+
+- Holding the BootSel button while plugging in
+- Holding while plugging in
+- Holding for 5 seconds.
+
+:::
+
+4. Drag and drop the `GP2040-CE_X.X.X_Pico.uf2` file into the removable drive.
+5. Wait for the Pico to automatically disconnect.
+
+## Flash Nuke process
+
+:::caution
+
+_Warning_ - Flash nuking your board wipes all your custom configuration for pin mappings and add-ons.
+
+:::
+
+1. Download the [flash_nuke.uf2 file](./downloads/flash_nuke.uf2)
+2. Put your device into Bootsel/USB mode. If successful, a new removable drive named `RPI-RP2` should appear in your file explorer.
+
+:::info How to get into Bootsel Mode
+
+- Holding the BootSel button while plugging in
+- Holding while plugging in
+- Holding for 5 seconds.
+
+:::
+
+3. Drag [flash_nuke.uf2 file](./downloads/flash_nuke.uf2) onto the drive
+4. **_Wait for the drive to disconnect and reconnect without unplugging_**
+5. Drag your firmware onto the RPI drive and wait for disconnect
+6. Check that the controller connects using this [gamepad tester](https://hardwaretester.com/gamepad) and pressing a button.
diff --git a/versioned_docs/version-0.7.7/introduction.mdx b/versioned_docs/version-0.7.7/introduction.mdx
new file mode 100644
index 0000000..d7d2be3
--- /dev/null
+++ b/versioned_docs/version-0.7.7/introduction.mdx
@@ -0,0 +1,41 @@
+---
+id: introduction
+title: Introduction
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "Introduction to GP2040-CE"
+---
+
+# Introduction
+
+Your controller has a board in it that processes your inputs and translates that to commands that your computer or game console understands. GP2040-CE is firmware that facilitates this process, providing compatibility with a number of consoles and input modes. In addition to this, there are many other useful features through the Web Configurator and the system of community developed add-ons.
+
+Not sure if your board can run GP2040-CE? As long as it has a RP2040 microprocessor, it's likely that it can. If your current controller board does not, there are a large number of hobbyist boards from the community that do support GP2040-CE.
+
+## Overview
+
+This section of the documentation is primarily geared towards end users who are looking to use their controllers without diving into the minutiae of configuring and customizing their device. Given a controller, how to get to using it as soon as possible. It consists of the following sections.
+
+- [Firmware Installation](./installation.mdx "GP2040-CE | Firmware Installation"): In the event that you need to install firmware (e.g. setting up a new board, updating to a new version, or as part of troubleshooting)
+- [Usage](./usage.mdx "GP2040-CE | Usage"): Descriptions of the various features and functions available for use with GP2040-CE
+- [Hotkeys](./hotkeys.mdx "GP2040-CE | Hotkeys"): A list of the various hotkey shortcuts available for use with GP2040-CE.
+
+:::note
+
+The actual buttons for the shortcut may differ as they are customizable and can be set by your device's vendor or seller.
+
+:::
+
+- [Web Configurator](./web-configurator/web-configurator.mdx): The built-in web-based configuration application to changes various settings related to firmware operations and features.
+- [RGB LED](./rgb-leds.mdx): A list of the various hotkey shortcuts to control RGB LED animations, color patterns, and behaviors.
+- [Getting Help/Support](./getting-help-support.mdx "GP2040-CE | Getting Help"): How to get help in the event of issues or malfunction
+
+## Additional Resources
+
+If you feel ready to start customizing your controller's functions, have a look at the [`Web Configurator`](./web-configurator/web-configurator.mdx) section of documentation.
+
+If you want to build your own device, check out the `Controller Building` section in the sidebar.
+
+If you want to go even deeper into the firmware to compile your own configuration of the firmware or even contributing to the code, have a look at the [`Contribute`](./development/contribution-guide.mdx) section of the documentation.
diff --git a/versioned_docs/version-0.7.7/rgb-leds.mdx b/versioned_docs/version-0.7.7/rgb-leds.mdx
new file mode 100644
index 0000000..271cb0b
--- /dev/null
+++ b/versioned_docs/version-0.7.7/rgb-leds.mdx
@@ -0,0 +1,80 @@
+---
+title: RGB LEDs
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "How to use addressable RGB LEDs to your controller. Hotkeys and animation themes."
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+
+# RGB LEDs
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+## Hardware Requirements
+
+GP2040-CE requires that addressable RGB LEDs be used for nearly all LED functions.
+
+The exception to this are [Player LEDs](./add-ons/player-number.mdx), which can use pulse width modulation (PWM) to vary the brightness of the LEDs.
+
+## RGB LED Hotkeys
+
+| Hotkey | Description |
+| -------------------------------------- | ---------------------- |
+| | Next Animation |
+| | Previous Animation |
+| | Brightness Up |
+| | Brightness Down |
+| | LED Parameter Up |
+| | LED Parameter Down |
+| | Pressed Parameter Up |
+| | Pressed Parameter Down |
+
+:::note
+
+The `LED Parameter` hotkeys may affect color, speed or theme depending on the current RGB LED animation. The `Pressed Parameter` options will change the colors/effects for the on-press animations.
+
+:::
+
+## RGB LED Animations
+
+The following animations are available:
+
+| Name | Description | LED Parameter |
+| ------------- | ---------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
+| Off | Turn off per-button RGB LEDs | - |
+| Static Color | Sets all LEDs to the same color | Cycle through colors: _Red_, _Orange_, _Yellow_, _Lime Green_, _Green_, _Seafoam_, _Aqua_, _Sky Blue_, _Blue_, _Purple_, _Pink_, _Magenta_ |
+| Rainbow Cycle | All LEDs cycle through the color wheel displaying the same color | Adjust animation speed |
+| Rainbow Chase | A fading, rainbow cycling lines travels across the LED chain | Adjust animation speed |
+| Static Theme | Set the LEDs to a pre-defined static theme | Cycle through themes, see [RGB LED Static Themes](#rgb-led-static-themes) for details. |
+
+## RGB LED Static Themes
+
+| Name | Preview |
+| ------------------------ | ------------------------------------------------------------------------------- |
+| **Static Rainbow** | ![Static Rainbow](./assets/images/led-themes/static-rainbow.png) |
+| **Xbox** | ![Xbox](./assets/images/led-themes/xbox.png) |
+| **Xbox (All)** | ![Xbox (All)](./assets/images/led-themes/xbox-all.png) |
+| **Super Famicom** | ![Super Famicom](./assets/images/led-themes/super-famicom.png) |
+| **Super Famicom (All)** | ![Super Famicom (All)](./assets/images/led-themes/super-famicom-all.png) |
+| **PlayStation** | ![Xbox](./assets/images/led-themes/playstation.png) |
+| **PlayStation (All)** | ![Xbox (All)](./assets/images/led-themes/playstation-all.png) |
+| **Neo Geo Straight** | ![Neo Geo Classic](./assets/images/led-themes/neogeo-straight.png) |
+| **Neo Geo Curved** | ![Neo Geo Curved](./assets/images/led-themes/neogeo-curved.png) |
+| **Neo Geo Modern** | ![Neo Geo Modern](./assets/images/led-themes/neogeo-modern.png) |
+| **Six Button Fighter** | ![Six Button Fighter](./assets/images/led-themes/six-button-fighter.png) |
+| **Six Button Fighter +** | ![Six Button Fighter +](./assets/images/led-themes/six-button-fighter-plus.png) |
+| **Street Fighter 2** | ![Street Fighter 2](./assets/images/led-themes/street-fighter-2.png) |
+| **Tekken** | ![Tekken](./assets/images/led-themes/tekken.png) |
+| **Guilty Gear Type-A** | ![Guilty Gear Type-A](./assets/images/led-themes/guilty-gear-type-a.png) |
+| **Guilty Gear Type-B** | ![Guilty Gear Type-B](./assets/images/led-themes/guilty-gear-type-b.png) |
+| **Guilty Gear Type-C** | ![Guilty Gear Type-C](./assets/images/led-themes/guilty-gear-type-c.png) |
+| **Guilty Gear Type-D** | ![Guilty Gear Type-D](./assets/images/led-themes/guilty-gear-type-d.png) |
+| **Guilty Gear Type-E** | ![Guilty Gear Type-E](./assets/images/led-themes/guilty-gear-type-e.png) |
+| **Fightboard** | ![Fightboard](./assets/images/led-themes/fightboard.png) |
diff --git a/versioned_docs/version-0.7.7/snippets/_add-usb-host-port.mdx b/versioned_docs/version-0.7.7/snippets/_add-usb-host-port.mdx
new file mode 100644
index 0000000..ae80f4e
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_add-usb-host-port.mdx
@@ -0,0 +1,84 @@
+import Tabs from "@theme/Tabs";
+import TabItem from "@theme/TabItem";
+
+
+
+
+### Example Wiring
+
+:::note
+
+While this example wiring guide uses a Raspberry Pi Pico, the general principle applies to **ALL** RP2040 based boards.
+
+:::
+
+![USB Host Wiring Diagram](../assets/images/gpc-add-ons-example-wiring-diagram-usb-host-port.png)
+
+- `VCC` - Connects to 5V power (Example: VBUS on the Raspberry Pi Pico)
+- `D+` - Connects to the `D+` GPIO Pin above, set in the Web Configurator. (Example: GPIO0 on the Raspberry Pi Pico)
+- `D-` - Connects to the `D-` GPIO Pin above, automatically set based on D+. (Example: GPIO1 on the Raspberry Pi Pico)
+- `GND` - Connects to a ground pin, any `GND` pin will work. (Example: GND on the Raspberry Pi Pico)
+
+
+
+:::note
+
+For `D+` and `D-`, any set of GPIO pins can be used from the RP2040. However, there is a requirement that `D-` GPIO must immediately precede or follow `D+` (i.e. `D+` = GPIO Pin X -> `D-` must be X+1 or X-1).
+
+:::
+
+
+
+
+### Example Wiring
+
+Step 1: Take the USB passthrough board and place it on a clean surface.
+
+---
+
+Step 2: Take one of the cables and place it on a clean surface.
+
+:::note
+
+The cables are JST 2.00mm 2pin same direction cables that are 10cm (100mm) in length. They can be made by hand or purchased directly from a variety of sellers on AliExpress. If you plan on installing the USB passthrough board somewhere else in your case you may want to get longer cables. For this install guide you will need three of the cables.
+
+:::
+
+---
+
+Step 3: Connect one end of the first JST 2.00mm 2pin cable into the socket labeled 5V IN on the USB passthrough board.
+
+:::note
+
+The direction of the cable does not matter as they are all same direction cables.
+
+:::
+
+---
+
+Step 4: Connect the other end of the first JST 2.00mm 2pin cable to the socket labeled 5v OUT on the RP2040 Advanced Breakout Board.
+
+---
+
+Step 5: Connect one end of the second JST 2.00mm 2pin cable into the socket labeled D+ OUT on the USB passthrough board.
+
+---
+
+Step 6: Connect the other end of the second JST 2.00mm 2pin cable to the socket labeled OPTION 5 on the RP2040 Advanced Breakout Board.
+
+:::note
+
+You can use other option sockets for this as well, but for the sake of this installation guide we will be using Option 5 and Option 6.
+
+:::
+
+---
+
+Step 7: Connect one end of the third JST 2.00mm 2pin cable into the socket labeled D- OUT on the USB passthrough board.
+
+---
+
+Step 8: Connect the other end of the third JST 2.00mm 2pin cable to the socket labeled OPTION 6 on the RP2040 Advanced Breakout Board.
+
+
+
diff --git a/versioned_docs/version-0.7.7/snippets/_deprecated-add-on.mdx b/versioned_docs/version-0.7.7/snippets/_deprecated-add-on.mdx
new file mode 100644
index 0000000..d96f7e1
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_deprecated-add-on.mdx
@@ -0,0 +1,5 @@
+:::warning
+
+This add-on will soon be deprecated and will be removed in the next version release. Once that occurs, this page will be removed and the add-on added to the [list of deprecated add-ons](../web-configurator/menu-pages/08-add-ons-configuration.mdx#deprecated-add-ons).
+
+:::
diff --git a/versioned_docs/version-0.7.7/snippets/_hotkey-note.mdx b/versioned_docs/version-0.7.7/snippets/_hotkey-note.mdx
new file mode 100644
index 0000000..8ec79c6
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_hotkey-note.mdx
@@ -0,0 +1,5 @@
+:::note Configurable Hotkeys
+
+If the hotkey combination is not present in or differs from the documentation, please refer to the Web Configurator on your device to verify which input combinations are assigned to each hotkey.
+
+:::
diff --git a/versioned_docs/version-0.7.7/snippets/_i2c-block-table.mdx b/versioned_docs/version-0.7.7/snippets/_i2c-block-table.mdx
new file mode 100644
index 0000000..9ad93b2
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_i2c-block-table.mdx
@@ -0,0 +1,10 @@
+| SDA | SCL | I2C Block | SDA | SCL | I2C Block |
+| :--: | :--: | :-------- | :--: | :--: | :-------- |
+| GP00 | GP01 | **I2C0** | GP02 | GP03 | **I2C1** |
+| GP04 | GP05 | **I2C0** | GP06 | GP07 | **I2C1** |
+| GP08 | GP09 | **I2C0** | GP10 | GP11 | **I2C1** |
+| GP12 | GP13 | **I2C0** | GP14 | GP15 | **I2C1** |
+| GP16 | GP17 | **I2C0** | GP18 | GP19 | **I2C1** |
+| GP20 | GP21 | **I2C0** | GP22 | GP23 | **I2C1** |
+| GP24 | GP25 | **I2C0** | GP26 | GP27 | **I2C1** |
+| GP28 | GP29 | **I2C0** | ---- | ---- | ---- |
diff --git a/versioned_docs/version-0.7.7/snippets/_input-table-mini-classic.mdx b/versioned_docs/version-0.7.7/snippets/_input-table-mini-classic.mdx
new file mode 100644
index 0000000..f21b23c
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_input-table-mini-classic.mdx
@@ -0,0 +1,16 @@
+| GP2040-CE | Sega Genesis
MegaDrive Mini | NEOGEO mini | PC Engine
Turbografx 16 Mini | EGRET II Mini | ASTROCITY Mini | Playstation Classic |
+| --------- | ---------------------------------- | ----------- | ----------------------------------- | ------------- | -------------- | ------------------- |
+| B1 | A | B | 1 | A | A | Cross |
+| B2 | B | D | 2 | B | B | Circle |
+| B3 | X | A | - | D | D | Square |
+| B4 | Y | C | - | E | E | Triangle |
+| L1 | - | - | - | - | - | L1 |
+| R1 | Z | - | - | F | F | R1 |
+| L2 | - | - | - | - | - | L2 |
+| R2 | C | - | - | C | C | R2 |
+| S1 | Mode | Select | Start | Start | Credit | Start |
+| S2 | Start | Start | Run | Credit | Start | Select |
+| L3 | - | - | - | - | - | - |
+| R3 | - | - | - | - | - | - |
+| A1 | - | - | - | Menu | - | - |
+| A2 | - | - | - | - | - | - |
diff --git a/versioned_docs/version-0.7.7/snippets/_input-table.mdx b/versioned_docs/version-0.7.7/snippets/_input-table.mdx
new file mode 100644
index 0000000..2d69a66
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_input-table.mdx
@@ -0,0 +1,16 @@
+| GP2040-CE | XInput
Xbox One | Switch | PS4 | PS3 | DirectInput | Arcade |
+| --------- | --------------------- | ------- | -------- | -------- | ----------- | ------ |
+| B1 | A | B | Cross | Cross | 2 | K1 |
+| B2 | B | A | Circle | Circle | 3 | K2 |
+| B3 | X | Y | Square | Square | 1 | P1 |
+| B4 | Y | X | Triangle | Triangle | 4 | P2 |
+| L1 | LB | L | L1 | L1 | 5 | P4 |
+| R1 | RB | R | R1 | R1 | 6 | P3 |
+| L2 | LT | ZL | L2 | L2 | 7 | K4 |
+| R2 | RT | ZR | R2 | R2 | 8 | K3 |
+| S1 | Back | Minus | Share | Select | 9 | Coin |
+| S2 | Start | Plus | Options | Start | 10 | Start |
+| L3 | LS | LS | L3 | L3 | 11 | LS |
+| R3 | RS | RS | R3 | R3 | 12 | RS |
+| A1 | Guide | Home | PS | PS | 13 | Home |
+| A2 | - | Capture | Touchpad | - | 14 | - |
diff --git a/versioned_docs/version-0.7.7/snippets/_pin-options-USB-Host.mdx b/versioned_docs/version-0.7.7/snippets/_pin-options-USB-Host.mdx
new file mode 100644
index 0000000..f98df5b
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_pin-options-USB-Host.mdx
@@ -0,0 +1,9 @@
+- `D+` - The GPIO Pin used to carry Data Plus between the USB Host Port and RP2040
+- `D-` - The GPIO Pin used to carry Data Minus between the USB Host Port and RP2040. This cannot be set and will be automatically determined from `D+`.
+- `5V Power (optional)` - The GPIO Pin used to enable 5V power to the host port on the board.
+
+:::note 5V Power
+
+This is only applicable to a small number of boards (e.g. Adafruit RP2040 Feather USB Host) and most boards do not require this to be set.
+
+:::
diff --git a/versioned_docs/version-0.7.7/snippets/_spi-block-table.mdx b/versioned_docs/version-0.7.7/snippets/_spi-block-table.mdx
new file mode 100644
index 0000000..cd6a835
--- /dev/null
+++ b/versioned_docs/version-0.7.7/snippets/_spi-block-table.mdx
@@ -0,0 +1,10 @@
+| RX | CS | CLK | TX | SPI Block |
+| :--: | :--: | :--: | :--: | :-------: |
+| GP00 | GP01 | GP02 | GP03 | **SPI0** |
+| GP04 | GP05 | GP06 | GP08 | **SPI0** |
+| GP08 | GP09 | GP10 | GP11 | **SPI1** |
+| GP12 | GP13 | GP14 | GP15 | **SPI1** |
+| GP16 | GP17 | GP18 | GP19 | **SPI0** |
+| GP20 | GP21 | GP22 | GP23 | **SPI0** |
+| GP24 | GP25 | GP26 | GP27 | **SPI1** |
+| GP28 | GP29 | ---- | ---- | **SPI1** |
diff --git a/versioned_docs/version-0.7.7/usage.mdx b/versioned_docs/version-0.7.7/usage.mdx
new file mode 100644
index 0000000..2d997aa
--- /dev/null
+++ b/versioned_docs/version-0.7.7/usage.mdx
@@ -0,0 +1,143 @@
+---
+title: GP2040-CE Usage
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "General How-To on using GP2040-CE"
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+import Tabs from "@theme/Tabs";
+import TabItem from "@theme/TabItem";
+import InputTable from "./snippets/_input-table.mdx";
+import InputTableMiniClassic from "./snippets/_input-table-mini-classic.mdx";
+
+# GP2040-CE Usage
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+
+:::caution
+
+The v0.5+ release has some breaking changes to boards other than the Raspberry Pi Pico. If you are using such a board, do not update from an older version unless you have a backup .uf2 from a known good version, or you know what you're doing.
+
+:::
+
+## Buttons
+
+GP2040-CE uses generic button labeling for gamepad state, which is then converted to the appropriate input type before sending. This table provides a map of GP2040-CE buttons to the supported input types and layouts:
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+If your controller is missing dedicated buttons for any specific inputs, check the [Hotkeys page](./hotkeys.mdx) on how to map a button combination that will emulate those missing inputs.
+
+:::note
+
+Unlike other controllers, Keyboard gets different keys for directional buttons. You can change the key mappings for Keyboard mode in [Webconfig mode > Configuration > Keyboard Mapping](./web-configurator/menu-pages/04-keyboard-mapping.mdx)
+
+:::
+
+| Direction | Keyboard |
+| --------- | ----------- |
+| Up | Up Arrow |
+| Down | Down Arrow |
+| Left | Left Arrow |
+| Right | Right Arrow |
+
+## Bootsel Mode
+
+Bootsel Mode is the state of the board where firmware can be flashed onto the board. You will need to use this whenever there is an update or as part of the troubleshooting process.
+
+You can boot into Bootsel Mode by either holding buttons while plugging in the controller, by booting into the Web Configurator and then restarting in Bootsel Mode, or by holding together for five seconds while the controller is plugged in. There is no way to leave Bootsel mode once activated other than by flashing new firmware or by unplugging the device.
+
+Generally, there is a Bootsel button somewhere on the board. This is often an exposed button on the PCB or a button inside the controller that requires either a pin to press or disassembly of the controller.
+
+:::note
+
+There are a number of controllers that elect not to include the Bootsel button. In these instances, you will need to locate the placement of the button and use conductor to connect the 2 sides of the contacts or pads together while plugging in or booting the controller.
+
+:::
+
+## WebConfig Mode
+
+WebConfig Mode is the state of the board where built-in web browser-based configuration application is launched. From here, you can customize and configure your controller as needed. For more information, click [here](./web-configurator/web-configurator.mdx) for more information.
+
+You can boot into WebConfig Mode by holding the button while plugging in the controller or by holding for five seconds while the controller is plugged in. Holding this same combination again for five seconds while in webconfig mode will swap the device back to the previously used controller mode.
+
+## Input Modes
+
+GP2040-CE is compatible with a number of systems and input modes. The specific input modes assigned to 8 buttons when held is configurable in the Web Configurator under [Settings](./web-configurator/menu-pages/01-settings.mdx#boot-input-modes).
+
+However, there are default input modes assigned in precompiled firmware. To change input modes, **hold one of the following buttons as the controller is plugged in:**
+
+| Primary Input Mode | Button Held |
+| :----------------- | :------------------------: |
+| Nintendo Switch | |
+| XInput | |
+| PS3/DirectInput | |
+| PS4 | |
+| Xbox One | |
+| Keyboard | |
+| Original XBox | `Unassigned` |
+
+| Mini/Classic Consoles | Button Held |
+| :--------------------------- | :----------: |
+| Sega Genesis/MegaDrive Mini | `Unassigned` |
+| NEOGEO mini | `Unassigned` |
+| PC Engine/Turbografx 16 Mini | `Unassigned` |
+| EGRET II Mini | `Unassigned` |
+| ASTROCITY Mini | `Unassigned` |
+| Playstation Classic | `Unassigned` |
+
+:::note
+
+Input mode is saved across power cycles.
+
+:::
+
+## Hotkeys
+
+A number of useful hotkeys exist that change the functionality of GP2040 without needing to access the Web Configurator. All of the hotkeys and hotkey bindings can be changed or assigned to different button combinations in [Hotkeys Settings](./web-configurator/menu-pages/01-settings.mdx#hotkey-settings) section of the Web Configurator.
+
+Commonly used hotkeys include changing the directions to emulate a digital DPad, Left analog joystick, Right analog joystick or to change [Simultaneous Opposite Cardinal Direction (SOCD)](https://glossary.infil.net/?t=SOCD) cleaning modes. Different SOCD cleaning modes will ensure the controller obeys certain directional input rules when sending inputs to the computer or game console.
+
+A number of hotkeys are enabled by default and if you are encountering issues with unexpected behavior on your controller, verify that you did not accidentally trigger a hotkey.
+
+| Hotkeys Enabled By Default | Inputs |
+| :------------------------------------------------- | :-------------------------------------- |
+| [Home Button](hotkeys.mdx#home-button) | |
+| [Dpad Digital](hotkeys.mdx#dpad-digital) | |
+| [Dpad Left Analog](hotkeys.mdx#dpad-left-analog) | |
+| [Dpad Right Analog](hotkeys.mdx#dpad-right-analog) | |
+| [SOCD Up Priority](hotkeys.mdx#socd-up-priority) | |
+| [SOCD Neutral](hotkeys.mdx#socd-neutral) | |
+| [SOCD Last Wins](hotkeys.mdx#socd-last-win) | |
+
+:::note
+
+Selected D-Pad mode and SOCD cleaning mode are saved across power cycles.
+
+:::
+
+## Add-Ons and Additional Features
+
+There are a number of add-ons that expand the functionality of GP2040-CE, such as [analog joystick emulation](./add-ons/analog.mdx) and [turbo functions](./add-ons/turbo.mdx). Due to the large number of add-ons created by the community, they are located in a separate documentation page. Navigate to Add-Ons page for more information on the individual add-ons.
diff --git a/versioned_docs/version-0.7.7/web-configurator/community-splash-screens.mdx b/versioned_docs/version-0.7.7/web-configurator/community-splash-screens.mdx
new file mode 100644
index 0000000..b1bac58
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/community-splash-screens.mdx
@@ -0,0 +1,160 @@
+---
+title: Community Splash Screens
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "Community created splash screens for use with an OLED screen"
+---
+
+export const Image = ({ name, path }) => {
+ return (
+
+
+
{name}
+
+ );
+};
+
+# Community Splash Screens
+
+Here is a collection of community created splash screens that can be used with an optional OLED screen. Upload the image using the web configurator to set it up.
+
+All images been formatted to 128x64 in black / white color.
+
+## GP2040-CE
+
+
+
+
+
+
+
+
+
+
+
+## Vendors
+
+
+
+
+
+
+
+## Video Games
+
+
+
+
+
+
+
+
+
+
+
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/00-home.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/00-home.mdx
new file mode 100644
index 0000000..4389ff6
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/00-home.mdx
@@ -0,0 +1,14 @@
+---
+title: Home
+# tags:
+# -
+# pagination_next: null
+pagination_prev: null
+description: "Home page for the GP2040-CE Web Configurator"
+---
+
+# Web Configurator - Home
+
+![GP2040-CE Configurator - Home](../../assets/images/gpc-home.png)
+
+Here you can see the current version of your firmware and the latest version available on GitHub in the releases section. If a firmware update is available, a link to that release will appear.
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/01-settings.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/01-settings.mdx
new file mode 100644
index 0000000..66687fd
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/01-settings.mdx
@@ -0,0 +1,54 @@
+---
+title: Settings
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Select the input mode, DPad Mode, SOCD Cleaning Mode, etc. and configure Hotkey Shortcuts"
+---
+
+# Settings
+
+![GP2040-CE Configurator - Settings](../../assets/images/gpc-settings.png)
+
+Here you can select the basic settings which are normally available via hotkeys.
+
+- `Input Mode` - Choose the main input mode (XINPUT, DINPUT, Switch, PS4, HID-Keyboard) this connected device will boot into when powered on. This selection will persist through unplug and plugging back in the controller.
+- `D-Pad Mode` - Choose the default D-Pad mode (D-Pad, Left Stick or Right Stick).
+- `SOCD Cleaning Mode` - Choose the default SOCD Cleaning Mode (Neutral, Last Win, First Win, OFF). Please note that PS4, PS3 and Nintendo Switch modes do not support setting SOCD to off and will default to Neutral SOCD.
+- `Forced Setup Mode` - Allows you to lock out Input Mode, the ability to enter Web-Config or both. Enabling a web-config lockout will require you to nuke and reload the firmware if you wish to make further changes.
+- `4-Way Joystick Mode` - Enables 4-Way Joystick mode which will prevent non-cardinal directions from registering. When a second cardinal direction input is received, the gamepad direction will change to the newest cardinal direction, similar to [SOCD Last Win](../../hotkeys.mdx#socd-last-win).
+- `Profile Number` - Enables different GPIO pin mappings per profile. Changeable through the Web-Config or [hotkeys](../../hotkeys.mdx#load-profile--1-4).
+- `Debounce Delay in milliseconds` - Timeframe where the firmware will ignore additional inputs to prevent switch noise from accidentally triggering unintended inputs.
+
+## Additional PS4 Settings
+
+![GP2040-CE Configurator - Additional PS4 Settings](../../assets/images/gpc-settings-ps4.png)
+
+- `Switch Touchpad and Share` - Share will now be mapped to A2 rather than S1, Touchpad will be now mapped to S1 rather than A2
+- `PS4 Report Speed Hack` - Disables report counters in the PS4/PS5 reports. This decreases PS4/PS5 latency, but is known to have instability in small number of games. Disable this setting if you are encountering stuck inputs.
+- ` Controller Mode` - Choose what PS4 mode the device will use, either `Controller` or `Arcade Stick`.
+ - `Controller` - The device will function as a native PS4 controller. Primarily intended for use with the [PS4 Mode](../../add-ons/ps4-mode.mdx) add-on and will require the various files be uploaded onto the controller to properly function and avoid the [8-Minute Timeout](../../faq/faq-console-compatibility.mdx#what-is-the-8-minute-timeout).
+ - `Arcade Stick` - The device will function as a licensed PS4 arcade stick, provided that an authentication device is connected and the PS Passthrough add-on is enabled and properly configured. It will also work for the PS5 UI, any PS4 games on the PS5 as well as PS5 titles that support legacy controllers.
+
+:::info
+
+If you wish to play compatible PS5 games, you will need to choose `Arcade Stick` and thus have an authentication device connected and the PS Passthrough add-on enabled and properly configured via a USB passthrough port.
+
+:::
+
+## Boot Input Modes
+
+![GP2040-CE Configurator - Input Boot Modes](../../assets/images/gpc-input-boot-modes.png)
+
+For each of the buttons listed in the menu, you can assign a different input mode to enter while holding that button during boot (e.g. when plugging in the controller or immediately after resetting the controller).
+
+For the list of input modes to select from, see [Input Modes](../../usage.mdx#input-modes).
+
+## Hotkey Settings
+
+![GP2040-CE Configurator - Hotkey Settings](../../assets/images/gpc-hotkey-settings.png)
+
+An arbitrary number of buttons and directions, plus the optional Function (Fn) button, can be used to define desired hotkey actions. Select `Fn` if desired, plus one or more buttons/directions, and associate them with a hotkey action. The default hotkeys can be modified or removed, and new ones added, up to 12 in total.
+
+The available hotkey actions will expand over time. We may also expand the number of hotkeys available to configure in the future. For a list of the available hotkey actions, see [Hotkeys](../../hotkeys.mdx).
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/02-pin-mapping.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/02-pin-mapping.mdx
new file mode 100644
index 0000000..f8cdc58
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/02-pin-mapping.mdx
@@ -0,0 +1,69 @@
+---
+title: Pin Mapping
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Map GPIO pins from RP2040 to gamepad inputs in GP2040-CE"
+---
+
+# Pin Mapping
+
+![GP2040-CE Configurator - Pin Mapping](../../assets/images/gpc-pin-mapping.png)
+
+Here you can remap the GP2040-CE buttons to different GPIO pins on the RP2040 chip. This can be used to simply remap buttons or bypass a GPIO pin that may have issues on your device.
+
+The following options are available for assignment to each GPIO Pin.
+
+- Standard Gamepad inputs found in [Buttons](../../usage.mdx#buttons)
+- [Dual Direction Input](../../add-ons/dual-direction-input.mdx) Up, Down, Left and Right
+- [D-Pad Mode](../../add-ons/joystick-selection-slider.mdx): Digital, Left Stick, and Right Stick
+- [Up Priority SOCD Cleaning](../../hotkeys.mdx#socd-up-priority)
+- [Neutral SOCD Cleaning](../../hotkeys.mdx#socd-neutral)
+- [Last Win SOCD Cleaning](../../hotkeys.mdx#socd-last-win)
+- [First Wins SOCD Cleaning](../../hotkeys.mdx#socd-first-wins)
+- [SOCD Cleaning Off](../../hotkeys.mdx#socd-cleaning-off)
+- [Turbo](../../add-ons/turbo.mdx)
+
+:::note
+
+Options are not limited to a single GPIO pin assignment and can be assigned multiple times (e.g. GPIO pins 0-29 can all be assigned to Up, if desired).
+
+:::
+
+## Pin Viewer :video_game:
+
+This tool is available to see what GPIO pin is physically wired to a button. Click on the button and follow the prompt. It will ask you to press the button and then display a "Pressed pin".
+
+## Map Buttons With :video_game:
+
+![GP2040-CE Configurator - Pin Mapping - "Map buttons with..." ](../../assets/images/gpc-pin-mapping-map-buttons.png)
+
+If you do not know what pins are mapped to which button on your device, there is a tool available to help. Click on the button shown above and follow the prompt. It will ask you to press each standard gamepad input found in [Buttons](../../usage.mdx#buttons) one at a time.
+
+![GP2040-CE Configurator - Pin Mapping - Prompt](../../assets/images/gpc-pin-mapping-map-buttons-prompt.png)
+
+- If you do not wish to map a specific input, you can click `Skip Button` and proceed.
+- If you do not need to map any more inputs, click `Stop Capture`.
+
+## Profiles
+
+You can configure profiles that will change the GPIO to GP2040-CE button mappings based on what profile number you have set. This means that you can have button layouts for different use cases and change between them without the need to enter the Web Configurator and remap GPIO pins.
+
+The profile number either using the Web Configurator on the [Settings page](../../web-configurator/menu-pages/01-settings.mdx) or using a [hotkey shortcut](../../hotkeys.mdx#load-profile--1-4). There is not a default input combination associated with these `Load Profile #1-4` hotkey shortcuts so you will likely need to set them up in the Settings page under [Hotkey Settings](../../web-configurator/menu-pages/01-settings.mdx#hotkey-settings).
+
+:::info
+
+At this time, profiles are limited to changing GPIO pin assignment can cannot be used to change other settings and add-ons that are not directly related to GPIO pin assignment and available to set. This includes, but is not limited to, settings and add-ons such as
+
+- Boot Input Modes
+- Hotkeys
+- Peripheral Mapping
+- Keyboard Mapping Assignments
+- Tilt Input
+- Wii Extension
+- SNES Extension
+- Focus Mode
+- Keyboard Host Button-to-Key mapping
+
+:::
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/03-peripheral-mapping.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/03-peripheral-mapping.mdx
new file mode 100644
index 0000000..6d16d81
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/03-peripheral-mapping.mdx
@@ -0,0 +1,84 @@
+---
+title: Peripheral Mapping
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Map GPIO pins from RP2040 and configure settings for peripherals in GP2040-CE such as I2C and USB Host Ports"
+---
+
+import I2CTable from "../../snippets/_i2c-block-table.mdx";
+import SPITable from "../../snippets/_spi-block-table.mdx";
+
+# Peripheral Mapping
+
+![GP2040-CE Configurator - Peripheral Mapping](../../assets/images/gpc-peripheral-mapping.png)
+
+Here you can assign the GPIO pins necessary for using peripherals and add-ons that require I2C and a USB host port. These include, but are not limited to
+
+- [OLED Display](./07-display-configuration.mdx)
+- [I2C Analog ADS1219](../../add-ons/i2c-analog-ads1219.mdx)
+- [PS Passthrough Add-on](../../add-ons/ps-passthrough.mdx)
+- [Xbox One Passthrough Add-on](../../add-ons/xbox-one-passthrough.mdx)
+- [Keyboard Host Add-on](../../add-ons/keyboard-host.mdx)
+
+:::info
+
+Click on the (i) tool tip in the Web Configurator for more information on the various settings
+
+:::
+
+## I2C
+
+Each I2C block, `I2C0` and `I2C1`, has separate settings and each must be configured before using the respective I2C block. These must be configured properly before any feature or add-on that uses I2C can be used.
+
+- `Toggle` - This will toggle a specific I2C block on and off
+- `SDA` - The GPIO pin used for Serial Data (SDA).
+- `SCL` - The GPIO pin used for Serial clock (SCL).
+- `Speed` - Sets the speed of I2C communication.
+ - `Normal - 100000`
+ - `Fast - 400000`
+ - `Fast Plus - 800000`
+
+:::caution
+
+The SDA and SCL pins must match a pair found on the table below for each I2C block. If this is not configured correctly, your I2C devices will not function properly.
+
+:::
+
+
+
+## SPI
+
+Each SPI block, SPI0 and SPI1, has separate settings and must be configured before using the respective SPI block. These must be configured properly before any feature or add-on that uses SPI can be used.
+
+- `Toggle` - This will toggle a specific SPI block on and off
+- `RX` - The GPIO pin used for MISO, to receive data.
+- `CS` - The GPIO pin used for Chip Select (CS).
+- `SCK` - The GPIO pin used for Serial Clock (SCK).
+- `TX` - The GPIO pin used for MOSI, to send data.
+
+:::caution
+
+The pins must match a set found on the table below for each SPI block. If this is not configured correctly, your SPI devices will not function properly.
+
+:::
+
+
+
+## USB Host
+
+There are not restrictions on which GPIO pins can be used for setting up a USB host port. You can pick any GPIO pin as long as it is available (not being used by any other feature) and the GPIO pin selected for `D+` has a GPIO pin immediately following or preceding it that can be used for `D-` (e.g. GPIO X and GPIO X+/-1).
+
+- `Toggle` - This will toggle the USB Host Port on and off
+- `D+` - The GPIO Pin used to carry Data Plus between the USB Host Port and RP2040
+- `Enable 5V` - The GPIO Pin used to enable 5V power to the host port on the board.
+- `Pin Order` - This setting is based on the order that the Data pins are connected to sequential GPIO pins
+ - `D+/D-` - The GPIO pins are set such that, sequentially, `D+` is immediately followed by `D-` (e.g. D+ = 0. D- = 1)
+ - `D-/D+` -The GPIO pins are set such that, sequentially, `D+` is immediately preceded by `D-` (e.g. D+ = 29, D- = 28)
+
+:::note Enable 5V
+
+Most boards do not require this to be set. This is only applicable to a small number of boards (e.g. Adafruit RP2040 Feather USB Host) as they possess pins for enabling and disabling 5V port on the USB host port.
+
+:::
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/04-keyboard-mapping.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/04-keyboard-mapping.mdx
new file mode 100644
index 0000000..2ad03c8
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/04-keyboard-mapping.mdx
@@ -0,0 +1,14 @@
+---
+title: Keyboard Mapping
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Map gamepad inputs in GP2040-CE to keyboard keycodes for use in Keyboard Input Mode"
+---
+
+# Keyboard Mapping
+
+![GP2040-CE Configurator - Keyboard Mapping](../../assets/images/gpc-keyboard-mapping.png)
+
+Here you can remap the GP2040-CE buttons to different keyboard keycodes that will be sent to the PC or game console when pressed in Keyboard Mode.
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/05-led-configuration.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/05-led-configuration.mdx
new file mode 100644
index 0000000..1a7f99a
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/05-led-configuration.mdx
@@ -0,0 +1,60 @@
+---
+title: LED Configuration
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Configure settings for addressable RGB LEDs on your controller"
+---
+
+# LED Configuration
+
+If you have a setup with per-button RGB LEDs, they can be configured here.
+
+## RGB LED Configuration
+
+![GP2040-CE Configurator - LED Configuration](../../assets/images/gpc-rgb-led-config.png)
+
+- `Data Pin` - The GPIO pin that will drive the data line for your RGB LED chain. Set to `-1` to disable RGB LEDs.
+- `LED Format` - The data format used to communicate with your RGB LEDs. If unsure the default `GRB` value is usually safe.
+- `LED Layout` - Select the layout for your controls/buttons. This is used for static themes and some per-button animations.
+- `LEDs Per Button` - Set the number of LEDs in each button on your chain.
+- `Max Brightness` - Set the maximum brightness for the LEDs. Ranges from 0-255.
+- `Brightness Steps` - The number of levels of brightness to cycle through when turning brightness up and down.
+
+## RGB LED Button Order
+
+:::note
+
+Please note that RGB Button LEDs must be the first LEDs configured. They will start at index 0 on the RGB LED strip.
+
+Also, at the current time, each button can only have one instance in the LED chain. This is the case even if multiple LEDs are assigned per button and multiple buttons are assigned to different GPIO pins.
+
+:::
+
+![GP2040-CE Configurator - RGB LED Button Order](../../assets/images/gpc-rgb-led-button-order.png)
+
+Rearrange the Buttons in the order of the LED Chain. This is different between devices and is determined by manufacturer of the board and LEDs.
+
+## Player LEDs (XInput)
+
+Available selections for `Player LED Type` are `None`, `PWM` or `RGB`.
+
+### PWM Player LEDs
+
+![GP2040-CE Configurator - PWM Player LEDs](../../assets/images/gpc-pled-pwm.png)
+
+- `PLED #[1-4] Pin` - The GPIO pin the standard LED is connected to.
+
+### RGB Player LEDs
+
+:::note
+
+Please note that RGB Player LEDs must be located at an index after the RGB LED Buttons on the LED strip! The Web Config interface will suggest a starting index based on the number of LED buttons mapped in [RGB LED Button Order](#rgb-led-button-order) and the select `LEDs Per Button` value. We hope to remove this limitation in the future.
+
+:::
+
+![GP2040-CE Configurator - PWM Player LEDs](../../assets/images/gpc-pled-rgb.png)
+
+- `PLED #[1-4] Index` - The index of the LED module on the RGB strip.
+- `RGB PLED Color` - Click the box to reveal a color picker, or manually enter the color.
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/06-custom-led-theme.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/06-custom-led-theme.mdx
new file mode 100644
index 0000000..7f1fea9
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/06-custom-led-theme.mdx
@@ -0,0 +1,29 @@
+---
+title: Custom LED Theme
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Create a custom RGB LED theme for your controller with different colors on rest and when pressed"
+---
+
+# Custom LED Theme
+
+![GP2040-CE Configurator - Custom LED Theme](../../assets/images/gpc-rgb-led-custom-theme.png)
+
+- `Enable` - Enables the use of Custom LED Theme.
+- `Preview Layout` - Predefined layouts for previewing LED theme. **NOTE:** This is for preview only, does not affect controller operation.
+- `Clear All` - Prompts for confirmation to reset the current theme to all buttons black (LEDs off). Make sure you have saved and have a backup if you don't want to lose your customizations.
+- `Set All To Color` - Presents a color picker to set all buttons to the same normal or pressed color.
+- `Set Gradient` - Sets a horizontal gradient across the action buttons according to the `Preview Layout` selection.
+- `Set Pressed Gradient` - Same as `Set Gradient`, but for pressed button state.
+- `Save Color` - Save a custom color to the color picker palette.
+- `Delete Color` - Deletes a custom color from the color picker palette. Stock colors cannot be deleted.
+
+:::note
+
+All saved colors and gradient selections are saved to your browser's local storage.
+
+:::
+
+If enabled, the Custom LED Theme will be available as another animation mode and will cycle with the `Previous Animation` and `Next Animation` shortcuts on your controller. You can also use the [Data Backup and Restoration](#data-backup-and-restoration) feature to create and share themes!
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/07-display-configuration.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/07-display-configuration.mdx
new file mode 100644
index 0000000..93f6365
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/07-display-configuration.mdx
@@ -0,0 +1,104 @@
+---
+title: Display Configuration
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Configure settings for an optional OLED display on your controller"
+---
+
+# Display Configuration
+
+GP2040-CE supports the use of a display module such as an OLED with a SSD1306, SH1106, or SH1107 display IC.
+
+![GP2040-CE Configurator - Display Configuration](../../assets/images/gpc-display-config.png)
+
+## Hardware Options
+
+- `Enabled` - Turns on/off the display module.
+- `I2C Block` - The Pico I2C block that will be used. Set based on pins, refer to table on page.
+- `I2C Address` - The I2C address of your device, defaults to the very commonly used `0x3C`.
+
+## Screen Options
+
+- `Flip Display` - Allows you to flip or mirror the display in a variety of ways.
+- `Invert Display` - Inverts the pixel colors, effectively giving you a negative image when enabled.
+
+## Layout Options
+
+:::note Button Layout Combinations
+
+Be sure to pick left and right layouts that match. Some layout combinations result in overlapping buttons on the screen.
+
+:::
+
+- `Button Layout (Left)` - Changes the onscreen layout for the left side of the display and stick.
+- `Button Layout (Right)` - Changes the onscreen layout for the right side of the display and stick.
+- `Splash Mode` - Enables or disables a splash screen displaying when the unit is turned on.
+- `Splash Duration` - Sets the amount of time the splash screen displays for on boot.
+- `Display Saver Timeout` - Will cause the display to turn off after the specified number of minutes. Pressing any input will cause the display to turn back on.
+- `Choose File` - Upload your own image to be used for the splash screen.
+
+## Custom Splash Screen
+
+It is recommend that you use a two color 128x64 image (or one that is sized appropriately for your display). Uploading any other type of image will result in a conversion and sizing of the image automatically.
+
+Supported Formats: BMP, GIF, JPG, JPEG, PNG, WEBP
+
+:::caution
+
+Animated GIFs are not supported at this time.
+
+:::
+
+Check out our collection of great custom splash screens from the community [HERE](../community-splash-screens.mdx)
+
+## Display Elements
+
+![GP2040-CE Configurator - Display Example](../../assets/images/gpc-display-example.png)
+
+This area contains an explanation of display elements and provide an example for how it may appear on your device.
+
+### Top Row
+
+Going from left to right, the display elements are
+
+- [Input Mode](../../usage.mdx#input-modes) - Displays the current input mode
+ - `XINPUT` - XInput
+ - `SWITCH` - Nintendo Switch
+ - `DINPUT` - PS3/DirectInput
+ - `HID-KB` - Keyboard
+ - `PS4` - Controller Mode set as `Controller`, will change to `PS4:AS` on successful authentication
+ - `PS4:AS` - [PS4 Mode](../../add-ons/ps4-mode.mdx) add-on successfully authenticated
+ - `PS5` - Controller Mode Set as `Arcade Stick`, will change to `PS5:AS` on successful authentication
+ - `PS5:AS` - [PS Passthrough](../../add-ons/ps-passthrough.mdx) add-on successfully authenticated
+ - `XBONE` - Xbox One compatible with [Xbox One Passthrough](../../add-ons/xbox-one-passthrough.mdx)
+ - `OGXBOX` - Original XBox
+ - `GEN/MD` - Sega Genesis/MegaDrive Mini
+ - `NGMINI` - NEOGEO mini
+ - `PCE/TG` - PC Engine/Turbografx 16 Mini
+ - `EGRET` - EGRET II Mini
+ - `ASTRO` - ASTROCITY Mini
+ - `PSC` - Playstation Classic
+- [Turbo](../../add-ons/turbo.mdx) - Will display `T##` when Turbo is enabled where ## is the number of presses per second
+- DPad Mode - Displays the current DPad Mode
+ - `D` - [DPad Digital](../../hotkeys.mdx#dpad-digital)
+ - `L` - [DPad Left Analog](../../hotkeys.mdx#dpad-left-analog)
+ - `R` - [DPad Right Analog](../../hotkeys.mdx#dpad-right-analog)
+- SOCD Cleaning Mode - Displays the current SOCD cleaning Mode
+ - `SOCD-U` - [SOCD Up Priority](../../hotkeys.mdx#socd-up-priority)
+ - `SOCD-N` - [SOCD Neutral](../../hotkeys.mdx#socd-neutral)
+ - `SOCD-L` - [SOCD Last Win](../../hotkeys.mdx#socd-last-win)
+ - `SOCD-F` - [SOCD First Wins](../../hotkeys.mdx#socd-first-wins)
+ - `SOCD-X` - [SOCD Cleaning Off](../../hotkeys.mdx#socd-cleaning-off)
+- [Macros](./09-macros.mdx) - `M` will appear if Macros are enabled and this cannot be disabled.
+
+### Middle
+
+The appearance of this area will depend on the particular configuration of your [Button Layouts](#layout-options) on the Left and Right sides
+
+- Turbo Rings - When using the Turbo Mode is enabled on individual buttons, the buttons will have a smaller inner ring as an indicator. When disabled, this button will disappear.
+
+### Bottom
+
+- Input History - Will display input history when the [Input History](../../add-ons/input-history.mdx) add-on is enabled and configured
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/08-add-ons-configuration.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/08-add-ons-configuration.mdx
new file mode 100644
index 0000000..6e13cd6
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/08-add-ons-configuration.mdx
@@ -0,0 +1,45 @@
+---
+title: Add-Ons Configuration
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "General overview for community created add-ons that extend functionality on the GP2040-CE feature set"
+---
+
+# Add-Ons Configuration
+
+This section is for custom add-ons that can be enabled to expand the functionality of GP2040-CE. Due to the large number of add-ons created by the community, each add-on has its own separate documentation page.
+
+:::caution
+
+Some of these add-ons are experimental and not all add-ons are interoperable with all other add-ons.
+
+:::
+
+## Available Add-ons
+
+- [Analog](../../add-ons/analog.mdx)
+- [BOOTSEL Button Configuration](../../add-ons/bootsel-button.mdx)
+- [Buzzer Speaker](../../add-ons/buzzer-speaker.mdx)
+- [Dual Directional Input](../../add-ons/dual-direction-input.mdx)
+- [Focus Mode Configuration](../../add-ons/focus-mode.mdx)
+- [I2C Analog ADS1219](../../add-ons/i2c-analog-ads1219.mdx)
+- [Input History](../../add-ons/input-history.mdx)
+- [Input Reverse](../../add-ons/input-reverse.mdx)
+- [Joystick Selection Slider](../../add-ons/joystick-selection-slider.mdx)
+- [Keyboard Host Configuration](../../add-ons/keyboard-host.mdx)
+- [On-board LED Configuration](../../add-ons/on-board-led.mdx)
+- [Player Number (X-INPUT ONLY)](../../add-ons/player-number.mdx)
+- [PS Passthrough](../../add-ons/ps-passthrough.mdx)
+- [PS4 Mode](../../add-ons/ps4-mode.mdx)
+- [SNES Input](../../add-ons/snes-input.mdx)
+- [SOCD Selection Slider](../../add-ons/socd-selection-slider.mdx)
+- [Tilt Input](../../add-ons/tilt-input.mdx)
+- [Turbo](../../add-ons/turbo.mdx)
+- [Wii Extensions](../../add-ons/wii-extensions.mdx)
+- [Xbox One Passthrough](../../add-ons/xbox-one-passthrough.mdx)
+
+## Deprecated Add-ons
+
+- Extra Button Configuration
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/09-macros.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/09-macros.mdx
new file mode 100644
index 0000000..79129ee
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/09-macros.mdx
@@ -0,0 +1,87 @@
+---
+title: Macro Settings
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Macro settings and how to create input macros"
+---
+
+# Macro Settings
+
+Macros are a series or combination of gamepad inputs triggered with a single button or a combination of buttons.
+
+![GP2040-CE Configurator - Macros](../../assets/images/gpc-macros.png)
+
+## Macro Options
+
+`Macro Button Pin` - The GPIO Pin used to activate macros in combination with other inputs when `Uses Button` is enabled and set.
+
+### Label
+
+This is the name of the macro and is optional.
+
+### Activate
+
+- `Off` - The macro is not available for use.
+- `On` - The macro is available for use when triggered by either the GPIO pin or the combination set in [`Uses Button`](#uses-button).
+
+### Interruptible
+
+- `Off` - The macro cannot be stopped and will execute all lines until the macro is completed.
+- `On` - Any input will stop the current ongoing macro or, if the input is another macro, the interrupting macro trigger will start executing instead.
+
+:::note Interrupting Macros
+
+When a macro stops for any reason and are triggered. again, the macro starts again from the beginning.
+
+:::
+
+### Exclusive
+
+- `Off` - Additional inputs from user will be sent as the macro continues to execute, resulting in a blend of macro and user inputs.
+- `On` - Filters only the macro inputs through and excludes any additional user gamepad inputs
+
+:::note
+
+This option is **only** available when `Interruptible` is disabled.
+
+:::
+
+### Show Frames
+
+- `Off` - The duration in the macro input line editor will appear in milliseconds (ms).
+- `On` - The duration in the macro input line editor will appear as a number of frames, assuming 60 frames per second.
+
+### Uses Button
+
+- `Off` - This macro is assigned to a GPIO pin on the board and when pressed, the macro will be triggered.
+- `On` - This macro is assigned to a button combination of `Macro Button Pin + Input` where the input can be any of the standard gamepad inputs.
+
+### Trigger Mode
+
+This describes is how the GPIO pin or the combination set in [`Uses Button`](#uses-button) triggers and repeats the macro.
+
+- Press - Full press of button triggers the macro once
+- Hold Repeat - Holding button to repeatedly triggers macro
+- Toggle - Full press of button causes the macro to repeatedly trigger, another full press of the button will stop the macro from repeatedly triggering.
+
+## Macro Input Line Editor
+
+Each individual macro has a maximum of 50 lines where each input line has a maximum of 18 gamepad inputs (using all available gamepad inputs).
+
+![GP2040-CE Configurator - Macro Input Line](../../assets/images/gpc-macros-input-line.png)
+
+Each input line is composed of the following elements from left to right.
+
+`Input Line Duration` ms/frame(s) `Inputs` | `Post Input Wait Duration` ms
+
+- Input Line Duration - The duration that the inputs are held for. (Maximum 4,294,967ms or 268,435 frames)
+- Inputs - The inputs to be held during the execution of the input line.
+- Post Input Wait Duration - The duration in-between when that input line finishes executing and when the next line will start executing. (Maximum 4,294,967ms or 268,435 frames)
+
+:::note Deleting Input Lines
+
+To delete an input line, double-click the "x" button.
+
+:::
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/10-data-backup-restoration.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/10-data-backup-restoration.mdx
new file mode 100644
index 0000000..8276c5c
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/10-data-backup-restoration.mdx
@@ -0,0 +1,23 @@
+---
+title: Data Backup and Restoration
+# tags:
+# -
+# pagination_next: null
+# pagination_prev: null
+description: "Backup and Restore your controller settings to an external configuration JSON file"
+---
+
+# Data Backup and Restoration
+
+![GP2040-CE Configurator - Add-Ons Backup and Restore](../../assets/images/gpc-backup-and-restore.png)
+
+- `Backup To File` - Allows you to select what to backup to a file (default is all selected).
+- `Restore From File` - Allows you to select what to restore from a file (default is all selected).
+
+:::warning
+
+As of GP2040-CE version 0.7.6, importing pin mappings from backups made in prior versions will have no effect. If the firmware file for your controller is available, it is recommended to [flash nuke](../../installation.mdx#flash-nuke-process) your controller and flash the GP2040-CE v0.7.6 onto your controllers.
+
+Do note that this will wipe any and all data your controller had prior to the flash nuke process.
+
+:::
diff --git a/versioned_docs/version-0.7.7/web-configurator/menu-pages/11-danger-zone.mdx b/versioned_docs/version-0.7.7/web-configurator/menu-pages/11-danger-zone.mdx
new file mode 100644
index 0000000..2e36d0e
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/menu-pages/11-danger-zone.mdx
@@ -0,0 +1,12 @@
+---
+title: DANGER ZONE
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "Perform a firmware reset on your controller"
+---
+
+# DANGER ZONE
+
+![GP2040-CE Configurator - Reset Settings](../../assets/images/gpc-reset-settings.png)
diff --git a/versioned_docs/version-0.7.7/web-configurator/web-configurator.mdx b/versioned_docs/version-0.7.7/web-configurator/web-configurator.mdx
new file mode 100644
index 0000000..fe9fc07
--- /dev/null
+++ b/versioned_docs/version-0.7.7/web-configurator/web-configurator.mdx
@@ -0,0 +1,59 @@
+---
+title: GP2040-CE Web Configurator
+# tags:
+# -
+pagination_next: null
+pagination_prev: null
+description: "GP2040-CE's Web-Based Configuration Application: Just hold S2 on boot or hold S2+B3+B4 while already plugged in. Then go to http://192.168.7.1 to access the Web Configurator."
+---
+
+import InputLabelSelector, {
+ Hotkey,
+} from "@site/src/components/LabelSelector.tsx";
+
+# GP2040-CE Web Configurator
+
+Select the button labels to be displayed in the usage guide:
+
+
+
+
+GP2040-CE contains a built-in web-based configuration application which can be started by holding when plugging your controller into a PC or by holding for five seconds while the controller is plugged in. Then access [http://192.168.7.1](http://192.168.7.1) in a web browser to begin configuration.
+
+This mode is compatible with Windows, Mac, Linux and SteamOS. Android and iOS devices are not supported at this time.
+
+:::note
+
+Linux distributions may need some extra steps to access the web configurator; see [Linux Setup](#linux-setup).
+
+:::
+
+## Linux Setup
+
+When you plug in your controller while holding , you should see it connect in the kernel logs if you run `dmesg`:
+
+```sh
+[ 72.291060] usb 1-3: new full-speed USB device number 12 using xhci_hcd
+[ 72.450166] usb 1-3: New USB device found, idVendor=cafe, idProduct=4028, bcdDevice= 1.01
+[ 72.450172] usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
+[ 72.450174] usb 1-3: Product: TinyUSB Device
+[ 72.450176] usb 1-3: Manufacturer: TinyUSB
+[ 72.450177] usb 1-3: SerialNumber: 123456
+[ 72.484285] rndis_host 1-3:1.0 usb0: register 'rndis_host' at usb-0000:06:00.1-3, RNDIS device, 02:02:84:6a:96:00
+[ 72.498630] rndis_host 1-3:1.0 enp6s0f1u3: renamed from usb0
+```
+
+In the above example, **enp6s0f1u3** is the virtual Ethernet interface for your controller. If you don't see the first `rndis_host` line, make sure `CONFIG_USB_NET_RNDIS_HOST` is compiled in your kernel or as a module.
+
+The web configurator is automatically running, you just need to be able to reach it. Some configurations automatically set up the route, so try [http://192.168.7.1](http://192.168.7.1) in your browser now. If it doesn't load, try configuring an IP for the interface manually via: `sudo ifconfig enp6s0f1u3 192.168.7.2`.
+
+Whether or not you had to add an IP manually, you should end up with a route something like this:
+
+```sh
+% ip route
+default via 10.0.5.1 dev enp5s0 proto dhcp src 10.0.5.38 metric 2
+10.0.5.0/24 dev enp5s0 proto dhcp scope link src 10.0.5.38 metric 2
+192.168.7.0/24 dev enp6s0f1u3 proto kernel scope link src 192.168.7.2 <---
+```
+
+Then the configurator should be reachable in your browser.
diff --git a/versioned_sidebars/version-0.7.7-sidebars.json b/versioned_sidebars/version-0.7.7-sidebars.json
new file mode 100644
index 0000000..98a2538
--- /dev/null
+++ b/versioned_sidebars/version-0.7.7-sidebars.json
@@ -0,0 +1,92 @@
+{
+ "docSidebar": [
+ {
+ "type": "doc",
+ "id": "home"
+ },
+ {
+ "type": "category",
+ "label": "General",
+ "collapsed": false,
+ "items": [
+ "introduction",
+ "installation",
+ "usage",
+ "hotkeys",
+ {
+ "type": "ref",
+ "label": "Web Configurator",
+ "id": "web-configurator/web-configurator"
+ },
+ "rgb-leds",
+ "getting-help-support"
+ ]
+ },
+ {
+ "type": "category",
+ "label": "FAQ",
+ "collapsed": false,
+ "items": [
+ "faq/faq-general",
+ "faq/faq-console-compatibility",
+ "faq/faq-troubleshooting"
+ ]
+ },
+ {
+ "type": "category",
+ "label": "Controller Building",
+ "collapsed": false,
+ "items": [
+ "controller-build/wiring",
+ "controller-build/usb-host"
+ ]
+ }
+ ],
+ "webConfigSidebar": [
+ "web-configurator/web-configurator",
+ {
+ "type": "category",
+ "label": "Web Configurator Menu",
+ "collapsed": false,
+ "items": [
+ {
+ "type": "autogenerated",
+ "dirName": "web-configurator/menu-pages"
+ }
+ ]
+ },
+ {
+ "type": "category",
+ "label": "Add-Ons",
+ "collapsed": false,
+ "items": [
+ {
+ "type": "autogenerated",
+ "dirName": "add-ons"
+ }
+ ]
+ }
+ ],
+ "contributeSidebar": [
+ "development/contribution-guide",
+ {
+ "type": "category",
+ "label": "Firmware",
+ "collapsed": false,
+ "items": [
+ "development/firmware-development"
+ ]
+ },
+ {
+ "type": "category",
+ "label": "Documentation",
+ "collapsed": false,
+ "items": [
+ "development/documentation-versioning",
+ "development/documentation-preview",
+ "development/documentation-update-downloads"
+ ]
+ },
+ "development/templates"
+ ]
+}
diff --git a/versions.json b/versions.json
new file mode 100644
index 0000000..dd86bef
--- /dev/null
+++ b/versions.json
@@ -0,0 +1,3 @@
+[
+ "0.7.7"
+]