SankakuComplex - Click on the image to download

Open the image in its best version

// ==UserScript==
// @name         SankakuComplex - Click on the image to download
// @namespace    http://tampermonkey.net/
// @version      2.0
// @description  Open the image in its best version
// @author       mtpontes
// @match       *://chan.sankakucomplex.com/posts/*
// @match       *://chan.sankakucomplex.com/*/posts/*
// @match       *://idol.sankakucomplex.com/posts/*
// @match       *://idol.sankakucomplex.com/*/posts/*
// @match       *://legacy.sankakucomplex.com/posts/*
// @match       *://legacy.sankakucomplex.com/*/posts/*
// @grant        none
// @icon        
// @license MIT
// ==/UserScript==

function imageComponent(principalImage, originalImage, fileName) {
    principalImage.addEventListener('click', async (event) => {
        const image = await fetch(originalImage.href)
        const imageBlog = await image.blob()
        const imageURL = URL.createObjectURL(imageBlog)

        const link = document.createElement('a')
        link.href = imageURL
        link.download = fileName

        document.body.appendChild(link)
        link.click()
        document.body.removeChild(link)
    })
}

(function() {
    'use strict';

    const principalImage = document.getElementById('image')
    const originalImage = document.getElementById('highres');
    const filehref = originalImage.href
    const [fileName, fileExtension] = filehref
        .slice(filehref.lastIndexOf('/') + 1)
        .split('?')[0]
        .split('.');
    console.log(`~~ Valores resgatados: ${fileName}, ${fileExtension}`)

    const allowedExtensions = ['jpg', 'jpeg', 'png']
    if (allowedExtensions.includes(fileExtension.toLowerCase())) {
        imageComponent(principalImage, originalImage, fileName)
    }
})();