itch.io Bundle to Library

This adds a handy button to a bundle to add all them gamez

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name        itch.io Bundle to Library
// @description This adds a handy button to a bundle to add all them gamez
// @namespace   ceremony.itchio.bundlelibrary
// @match       https://itch.io/bundle/download/*
// @grant       none
// @version     1.1
// @author      Ceremony
// ==/UserScript==

/*jshint esversion: 6 */
let games = [];
document.querySelectorAll(".game_row form.form").forEach((form) => {
  let data = [];
  form.querySelectorAll("*[name]").forEach((el) => {
    data.push(encodeURIComponent(el.name) + "=" + encodeURIComponent(el.value));
  })
  games.push(data.join("&"));
});


async function postData(game) {
  const response = await fetch(window.location.href, {
    method: 'POST',
    headers: {
      'Content-Type': 'application/x-www-form-urlencoded',
    },
    redirect: 'manual',
    body: game
  });

  next();
}

function next() {
  if (game = games.pop()) {
    button.textContent = "Adding " + (games.length + 1) + " game(s) to your library! Please wait!";
    postData(game);
  } else {
    button.textContent = "Added all games on this page!"
  }
}

var button = document.createElement("p");
button.style.fontWeight = "bold";

if (games.length) {
  button.addEventListener("click", () => {
    button.style.cursor = "";
    next();
  }, { once: true });
  button.textContent = "Found " + games.length + " game(s) not yet added to your library. Click here to add them!";
  button.style.cursor = "pointer";
} else {
  button.textContent = "No unclaimed games found! Try another page!"
}

document.querySelector(".game_outer").insertBefore(button, document.querySelector(".game_outer p:not([class])"))