Last active
July 20, 2025 16:49
-
-
Save Howard20181/7cb220417da9451f135b9b999845d2ec to your computer and use it in GitHub Desktop.
ColaManga Debug for TachiX extensions
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| // ==UserScript== | |
| // @name ColaManga Debug | |
| // @namespace http://tampermonkey.net/ | |
| // @version 2025-07-15 | |
| // @description try to take over the world! | |
| // @author Howard Wu | |
| // @match *://www.colamanga.com/manga-*/*/*.html | |
| // @icon  | |
| // @grant GM_log | |
| // ==/UserScript== | |
| (function () { | |
| 'use strict' | |
| function waitForElm(selector) { | |
| return new Promise(resolve => { | |
| if (document.querySelector(selector)) { | |
| return resolve(document.querySelector(selector)) | |
| } | |
| const observer = new MutationObserver(() => { | |
| if (document.querySelector(selector)) { | |
| observer.disconnect() | |
| resolve(document.querySelector(selector)) | |
| } | |
| }) | |
| observer.observe(document.body, { | |
| childList: true, | |
| subtree: true | |
| }) | |
| }) | |
| } | |
| let hasImgReady = false | |
| let scrolledOnce = false | |
| let scrolling = false | |
| async function scroll() { | |
| if (scrolling || !hasImgReady) return | |
| scrolling = true | |
| window.scrollTo(0, 0) | |
| await new Promise((resolve, reject) => { | |
| try { | |
| const maxScroll = Number.MAX_SAFE_INTEGER | |
| let lastScroll = 0 | |
| const interval = setInterval(() => { | |
| window.scrollBy(0, 100) | |
| const scrollTop = document.documentElement.scrollTop | |
| if (scrollTop === maxScroll || scrollTop === lastScroll) { | |
| clearInterval(interval) | |
| scrolling = false | |
| scrolledOnce = true | |
| resolve() | |
| } else { | |
| lastScroll = scrollTop | |
| } | |
| }, 100) | |
| } catch (err) { | |
| reject(err.toString()) | |
| } | |
| }) | |
| } | |
| function loadPic(pageIndex) { | |
| if (scrolling || !hasImgReady) return | |
| if (!scrolledOnce) { | |
| scroll() | |
| return | |
| } | |
| document.querySelector("#mangalist").dispatchEvent(new CustomEvent('scroll')) | |
| const page = pageIndex + 1 | |
| const target = document.querySelector(`div.mh_comicpic[p="${page}"] img[src]`) | |
| const mh_loading = document.querySelector(`div.mh_comicpic[p="${page}"] .mh_loading`) | |
| const mh_loaderr = document.querySelector(`div.mh_comicpic[p="${page}"] .mh_loaderr`) | |
| if (target) { | |
| target.scrollIntoView() | |
| target.dispatchEvent(new CustomEvent('scroll')) | |
| } else if (mh_loading?.style.display != 'none') { | |
| mh_loading.scrollIntoView() | |
| mh_loading.dispatchEvent(new CustomEvent('scroll')) | |
| } else if (mh_loaderr?.style.display != 'none') { | |
| mh_loaderr.scrollIntoView() | |
| mh_loaderr.dispatchEvent(new CustomEvent('scroll')) | |
| mh_loaderr.querySelector('.mh_btn')?.click() | |
| } else { | |
| scroll() | |
| } | |
| } | |
| window.__ad = () => { } // Ad placeholder to prevent site anti-ad measures | |
| let pageCount = 0 | |
| waitForElm("#mangalist").then(() => { | |
| pageCount = parseInt($.cookie(__cad.getCookieValue()[1] + mh_info.pageid) || "0") | |
| window.__interface__.setPageCount(pageCount) | |
| }) | |
| const observer = new MutationObserver(() => { | |
| if (document.querySelector("div.mh_comicpic img")) { | |
| const images = document.querySelectorAll("div.mh_comicpic img") | |
| images.forEach(img => { | |
| if (!img._Hijacked) { | |
| const originalSrc = Object.getOwnPropertyDescriptor(img.__proto__, "src") | |
| Object.defineProperty(img, "src", { | |
| ...originalSrc, | |
| set: function (value) { | |
| fetch(value).then(response => { | |
| return response.blob() | |
| }).then(blob => { | |
| const reader = new FileReader() | |
| reader.onloadend = () => { | |
| window.__interface__.setPage(this.parentElement.getAttribute('p') - 1, reader.result) | |
| hasImgReady = true | |
| } | |
| reader.readAsDataURL(blob) | |
| }) | |
| originalSrc.set.call(this, value) | |
| } | |
| }) | |
| img._Hijacked = true | |
| } | |
| }) | |
| if (images.length >= pageCount) { | |
| observer.disconnect() | |
| } | |
| } | |
| }) | |
| observer.observe(document.body, { subtree: true, childList: true }) | |
| window.__interface__ = { | |
| log: (message) => { | |
| GM_log(message) | |
| }, | |
| setPage: (index, data) => { | |
| GM_log(`setPage: index=${index}`) | |
| GM_log(data) | |
| }, | |
| setPageCount: (count) => { | |
| GM_log(`setPageCount: count=${count}`) | |
| } | |
| } | |
| window.addEventListener("message", async (event) => { | |
| if (event.data.type === "load") { | |
| const pageIndex = event.data.page | |
| loadPic(pageIndex) | |
| } | |
| }) | |
| })() | |
| // const data = { type: "load", page: 0 }; window.postMessage(data, "*") |
Author
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Warning: For Android WebView 91 and below,
OffscreenCanvasis not defined.