Greasy Fork is available in English.

Pixiv Auto Like

Click **like** automatically in new illust pages

// ==UserScript==
// @name         Pixiv Auto Like
// @name:zh-TW   Pixiv 自動點讚
// @description        Click **like** automatically in new illust pages
// @description:zh-TW  在新版頁面自動點讚
// @namespace    https://github.com/FlandreDaisuki
// @version      1.3.1
// @author       FlandreDaisuki
// @include      *://www.pixiv.net/artworks/*
// @require      https://unpkg.com/sentinel-js@0.0.5/dist/sentinel.js
// @icon         
// @grant        none
// @compatible   firefox
// @compatible   chrome
// @noframes
// ==/UserScript==

/* global sentinel */

const $ = (s) => document.querySelector(s);

registerReactiveEvent('_35vRH4a', '_3eF4D7o', '_1vHxmVH', '_2sram-m');
registerReactiveEvent('Ki5EGTG', 'v2zpsfm', '_2iDv0r8', '_1YUwQdz');

// pixiv 不把東西放在 window 了,麻煩
async function fetchPixivGlobalData() {
  const resp = await fetch('/');
  const html = await resp.text();
  const metaHTMLs = html.match(/<meta[^>]*>/g);
  return metaHTMLs.filter((metaHTML) => metaHTML.includes('global-data'))
    .map((metaHTML) => {
      const h = document.createElement('head');
      h.innerHTML = metaHTML;
      return h;
    }).map((h) => JSON.parse(h.firstChild.content))[0];
}

function registerReactiveEvent(btnClass, svgClass, btnActiveClass, svgActiveClass) {
  sentinel.on(`button.${btnClass}:not(.${btnActiveClass})`, async() => {
    const likeBtn = $(`button.${btnClass}`);
    const likeSVG = $(`svg.${svgClass}`);

    const globalInitData = await fetchPixivGlobalData();

    const resp = await fetch('/ajax/illusts/like', {
      method: 'POST',
      headers: {
        Accept: 'application/json',
        'Content-Type': 'application/json',
        'x-csrf-token': globalInitData.token,
      },
      credentials: 'same-origin',
      body: JSON.stringify({
        illust_id: location.pathname.replace('/artworks/', ''),
      }),
    });

    const data = await resp.json();
    if (!data.error) {
      if (likeBtn) {
        likeBtn.classList.add(btnActiveClass);
      }
      if (likeSVG) {
        likeSVG.classList.add(svgActiveClass);
        const svgPath = document.createElementNS('http://www.w3.org/2000/svg', 'path');
        svgPath.setAttribute('d', `M5,7.08578644 L9.29289322,2.79289322 C9.68341751,2.40236893 10.3165825,2.40236893 10.7071068,
2.79289322 C11.0976311,3.18341751 11.0976311,3.81658249 10.7071068,4.20710678 L5,9.91421356 L2.29289322,
7.20710678 C1.90236893,6.81658249 1.90236893,6.18341751 2.29289322,5.79289322 C2.68341751,5.40236893 3.31658249,
5.40236893 3.70710678,5.79289322 L5,7.08578644 Z`);
        while (likeSVG.firstChild) {
          likeSVG.firstChild.remove();
        }
        likeSVG.appendChild(svgPath);
      }
    }
  });
}